/* =====================================================
   RSF SOFT — 3D Animated Premium Website
   ===================================================== */

/* Fonts loaded via <link> in HTML head for non-blocking render */

/* ---- Performance ---- */
/* Hide Three.js canvas on mobile to save resources */
@media (max-width: 768px) { #three-canvas { display: none !important; } }

/* Reduce motion for accessibility & performance */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
  .hero-glow-1, .hero-glow-2, .cube, .message-ticker, .hero-grid { animation: none !important; }
}

/* Optimise will-change — only where needed */
.navbar { will-change: background-color; }
.btn-primary-3d { will-change: transform; }
.dropdown-menu { will-change: opacity, transform; }

/* Content-visibility for lazy rendering of off-screen content */
.section, .content-section, .content-section-alt, .stats-section, .message-cards-section { content-visibility: auto; contain-intrinsic-size: 0 500px; }

/* Font fallback to prevent CLS */
body { font-family: 'Outfit', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; }

/* ---- Variables ---- */
:root {
  --bg-primary: #04070f;
  --bg-secondary: #080d1a;
  --bg-card: rgba(255,255,255,0.04);
  --bg-card-hover: rgba(255,255,255,0.08);
  --accent-violet: #7c3aed;
  --accent-cyan: #06d6f0;
  --accent-purple: #a855f7;
  --accent-pink: #ec4899;
  --gradient-primary: linear-gradient(135deg,#7c3aed 0%,#06d6f0 100%);
  --gradient-hero: linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#06d6f0 100%);
  --text-primary: #f0f6ff;
  --text-secondary: #94a3b8;
  --text-muted: #4b5e7a;
  --border-glass: rgba(255,255,255,0.07);
  --border-glow: rgba(124,58,237,0.5);
  --shadow-glow: 0 0 60px rgba(124,58,237,0.25);
  --shadow-card: 0 20px 60px rgba(0,0,0,0.5);
  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 26px;
  --radius-xl: 36px;
  --transition: all 0.4s cubic-bezier(0.4,0,0.2,1);
  --font-primary: 'Outfit', sans-serif;
  --font-secondary: 'Inter', sans-serif;
}

/* =====================================================
   PERFORMANCE OPTIMIZATIONS
   ===================================================== */
/* Use content-visibility for off-screen content */
.section, .content-section, .content-section-alt {
  content-visibility: auto;
  contain-intrinsic-size: 0 500px;
}

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .hero-glow-1, .hero-glow-2 { animation: none; }
  .cube { animation: none; }
  .message-ticker { animation: none; }
}

/* Optimize will-change - only apply where needed */
.navbar { will-change: background-color; }
.btn-primary-3d { will-change: transform; }
.dropdown-menu { will-change: opacity, transform; }

/* Prevent CLS from font loading */
html { font-family: system-ui, -apple-system, sans-serif; }
body { font-family: 'Outfit', system-ui, -apple-system, sans-serif; }

/* Optimize images */
img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Three.js canvas - hide on mobile for performance */
@media (max-width: 768px) {
  #three-canvas { display: none !important; }
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font-primary);background:var(--bg-primary);color:var(--text-primary);line-height:1.7;overflow-x:hidden;}
a{text-decoration:none;color:inherit;transition:var(--transition);}
ul{list-style:none;}
img{max-width:100%;display:block;}

::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg-primary);}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#7c3aed,#06d6f0);border-radius:3px;}
::selection{background:rgba(124,58,237,0.35);color:#fff;}

/* =====================================================
   THREE.JS CANVAS (FULL BACKGROUND)
   ===================================================== */
#three-canvas {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  z-index: 0;
  pointer-events: none;
}

/* =====================================================
   TOP BAR
   ===================================================== */
.top-bar {
  position: relative;
  z-index: 100;
  background: linear-gradient(90deg, rgba(124,58,237,0.9), rgba(6,214,240,0.8));
  backdrop-filter: blur(20px);
  padding: 9px 0;
  text-align: center;
  font-size: 0.8rem;
  font-weight: 600;
  color: white;
  letter-spacing: 0.4px;
}
.top-bar a{color:white;text-decoration:underline;opacity:0.9;}
.top-bar a:hover{opacity:1;}
.top-bar-ticker{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;}
.ticker-sep{opacity:0.3;}

/* =====================================================
   NAVBAR
   ===================================================== */
.navbar {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(4,7,15,0.75);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border-glass);
  transition: var(--transition);
}
.navbar.scrolled{background:rgba(4,7,15,0.96);box-shadow:0 4px 40px rgba(0,0,0,0.6);}

.nav-container{max-width:1300px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:74px;}
.nav-logo img{height:46px;width:auto;filter:brightness(1.15);}

.nav-menu{display:flex;align-items:center;gap:4px;}
.nav-link{padding:9px 15px;border-radius:10px;font-size:0.88rem;font-weight:500;color:var(--text-secondary);transition:var(--transition);}
.nav-link:hover{color:var(--text-primary);background:var(--bg-card);}

.nav-item.has-dropdown{position:relative;}
.nav-item.has-dropdown>.nav-link::after{content:'▾';margin-left:4px;font-size:0.68rem;opacity:0.5;}

.dropdown-menu{
  position:absolute;top:calc(100% + 10px);left:0;
  background:rgba(8,13,26,0.98);backdrop-filter:blur(24px);
  border:1px solid var(--border-glass);border-radius:var(--radius-md);
  padding:8px;min-width:210px;
  opacity:0;visibility:hidden;transform:translateY(-10px) scale(0.97);
  transition:all 0.25s ease;box-shadow:var(--shadow-card);
}
.nav-item.has-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0) scale(1);}
.dropdown-menu a{display:block;padding:9px 14px;font-size:0.85rem;color:var(--text-secondary);border-radius:8px;transition:var(--transition);}
.dropdown-menu a:hover{color:var(--text-primary);background:var(--bg-card-hover);padding-left:20px;}

.nav-cta{
  background:var(--gradient-primary) !important;
  color:white !important;padding:10px 24px !important;
  border-radius:40px !important;font-weight:700 !important;
  font-size:0.85rem !important;
  box-shadow:0 4px 24px rgba(124,58,237,0.4);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 40px rgba(124,58,237,0.6) !important;}

.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;}
.nav-toggle span{width:24px;height:2px;background:var(--text-primary);border-radius:2px;transition:var(--transition);}

/* =====================================================
   HERO 3D SECTION
   ===================================================== */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  z-index: 1;
  overflow: hidden;
}

/* Scanline effect */
.hero::before {
  content:'';
  position:absolute;inset:0;
  background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(6,214,240,0.015) 2px, rgba(6,214,240,0.015) 4px);
  pointer-events:none;z-index:1;
}

/* Radial glow overlays */
.hero-glow-1{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,0.18) 0%,transparent 70%);top:-200px;right:-150px;animation:breathe 6s ease-in-out infinite;z-index:0;}
.hero-glow-2{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(6,214,240,0.12) 0%,transparent 70%);bottom:-150px;left:-100px;animation:breathe 8s ease-in-out infinite 2s;z-index:0;}

@keyframes breathe{0%,100%{transform:scale(1);opacity:0.8;}50%{transform:scale(1.15);opacity:1;}}

/* Grid lines */
.hero-grid{
  position:absolute;inset:0;
  background-image: linear-gradient(rgba(124,58,237,0.07) 1px, transparent 1px), linear-gradient(90deg, rgba(124,58,237,0.07) 1px, transparent 1px);
  background-size: 60px 60px;
  animation:gridMove 20s linear infinite;
  z-index:0;
}
@keyframes gridMove{0%{background-position:0 0;}100%{background-position:60px 60px;}}

.hero-content{
  position:relative;z-index:2;
  max-width:1300px;margin:0 auto;padding:0 28px;width:100%;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}

/* LEFT: text */
.hero-text-block{}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(124,58,237,0.12);border:1px solid rgba(124,58,237,0.35);
  padding:7px 18px;border-radius:40px;
  font-size:0.75rem;font-weight:700;color:var(--accent-violet);
  letter-spacing:1.5px;text-transform:uppercase;
  margin-bottom:24px;
  animation:slideInLeft 0.8s ease both;
}
.hero-badge-dot{width:7px;height:7px;background:var(--accent-cyan);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.4;transform:scale(1.6);}}

.hero-title{
  font-size:clamp(2.5rem,5vw,4.6rem);font-weight:900;line-height:1.08;
  margin-bottom:20px;
  animation:slideInLeft 0.8s ease 0.1s both;
}
.hero-title .line1{display:block;color:var(--text-primary);}
.hero-title .line2{display:block;}
.hero-title .line3{display:block;color:var(--text-primary);}

.gradient-text{
  background:var(--gradient-hero);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* Typewriter container */
.typewriter-wrap{
  font-size:clamp(2rem,4vw,3.8rem);font-weight:900;
  background:var(--gradient-hero);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  min-height:1.2em;display:inline-block;
}
.typewriter-cursor{
  display:inline-block;width:3px;background:var(--accent-cyan);
  animation:blink 0.8s ease infinite;margin-left:3px;vertical-align:middle;height:0.85em;
  border-radius:2px;
}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}

.hero-subtitle{
  font-family:var(--font-secondary);font-size:1.05rem;color:var(--text-secondary);
  max-width:520px;margin-bottom:36px;line-height:1.85;
  animation:slideInLeft 0.8s ease 0.3s both;
}

.hero-actions{display:flex;gap:14px;flex-wrap:wrap;animation:slideInLeft 0.8s ease 0.4s both;}

.btn-primary-3d{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 34px;background:var(--gradient-primary);
  color:white;font-family:var(--font-primary);font-size:0.95rem;font-weight:700;
  border:none;border-radius:50px;cursor:pointer;
  transition:var(--transition);
  box-shadow:0 8px 32px rgba(124,58,237,0.4), 0 2px 0 rgba(255,255,255,0.15) inset;
  position:relative;overflow:hidden;
}
.btn-primary-3d::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s;}
.btn-primary-3d:hover::before{left:100%;}
.btn-primary-3d:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 20px 60px rgba(124,58,237,0.6);}

.btn-glass{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 34px;background:rgba(255,255,255,0.05);
  color:var(--text-primary);font-family:var(--font-primary);font-size:0.95rem;font-weight:600;
  border:1px solid rgba(255,255,255,0.12);border-radius:50px;cursor:pointer;
  transition:var(--transition);backdrop-filter:blur(12px);
}
.btn-glass:hover{border-color:rgba(124,58,237,0.5);background:rgba(124,58,237,0.1);transform:translateY(-4px);}

/* RIGHT: 3D Dashboard Visual */
.hero-visual{
  display:flex;align-items:center;justify-content:center;
  animation:slideInRight 1s ease 0.2s both;
  perspective:1200px;
}

.dashboard-3d{
  width:100%;max-width:520px;
  transform-style:preserve-3d;
  animation:floatCard 6s ease-in-out infinite;
}

@keyframes floatCard{0%,100%{transform:rotateX(8deg) rotateY(-12deg) translateY(0);}50%{transform:rotateX(12deg) rotateY(-8deg) translateY(-20px);}}

.dash-main{
  background:rgba(8,13,26,0.85);
  border:1px solid rgba(124,58,237,0.25);
  border-radius:24px;padding:28px;
  backdrop-filter:blur(20px);
  box-shadow:0 30px 80px rgba(0,0,0,0.5), 0 0 60px rgba(124,58,237,0.15), inset 0 1px 0 rgba(255,255,255,0.08);
  transform-style:preserve-3d;
}

.dash-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.dash-dot{width:10px;height:10px;border-radius:50%;}
.dash-dot.red{background:#ff5f57;}
.dash-dot.yellow{background:#ffbd2e;}
.dash-dot.green{background:#28ca41;}
.dash-title{font-size:0.78rem;color:var(--text-muted);margin-left:auto;font-family:var(--font-secondary);}

.dash-metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;}

.dash-metric{
  background:rgba(124,58,237,0.08);border:1px solid rgba(124,58,237,0.15);
  border-radius:14px;padding:14px 12px;text-align:center;
  transition:var(--transition);
  transform-style:preserve-3d;
}
.dash-metric:hover{transform:translateZ(10px);background:rgba(124,58,237,0.15);}
.dash-metric-num{font-size:1.4rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.dash-metric-label{font-size:0.68rem;color:var(--text-muted);margin-top:2px;}

.dash-chart{margin-bottom:16px;}
.dash-chart-label{font-size:0.72rem;color:var(--text-muted);margin-bottom:8px;}
.chart-bars{display:flex;align-items:flex-end;gap:6px;height:60px;}
.bar{
  flex:1;background:var(--gradient-primary);border-radius:4px 4px 0 0;
  transition:height 0.8s ease;
  box-shadow:0 0 12px rgba(124,58,237,0.4);
}

.dash-tags{display:flex;flex-wrap:wrap;gap:6px;}
.dash-tag{
  padding:5px 12px;background:rgba(6,214,240,0.1);border:1px solid rgba(6,214,240,0.2);
  border-radius:20px;font-size:0.72rem;font-weight:600;color:var(--accent-cyan);
  animation:tagPop 0.4s ease backwards;
}

/* Floating satellite cards */
.sat-card{
  position:absolute;
  background:rgba(8,13,26,0.9);border:1px solid rgba(124,58,237,0.3);
  border-radius:14px;padding:12px 16px;
  backdrop-filter:blur(16px);
  box-shadow:0 16px 40px rgba(0,0,0,0.4), 0 0 20px rgba(124,58,237,0.15);
  font-size:0.78rem;font-weight:600;
  animation:floatSat 4s ease-in-out infinite;
  white-space:nowrap;
}
.sat-card-1{top:-24px;right:-40px;animation-delay:0s;color:var(--accent-cyan);}
.sat-card-2{bottom:-20px;left:-50px;animation-delay:1.5s;color:#10b981;}
.sat-card-3{top:50%;right:-60px;animation-delay:0.8s;color:#f59e0b;}

@keyframes floatSat{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}

.sat-icon{margin-right:6px;}

/* Hero stats */
.hero-stats{
  display:flex;gap:32px;flex-wrap:wrap;margin-top:44px;
  animation:slideInLeft 0.8s ease 0.6s both;
}
.hero-stat-item{display:flex;align-items:center;gap:10px;}
.hstat-icon{width:40px;height:40px;border-radius:10px;background:rgba(124,58,237,0.12);border:1px solid rgba(124,58,237,0.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;}
.hstat-value{font-size:1.25rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.hstat-label{font-size:0.72rem;color:var(--text-muted);font-weight:500;}

@keyframes slideInLeft{from{opacity:0;transform:translateX(-40px);}to{opacity:1;transform:translateX(0);}}
@keyframes slideInRight{from{opacity:0;transform:translateX(40px);}to{opacity:1;transform:translateX(0);}}

/* Scroll indicator */
.scroll-indicator{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  animation:slideInUp 1s ease 1.5s both;z-index:2;
}
.scroll-mouse{width:24px;height:38px;border:2px solid rgba(124,58,237,0.5);border-radius:12px;display:flex;justify-content:center;padding-top:6px;}
.scroll-wheel{width:3px;height:8px;background:var(--accent-violet);border-radius:2px;animation:scrollWheel 1.5s ease-in-out infinite;}
@keyframes scrollWheel{0%,100%{transform:translateY(0);opacity:1;}50%{transform:translateY(8px);opacity:0;}}
.scroll-text{font-size:0.68rem;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;}
@keyframes slideInUp{from{opacity:0;transform:translateX(-50%) translateY(20px);}to{opacity:1;transform:translateX(-50%) translateY(0);}}

/* =====================================================
   SECTION UTILITIES
   ===================================================== */
.section{padding:110px 0;position:relative;z-index:1;}
.section-alt{background:rgba(8,13,26,0.6);backdrop-filter:blur(10px);}
.container{max-width:1300px;margin:0 auto;padding:0 28px;}

.section-header{text-align:center;margin-bottom:72px;}
.section-badge{
  display:inline-block;
  background:rgba(124,58,237,0.1);border:1px solid rgba(124,58,237,0.25);
  color:var(--accent-violet);font-size:0.73rem;font-weight:700;
  letter-spacing:1.8px;text-transform:uppercase;
  padding:5px 16px;border-radius:40px;margin-bottom:14px;
}
.section-title{font-size:clamp(1.9rem,4vw,3rem);font-weight:900;line-height:1.15;margin-bottom:16px;}
.section-subtitle{font-family:var(--font-secondary);font-size:1.05rem;color:var(--text-secondary);max-width:580px;margin:0 auto;line-height:1.85;}

/* =====================================================
   ANIMATED MESSAGE BANNER (between sections)
   ===================================================== */
.message-banner {
  position:relative;z-index:1;
  overflow:hidden;
  padding:0;
  background: linear-gradient(135deg, rgba(124,58,237,0.12) 0%, rgba(6,214,240,0.08) 100%);
  border-top:1px solid rgba(124,58,237,0.15);
  border-bottom:1px solid rgba(6,214,240,0.15);
}
.message-ticker{
  display:flex;gap:0;
  animation:tickerScroll 25s linear infinite;
  padding:16px 0;
  white-space:nowrap;
}
.message-ticker-inner{display:flex;gap:48px;align-items:center;}
.ticker-item{
  display:flex;align-items:center;gap:10px;
  font-size:0.88rem;font-weight:600;color:var(--text-secondary);
  padding:0 24px;
}
.ticker-item span.ti-icon{font-size:1.1rem;}
.ticker-item strong{color:var(--text-primary);}
@keyframes tickerScroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* =====================================================
   SERVICES — 3D TILT CARDS
   ===================================================== */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px;}

.service-card-3d{
  position:relative;border-radius:var(--radius-lg);
  background:rgba(8,13,26,0.6);
  border:1px solid rgba(255,255,255,0.06);
  padding:0;overflow:visible;
  transition:var(--transition);
  transform-style:preserve-3d;
  cursor:pointer;
}

/* Holographic border glow on hover */
.service-card-3d::before{
  content:'';position:absolute;inset:-1px;border-radius:inherit;
  background:var(--gradient-hero);opacity:0;
  transition:opacity 0.4s ease;z-index:-1;border-radius:var(--radius-lg);
}
.service-card-3d:hover::before{opacity:1;}

.service-card-inner-3d{
  background:rgba(8,13,26,0.92);
  border-radius:inherit;padding:32px 28px;
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.05);
  height:100%;
  position:relative;overflow:hidden;
  transition:var(--transition);
}

/* Animated glow orb inside card */
.card-orb{
  position:absolute;width:120px;height:120px;border-radius:50%;
  filter:blur(40px);opacity:0;transition:opacity 0.4s ease;
  top:-30px;right:-30px;pointer-events:none;
}
.service-card-3d:hover .card-orb{opacity:0.6;}

.orb-violet{background:rgba(124,58,237,0.6);}
.orb-cyan{background:rgba(6,214,240,0.5);}
.orb-purple{background:rgba(168,85,247,0.5);}
.orb-pink{background:rgba(236,72,153,0.5);}
.orb-green{background:rgba(16,185,129,0.5);}
.orb-orange{background:rgba(249,115,22,0.5);}
.orb-blue{background:rgba(59,130,246,0.5);}
.orb-gold{background:rgba(234,179,8,0.5);}

.service-icon-3d{
  width:64px;height:64px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;font-size:1.8rem;
  margin-bottom:22px;position:relative;
  transition:transform 0.4s ease;
}
.service-card-3d:hover .service-icon-3d{transform:translateZ(20px) rotateY(20deg) scale(1.1);}

.s-icon-v{background:linear-gradient(135deg,rgba(124,58,237,0.25),rgba(168,85,247,0.1));}
.s-icon-c{background:linear-gradient(135deg,rgba(6,214,240,0.2),rgba(59,130,246,0.1));}
.s-icon-p{background:linear-gradient(135deg,rgba(168,85,247,0.25),rgba(236,72,153,0.1));}
.s-icon-b{background:linear-gradient(135deg,rgba(59,130,246,0.2),rgba(6,214,240,0.1));}
.s-icon-g{background:linear-gradient(135deg,rgba(16,185,129,0.2),rgba(6,214,240,0.1));}
.s-icon-o{background:linear-gradient(135deg,rgba(249,115,22,0.2),rgba(234,179,8,0.1));}
.s-icon-go{background:linear-gradient(135deg,rgba(234,179,8,0.2),rgba(249,115,22,0.1));}
.s-icon-pk{background:linear-gradient(135deg,rgba(236,72,153,0.2),rgba(168,85,247,0.1));}

.service-title-3d{font-size:1.1rem;font-weight:800;margin-bottom:10px;color:var(--text-primary);transition:var(--transition);}
.service-card-3d:hover .service-title-3d{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.service-desc-3d{font-family:var(--font-secondary);font-size:0.855rem;color:var(--text-secondary);line-height:1.75;}
.service-arrow{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:0.8rem;font-weight:700;color:var(--accent-violet);opacity:0;transform:translateX(-8px);transition:var(--transition);}
.service-card-3d:hover .service-arrow{opacity:1;transform:translateX(0);}

/* =====================================================
   STATS — 3D FLIP COUNTERS
   ===================================================== */
.stats-section{padding:70px 0;position:relative;z-index:1;}
.stats-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(124,58,237,0.08),rgba(6,214,240,0.05));
  border-top:1px solid rgba(124,58,237,0.15);
  border-bottom:1px solid rgba(6,214,240,0.12);
}

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}

.stat-flip-card{
  perspective:1000px;cursor:pointer;
}
.stat-flip-inner{
  position:relative;transform-style:preserve-3d;
  transition:transform 0.7s cubic-bezier(0.4,0,0.2,1);
}
.stat-flip-card:hover .stat-flip-inner{transform:rotateY(180deg);}

.stat-face{
  backface-visibility:hidden;
  background:rgba(8,13,26,0.7);border:1px solid rgba(124,58,237,0.15);
  border-radius:var(--radius-md);padding:32px 20px;text-align:center;
  backdrop-filter:blur(20px);
}
.stat-face.back{
  position:absolute;inset:0;
  transform:rotateY(180deg);
  background:linear-gradient(135deg,rgba(124,58,237,0.2),rgba(6,214,240,0.15));
  border-color:rgba(124,58,237,0.4);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}

.stat-emoji{font-size:2rem;margin-bottom:8px;}
.stat-number{
  font-size:clamp(2.2rem,3.5vw,3rem);font-weight:900;
  background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1;margin-bottom:8px;
}
.stat-label{font-size:0.85rem;color:var(--text-secondary);font-weight:500;}
.stat-back-text{font-size:0.9rem;color:var(--text-primary);font-weight:700;margin-bottom:8px;}
.stat-back-sub{font-size:0.78rem;color:var(--text-secondary);}

/* =====================================================
   ANIMATED MESSAGE CARDS (3D PERSPECTIVE REVEAL)
   ===================================================== */
.message-cards-section{position:relative;z-index:1;padding:100px 0;}

.msg-cards-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
  perspective:1200px;
}

.msg-card{
  position:relative;
  background:rgba(8,13,26,0.75);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--radius-xl);
  padding:40px 32px;
  overflow:hidden;
  transform:translateZ(0);
  transition:transform 0.5s ease, box-shadow 0.5s ease;
  transform-style:preserve-3d;
}
.msg-card:hover{
  transform:translateZ(30px) rotateX(-5deg);
  box-shadow:0 40px 100px rgba(124,58,237,0.25), 0 0 0 1px rgba(124,58,237,0.3);
}

.msg-card-glow{
  position:absolute;width:200px;height:200px;border-radius:50%;filter:blur(60px);opacity:0.25;
  pointer-events:none;transition:opacity 0.4s;
}
.msg-card:hover .msg-card-glow{opacity:0.45;}
.msg-glow-1{background:#7c3aed;top:-60px;right:-60px;}
.msg-glow-2{background:#06d6f0;bottom:-60px;left:-60px;}
.msg-glow-3{background:#a855f7;top:-60px;left:-60px;}

.msg-icon{
  width:72px;height:72px;border-radius:20px;
  display:flex;align-items:center;justify-content:center;font-size:2rem;
  margin-bottom:24px;position:relative;
}
.msg-icon::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  box-shadow:0 0 30px currentColor;opacity:0.4;
}
.msg-icon-1{background:rgba(124,58,237,0.15);color:#7c3aed;}
.msg-icon-2{background:rgba(6,214,240,0.12);color:#06d6f0;}
.msg-icon-3{background:rgba(16,185,129,0.12);color:#10b981;}

.msg-card-title{font-size:1.3rem;font-weight:800;margin-bottom:12px;}
.msg-card-text{font-family:var(--font-secondary);font-size:0.88rem;color:var(--text-secondary);line-height:1.8;margin-bottom:20px;}

.msg-counter{
  display:inline-flex;align-items:baseline;gap:4px;
  font-size:2.5rem;font-weight:900;
  background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.msg-counter-suffix{font-size:1.2rem;font-weight:700;}
.msg-counter-label{display:block;font-size:0.8rem;color:var(--text-muted);font-weight:500;margin-top:4px;}

/* Animated progress bar */
.msg-progress{height:4px;background:rgba(255,255,255,0.06);border-radius:2px;margin-top:20px;overflow:hidden;}
.msg-progress-bar{height:100%;border-radius:2px;background:var(--gradient-primary);width:0%;transition:width 1.5s ease;}

/* =====================================================
   WHY US — 3D SPLIT LAYOUT
   ===================================================== */
.why-section{position:relative;z-index:1;}

.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}

.why-list{display:flex;flex-direction:column;gap:20px;}

.why-item{
  display:flex;gap:18px;align-items:flex-start;
  padding:22px 24px;
  background:rgba(8,13,26,0.6);
  border:1px solid rgba(255,255,255,0.05);
  border-radius:var(--radius-md);
  transition:all 0.4s ease;
  transform-origin:left center;
  position:relative;overflow:hidden;
}
.why-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--gradient-primary);opacity:0;
  transition:opacity 0.3s;border-radius:0 3px 3px 0;
}
.why-item:hover{transform:translateX(8px);border-color:rgba(124,58,237,0.25);background:rgba(124,58,237,0.07);}
.why-item:hover::before{opacity:1;}

.why-item-icon{
  width:46px;height:46px;min-width:46px;border-radius:14px;
  background:var(--gradient-primary);
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;box-shadow:0 6px 20px rgba(124,58,237,0.3);
  transition:transform 0.3s;
}
.why-item:hover .why-item-icon{transform:scale(1.1) rotate(5deg);}
.why-item-title{font-size:0.98rem;font-weight:700;margin-bottom:4px;}
.why-item-desc{font-family:var(--font-secondary);font-size:0.83rem;color:var(--text-secondary);}

/* 3D RSF Cube Visual */
.why-visual{display:flex;align-items:center;justify-content:center;}
.scene{width:280px;height:280px;perspective:800px;margin:0 auto;}
.cube{
  width:100%;height:100%;position:relative;
  transform-style:preserve-3d;
  animation:rotateCube 12s linear infinite;
}
@keyframes rotateCube{0%{transform:rotateX(15deg) rotateY(0deg);}100%{transform:rotateX(15deg) rotateY(360deg);}}

.cube-face{
  position:absolute;width:280px;height:280px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  border:2px solid rgba(124,58,237,0.4);
  border-radius:24px;
  background:rgba(8,13,26,0.7);
  backdrop-filter:blur(10px);
  box-shadow:0 0 40px rgba(124,58,237,0.15) inset;
  gap:10px;font-size:0.9rem;font-weight:700;
}
.face-front{transform:translateZ(140px);}
.face-back{transform:rotateY(180deg) translateZ(140px);}
.face-left{transform:rotateY(-90deg) translateZ(140px);}
.face-right{transform:rotateY(90deg) translateZ(140px);}
.face-top{transform:rotateX(90deg) translateZ(140px);}
.face-bottom{transform:rotateX(-90deg) translateZ(140px);}

.face-icon{font-size:2.8rem;display:block;}
.face-label{font-size:0.9rem;font-weight:700;color:var(--text-primary);}
.face-sub{font-size:0.72rem;color:var(--text-muted);}

/* =====================================================
   CALCULATOR
   ===================================================== */
.calc-wrapper{
  background:rgba(8,13,26,0.8);border:1px solid rgba(124,58,237,0.2);
  border-radius:var(--radius-xl);overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,0.4), var(--shadow-glow);
  backdrop-filter:blur(20px);
}

.calc-tabs{display:flex;background:rgba(0,0,0,0.3);border-bottom:1px solid rgba(255,255,255,0.06);}
.calc-tab{flex:1;padding:20px;text-align:center;font-size:0.9rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:var(--transition);border-bottom:3px solid transparent;}
.calc-tab.active{color:var(--accent-violet);background:rgba(124,58,237,0.07);border-bottom-color:var(--accent-violet);}
.calc-tab:hover:not(.active){color:var(--text-secondary);}

.calc-body{display:grid;grid-template-columns:1fr 1fr;min-height:440px;}

.calc-opts{padding:36px;border-right:1px solid rgba(255,255,255,0.06);}
.calc-opts h4{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:12px;margin-top:24px;}
.calc-opts h4:first-child{margin-top:0;}

.chip-row{display:flex;flex-wrap:wrap;gap:8px;}
.chip{
  padding:8px 16px;border:1px solid rgba(255,255,255,0.07);border-radius:40px;
  font-size:0.8rem;font-weight:500;color:var(--text-secondary);cursor:pointer;
  transition:var(--transition);user-select:none;
}
.chip:hover,.chip.sel{background:rgba(124,58,237,0.12);border-color:rgba(124,58,237,0.45);color:var(--text-primary);}
.chip.sel{background:rgba(124,58,237,0.2);color:var(--accent-violet);font-weight:700;}

.calc-result-panel{
  padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  background:radial-gradient(circle at 50% 40%, rgba(124,58,237,0.1), transparent 70%);
}
.calc-price-label{font-size:0.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;}
.calc-price{
  font-size:clamp(2.5rem,4vw,3.5rem);font-weight:900;
  background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:6px;transition:all 0.5s ease;
}
.calc-timeline-txt{font-size:0.83rem;color:var(--text-secondary);margin-bottom:28px;}
.calc-cta-btn{
  display:flex;align-items:center;gap:8px;
  padding:14px 30px;background:var(--gradient-primary);color:white;
  border:none;border-radius:40px;font-family:var(--font-primary);font-size:0.9rem;font-weight:700;
  cursor:pointer;transition:var(--transition);box-shadow:0 6px 24px rgba(124,58,237,0.4);
}
.calc-cta-btn:hover{transform:translateY(-3px);box-shadow:0 16px 48px rgba(124,58,237,0.55);}
.calc-incl{list-style:none;margin-top:20px;width:100%;text-align:left;}
.calc-incl li{display:flex;align-items:center;gap:8px;font-size:0.8rem;color:var(--text-secondary);padding:4px 0;}
.calc-incl li::before{content:'✓';color:var(--accent-cyan);font-weight:700;}

/* =====================================================
   TESTIMONIALS
   ===================================================== */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}

.testi-card{
  background:rgba(8,13,26,0.7);border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--radius-lg);padding:28px;
  transition:all 0.4s ease;
  transform-style:preserve-3d;
  backdrop-filter:blur(10px);
}
.testi-card:hover{
  border-color:rgba(124,58,237,0.3);
  transform:translateY(-8px) rotateX(3deg);
  box-shadow:0 30px 80px rgba(124,58,237,0.2);
}
.testi-stars{display:flex;gap:4px;color:#f59e0b;font-size:0.9rem;margin-bottom:16px;}
.testi-quote{font-size:2.5rem;color:rgba(124,58,237,0.25);line-height:1;margin-bottom:8px;font-family:Georgia,serif;}
.testi-text{font-family:var(--font-secondary);font-size:0.88rem;color:var(--text-secondary);line-height:1.85;margin-bottom:20px;font-style:italic;}
.testi-author{display:flex;align-items:center;gap:12px;}
.testi-avatar{
  width:46px;height:46px;border-radius:50%;
  background:var(--gradient-primary);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;font-weight:800;color:white;flex-shrink:0;
  box-shadow:0 4px 16px rgba(124,58,237,0.35);
}
.testi-name{font-size:0.9rem;font-weight:700;}
.testi-loc{font-size:0.76rem;color:var(--text-muted);}

/* =====================================================
   FAQ
   ===================================================== */
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.faq-item{
  background:rgba(8,13,26,0.7);border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--radius-md);overflow:hidden;
  transition:var(--transition);backdrop-filter:blur(10px);
}
.faq-item:hover{border-color:rgba(124,58,237,0.2);}
.faq-item.open{border-color:rgba(124,58,237,0.4);box-shadow:0 8px 32px rgba(124,58,237,0.1);}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:22px 26px;background:none;border:none;
  color:var(--text-primary);font-family:var(--font-primary);font-size:0.95rem;font-weight:600;
  cursor:pointer;text-align:left;gap:16px;
}
.faq-icon{
  width:30px;height:30px;min-width:30px;
  background:rgba(124,58,237,0.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;color:var(--accent-violet);transition:all 0.3s ease;
}
.faq-item.open .faq-icon{background:var(--gradient-primary);color:white;transform:rotate(45deg);}
.faq-ans{max-height:0;overflow:hidden;transition:max-height 0.35s ease;}
.faq-ans-inner{padding:0 26px 22px;font-family:var(--font-secondary);font-size:0.875rem;color:var(--text-secondary);line-height:1.85;}

/* =====================================================
   CONTACT
   ===================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:52px;align-items:start;}
.contact-title{font-size:1.9rem;font-weight:800;margin-bottom:14px;}
.contact-desc{font-family:var(--font-secondary);font-size:0.9rem;color:var(--text-secondary);line-height:1.8;margin-bottom:28px;}
.contact-list{display:flex;flex-direction:column;gap:12px;}
.contact-it{
  display:flex;align-items:center;gap:14px;padding:16px 18px;
  background:rgba(8,13,26,0.6);border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--radius-md);transition:var(--transition);
}
.contact-it:hover{border-color:rgba(124,58,237,0.3);background:rgba(124,58,237,0.06);}
.ci-icon{width:40px;height:40px;min-width:40px;background:rgba(124,58,237,0.12);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;}
.ci-label{font-size:0.72rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:0.5px;}
.ci-val{font-size:0.875rem;font-weight:600;}
.ci-val a{color:inherit;}
.ci-val a:hover{color:var(--accent-violet);}

.social-row{display:flex;gap:10px;margin-top:24px;}
.soc-btn{
  width:44px;height:44px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);
  border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1rem;
  color:var(--text-secondary);transition:var(--transition);
}
.soc-btn:hover{background:rgba(124,58,237,0.15);border-color:rgba(124,58,237,0.4);color:var(--accent-violet);transform:translateY(-3px);}

.contact-form-box{
  background:rgba(8,13,26,0.8);border:1px solid rgba(124,58,237,0.15);
  border-radius:var(--radius-xl);padding:40px;
  backdrop-filter:blur(20px);
  box-shadow:0 30px 80px rgba(0,0,0,0.3);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-grp{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.form-grp label{font-size:0.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;}
.form-grp input,.form-grp select,.form-grp textarea{
  background:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.07);
  border-radius:10px;padding:13px 16px;color:var(--text-primary);
  font-family:var(--font-primary);font-size:0.9rem;transition:var(--transition);outline:none;width:100%;
}
.form-grp input:focus,.form-grp select:focus,.form-grp textarea:focus{border-color:rgba(124,58,237,0.5);box-shadow:0 0 0 3px rgba(124,58,237,0.1);}
.form-grp textarea{min-height:120px;resize:vertical;}
.form-grp select option{background:var(--bg-secondary);}
.form-submit{
  width:100%;padding:17px;background:var(--gradient-primary);color:white;border:none;
  border-radius:var(--radius-md);font-family:var(--font-primary);font-size:1rem;font-weight:700;
  cursor:pointer;transition:var(--transition);letter-spacing:0.3px;
}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(124,58,237,0.5);}
.form-ok{display:none;background:rgba(16,185,129,0.1);border:1px solid rgba(16,185,129,0.3);border-radius:10px;padding:14px;color:#10b981;font-size:0.875rem;font-weight:600;margin-top:14px;text-align:center;}

/* =====================================================
   FOOTER
   ===================================================== */
footer{background:rgba(2,4,10,0.95);border-top:1px solid rgba(255,255,255,0.05);padding:64px 0 0;position:relative;z-index:1;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.6fr;gap:40px;margin-bottom:48px;}
.footer-brand{font-size:1.6rem;font-weight:900;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.footer-desc{font-family:var(--font-secondary);font-size:0.845rem;color:var(--text-muted);line-height:1.8;margin:12px 0 20px;}
.footer-soc{display:flex;gap:8px;}
.fsoc-btn{width:36px;height:36px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:0.85rem;color:var(--text-muted);transition:var(--transition);}
.fsoc-btn:hover{background:rgba(124,58,237,0.15);border-color:rgba(124,58,237,0.35);color:var(--accent-violet);transform:translateY(-2px);}
.footer-head{font-size:0.82rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-primary);margin-bottom:16px;}
.footer-lnks{display:flex;flex-direction:column;gap:9px;}
.footer-lnks a{font-size:0.84rem;color:var(--text-muted);transition:var(--transition);}
.footer-lnks a:hover{color:var(--text-primary);padding-left:4px;}
.footer-contacts{display:flex;flex-direction:column;gap:10px;}
.fci{display:flex;align-items:flex-start;gap:8px;font-size:0.81rem;color:var(--text-muted);line-height:1.5;}
.fci a{color:var(--text-muted);}
.fci a:hover{color:var(--text-primary);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.05);padding:35px 24px 100px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;}
.footer-copy{font-size:0.85rem;color:#f0f6ff;}
.footer-policy{display:flex;gap:12px 16px;flex-wrap:wrap;justify-content:center;align-items:center;}
.footer-policy a{font-size:0.78rem;color:var(--text-muted);transition:var(--transition);text-decoration:none;}
.footer-policy a:hover{color:var(--accent-cyan);}

/* =====================================================
   CALLBACK MODAL
   ===================================================== */
/* Google Fonts loaded non-blocking via HTML preload (see <head>) */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,0.75);backdrop-filter:blur(12px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:all 0.3s ease;}
.modal-ov.active{opacity:1;visibility:visible;}
.modal-bx{background:var(--bg-secondary);border:1px solid rgba(124,58,237,0.25);border-radius:var(--radius-xl);padding:44px;max-width:480px;width:100%;position:relative;transform:scale(0.88);transition:transform 0.3s ease;box-shadow:0 40px 100px rgba(0,0,0,0.6);}
.modal-ov.active .modal-bx{transform:scale(1);}
.modal-x{position:absolute;top:16px;right:16px;width:36px;height:36px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;color:var(--text-secondary);transition:var(--transition);}
.modal-x:hover{background:rgba(239,68,68,0.1);border-color:rgba(239,68,68,0.3);color:#ef4444;}
.modal-tit{font-size:1.6rem;font-weight:800;margin-bottom:6px;}
.modal-sub{font-size:0.875rem;color:var(--text-secondary);margin-bottom:28px;}

/* =====================================================
   FLOATING ELEMENTS
   ===================================================== */
.fab-wrap{position:fixed;bottom:32px;right:32px;z-index:999;}
.fab-btn{
  display:flex;align-items:center;gap:10px;
  padding:15px 24px;background:var(--gradient-primary);color:white;
  border:none;border-radius:50px;font-family:var(--font-primary);font-size:0.875rem;font-weight:700;
  cursor:pointer;transition:var(--transition);
  box-shadow:0 8px 32px rgba(124,58,237,0.45);
  animation:fabPulse 3s ease-in-out infinite;
}
.fab-btn:hover{transform:translateY(-3px);box-shadow:0 20px 60px rgba(124,58,237,0.65);}
@keyframes fabPulse{0%,100%{box-shadow:0 8px 32px rgba(124,58,237,0.45);}50%{box-shadow:0 8px 60px rgba(124,58,237,0.7),0 0 0 12px rgba(124,58,237,0.06);}}

.scroll-top-btn{position:fixed;bottom:100px;right:32px;width:46px;height:46px;background:rgba(124,58,237,0.15);border:1px solid rgba(124,58,237,0.35);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--accent-violet);transition:var(--transition);opacity:0;visibility:hidden;z-index:998;}
.scroll-top-btn.vis{opacity:1;visibility:visible;}
.scroll-top-btn:hover{background:rgba(124,58,237,0.35);transform:translateY(-3px);}

/* =====================================================
   SCROLL ANIMATIONS
   ===================================================== */
.aos{opacity:1;transform:translateY(0);transition:opacity 0.7s ease,transform 0.7s ease;}
.aos.in{opacity:1;transform:translateY(0);}
.aos-left{opacity:1;transform:translateX(0);transition:opacity 0.7s ease,transform 0.7s ease;}
.aos-left.in{opacity:1;transform:translateX(0);}
.aos-right{opacity:1;transform:translateX(0);transition:opacity 0.7s ease,transform 0.7s ease;}
.aos-right.in{opacity:1;transform:translateX(0);}
.aos-scale{opacity:1;transform:scale(1);transition:opacity 0.6s ease,transform 0.6s ease;}
.aos-scale.in{opacity:1;transform:scale(1);}

.d1{transition-delay:0.1s;}.d2{transition-delay:0.2s;}.d3{transition-delay:0.3s;}.d4{transition-delay:0.4s;}.d5{transition-delay:0.5s;}.d6{transition-delay:0.6s;}

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media(max-width:1100px){
  .hero-content{grid-template-columns:1fr;gap:0;padding-top:60px;}
  .hero-visual{display:none;}
  .why-grid{grid-template-columns:1fr;}
  .scene{display:none;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .calc-body{grid-template-columns:1fr;}
  .calc-opts{border-right:none;border-bottom:1px solid rgba(255,255,255,0.06);}
}
@media(max-width:768px){
  .nav-menu{display:none;}.nav-toggle{display:flex;}
  .nav-menu.open{display:flex;flex-direction:column;position:absolute;top:74px;left:0;right:0;background:rgba(4,7,15,0.98);backdrop-filter:blur(24px);border-bottom:1px solid var(--border-glass);padding:16px;gap:4px;}
  .dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;display:none;}
  .nav-item.has-dropdown.open .dropdown-menu{display:block;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .testi-grid{grid-template-columns:1fr;}
  .msg-cards-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .hero-stats{gap:20px;}
}
@media(max-width:480px){
  .hero-stats{flex-direction:column;}
  .hero-actions{flex-direction:column;}
  .btn-primary-3d,.btn-glass{width:100%;justify-content:center;}
  .fab-wrap{bottom:20px;right:20px;}
  .scroll-top-btn{bottom:80px;right:20px;}
  .msg-cards-grid{grid-template-columns:1fr;}
  .services-grid{grid-template-columns:1fr;}
}

/* ---- CALCULATOR OPT GROUPS ---- */
.calc-opt-group { margin-bottom: 28px; }
.calc-opt-group:last-child { margin-bottom: 0; }
.calc-opt-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
  font-family: var(--font-secondary);
}
.chip-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
/* ============================================================
   MEGA MENU
   ============================================================ */

/* Trigger arrow links */
.nav-link-arrow { display:flex; align-items:center; gap:3px; }
.nav-link-arrow .fa-chevron-down {
  transition: transform 0.3s ease;
}
.nav-item.has-mega:hover .fa-chevron-down,
.nav-item.has-dropdown:hover .fa-chevron-down {
  transform: rotate(180deg);
}

/* ---- MEGA MENU CONTAINER ---- */
.nav-item.has-mega { position: static; }

.mega-menu {
  position: fixed;
  top: 74px;
  left: 0;
  width: 100%;
  background: rgba(6, 10, 22, 0.98);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border-top: 1px solid rgba(124,58,237,0.2);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  box-shadow: 0 28px 80px rgba(0,0,0,0.6);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-12px);
  transition: opacity 0.28s ease, visibility 0.28s ease, transform 0.28s ease;
  z-index: 999;
}

.nav-item.has-mega:hover .mega-menu,
.mega-menu:hover {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.mega-inner {
  max-width: 1300px;
  margin: 0 auto;
  padding: 32px 28px 36px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 260px;
  gap: 0;
}

/* ---- MEGA COLUMNS ---- */
.mega-col {
  padding: 0 28px 0 0;
  border-right: 1px solid rgba(255,255,255,0.05);
  margin-right: 0;
}
.mega-col:last-child { border-right: none; padding-left: 28px; padding-right: 0; }

.mega-col-head {
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  color: var(--accent-violet);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(124,58,237,0.2);
  display: flex;
  align-items: center;
  gap: 7px;
}

/* ---- MEGA LINKS ---- */
.mega-link {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 9px 12px;
  border-radius: 10px;
  text-decoration: none;
  transition: background 0.2s, transform 0.2s;
  margin-bottom: 2px;
}
.mega-link:hover {
  background: rgba(124,58,237,0.1);
  transform: translateX(4px);
}
.mega-link > i {
  font-size: 0.95rem;
  color: var(--accent-violet);
  margin-top: 3px;
  min-width: 18px;
  text-align: center;
}
.mega-link span { display: flex; flex-direction: column; }
.mega-link strong {
  font-size: 0.83rem;
  font-weight: 700;
  color: #f0f6ff;
  line-height: 1.3;
}
.mega-link em {
  font-style: normal;
  font-size: 0.71rem;
  color: #64748b;
  margin-top: 1px;
  line-height: 1.4;
}
.mega-link:hover strong { color: #fff; }
.mega-link:hover em { color: #94a3b8; }
.mega-link:hover > i { color: var(--accent-cyan); }

/* ---- CTA COLUMN ---- */
.mega-col-cta { display: flex; flex-direction: column; gap: 20px; }

.mega-cta-box {
  background: linear-gradient(135deg, rgba(124,58,237,0.15), rgba(6,214,240,0.08));
  border: 1px solid rgba(124,58,237,0.25);
  border-radius: 16px;
  padding: 22px 20px;
  text-align: center;
}
.mega-cta-icon {
  width: 48px; height: 48px;
  background: linear-gradient(135deg,#7c3aed,#06d6f0);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 14px;
  font-size: 1.2rem; color: #fff;
}
.mega-cta-title {
  font-size: 0.95rem; font-weight: 800; color: #f0f6ff;
  margin-bottom: 6px;
}
.mega-cta-sub {
  font-size: 0.72rem; color: #64748b;
  line-height: 1.55; margin-bottom: 16px;
}
.mega-cta-btn {
  display: inline-block;
  background: linear-gradient(135deg,#7c3aed,#06d6f0);
  color: #fff !important;
  font-size: 0.82rem;
  font-weight: 700;
  padding: 10px 20px;
  border-radius: 40px;
  border: none;
  cursor: pointer;
  font-family: inherit;
  transition: transform 0.25s, box-shadow 0.25s;
  box-shadow: 0 6px 24px rgba(124,58,237,0.35);
  text-decoration: none;
}
.mega-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(124,58,237,0.5);
}

.mega-popular { background: rgba(255,255,255,0.02); border-radius: 12px; padding: 14px 16px; }
.mega-popular-head {
  font-size: 0.68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1px;
  color: #64748b; margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}
.mega-popular-link {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.78rem; color: #94a3b8;
  padding: 5px 0;
  text-decoration: none;
  transition: color 0.2s;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.mega-popular-link::before {
  content: '→';
  color: var(--accent-violet);
  font-size: 0.7rem;
  transition: transform 0.2s;
}
.mega-popular-link:hover { color: #f0f6ff; }
.mega-popular-link:hover::before { transform: translateX(3px); }
.mega-popular-link:last-child { border-bottom: none; }

/* ---- SMALL DROPDOWN (Pricing, Company) ---- */
.dropdown-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  background: rgba(6,10,22,0.97);
  backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 16px;
  padding: 10px;
  min-width: 230px;
  opacity: 0; visibility: hidden;
  transform: translateY(-10px) scale(0.97);
  transition: all 0.25s ease;
  box-shadow: 0 24px 60px rgba(0,0,0,0.55);
  z-index: 1001;
  list-style: none;
}
.nav-item.has-dropdown:hover .dropdown-menu {
  opacity: 1; visibility: visible; transform: translateY(0) scale(1);
}
.dropdown-menu li a,
.dropdown-menu a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  font-size: 0.82rem;
  color: #94a3b8;
  border-radius: 9px;
  transition: all 0.2s;
  text-decoration: none;
}
.dropdown-menu li a:hover,
.dropdown-menu a:hover {
  color: #f0f6ff;
  background: rgba(124,58,237,0.1);
  padding-left: 18px;
}
.dropdown-menu li a i { font-size: 0.8rem; }

/* ---- MOBILE MENU ---- */
.mobile-menu {
  display: none;
  position: fixed;
  top: 74px;
  left: 0;
  width: 100%;
  height: calc(100vh - 74px);
  background: rgba(4,7,15,0.99);
  backdrop-filter: blur(20px);
  z-index: 998;
  overflow-y: auto;
  transform: translateX(-100%);
  transition: transform 0.35s ease;
}
.mobile-menu.open { transform: translateX(0); }

.mobile-menu-inner {
  padding: 24px 24px 40px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mobile-section { margin-bottom: 16px; }
.mobile-section-head {
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  color: var(--accent-violet);
  padding: 8px 12px 10px;
  border-bottom: 1px solid rgba(124,58,237,0.2);
  margin-bottom: 4px;
}
.mobile-section a {
  display: block;
  padding: 9px 14px;
  font-size: 0.88rem;
  color: #94a3b8;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.2s;
}
.mobile-section a:hover { color: #f0f6ff; background: rgba(255,255,255,0.05); }

@media (max-width: 1024px) {
  .nav-menu { display: none !important; }
  .nav-toggle { display: flex !important; }
  .mobile-menu { display: block; }
  .mega-menu { display: none; }
}
/* ============================================================
   COMPREHENSIVE RESPONSIVE CSS
   Breakpoints: 1200px | 1024px | 900px | 768px | 600px | 480px | 360px
   ============================================================ */

/* ---- BASE: stop horizontal scroll on ALL screens ---- */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw;
}
*, *::before, *::after { box-sizing: border-box; }
img, video, iframe, embed { max-width: 100%; height: auto; }
.container { padding: 0 20px; }

/* ============================================================
   TABLET LANDSCAPE / LARGE TABLET  (max 1200px)
   ============================================================ */
@media (max-width: 1200px) {
  .mega-inner { grid-template-columns: 1fr 1fr 1fr; }
  .mega-col-cta { display: none; }
  .hero-content { gap: 40px; }
  .why-grid { gap: 40px; }
  .calc-body { grid-template-columns: 1fr; }
  .calc-result-panel {
    border-top: 1px solid rgba(255,255,255,0.07);
    padding: 28px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 20px;
  }
  .calc-price { font-size: 2.5rem; }
}

/* ============================================================
   TABLET PORTRAIT  (max 1024px)
   ============================================================ */
@media (max-width: 1024px) {
  /* Nav */
  .nav-menu { display: none !important; }
  .nav-toggle { display: flex !important; }
  .mega-menu, .dropdown-menu { display: none !important; }
  .mobile-menu { display: block; }

  /* Hero */
  .hero-content {
    grid-template-columns: 1fr;
    text-align: center;
    padding-top: 100px;
    padding-bottom: 60px;
  }
  .hero-visual { display: none; }
  .hero-actions { justify-content: center; }
  .hero-stats { justify-content: center; }
  .hero-badge { margin: 0 auto 20px; }
  .hero-title { font-size: clamp(2rem, 6vw, 3.5rem); }

  /* Grids */
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid { grid-template-columns: 1fr; }
  .why-visual { display: none; }
  .why-list { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .testi-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
  .mega-inner { grid-template-columns: 1fr 1fr; }

  /* Calculator */
  .calc-body { grid-template-columns: 1fr; }
  .calc-result-panel { padding: 24px; }

  /* Trust badges */
  .trust-badges-row { flex-direction: column; align-items: center; }

  /* Message cards */
  .msg-cards-grid { grid-template-columns: repeat(2, 1fr); }

  /* Sections spacing */
  .section { padding: 80px 0; }
}

/* ============================================================
   MOBILE LANDSCAPE / LARGE MOBILE  (max 900px)
   ============================================================ */
@media (max-width: 900px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .features-grid-3col { grid-template-columns: repeat(2, 1fr) !important; }
  .pricing-grid { grid-template-columns: 1fr !important; max-width: 480px; margin-left: auto; margin-right: auto; }
  .split-layout { grid-template-columns: 1fr !important; }
  .split-visual { display: none; }
  .process-steps { grid-template-columns: repeat(2, 1fr); }
  .testi-grid { grid-template-columns: 1fr; }
  .why-list { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   MOBILE PORTRAIT  (max 768px)
   ============================================================ */
@media (max-width: 768px) {
  /* Canvas off */
  #three-canvas { display: none !important; }

  /* Spacing */
  .section { padding: 64px 0; }
  .container { padding: 0 16px; }

  /* Top bar */
  .top-bar-ticker { gap: 8px; font-size: 0.72rem; }
  .ticker-sep { display: none; }
  .top-bar-ticker span:nth-child(n+4) { display: none; }

  /* Navbar */
  .nav-container { height: 62px; }
  .nav-logo img { height: 36px; }

  /* Hero */
  .hero-content {
    grid-template-columns: 1fr;
    text-align: center;
    padding-top: 80px;
    gap: 24px;
  }
  .hero-visual { display: none !important; }
  .hero-title { font-size: clamp(1.8rem, 8vw, 2.8rem); line-height: 1.2; }
  .hero-sub { font-size: 0.92rem; }
  .hero-actions { flex-direction: column; align-items: center; gap: 12px; }
  .btn-primary-3d, .btn-glass { width: 100%; max-width: 320px; justify-content: center; }
  .hero-stats { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .hstat-value { font-size: 1.6rem; }

  /* Section headers */
  .section-title { font-size: clamp(1.5rem, 6vw, 2.2rem); }
  .section-subtitle { font-size: 0.88rem; }

  /* Services */
  .services-grid { grid-template-columns: 1fr; }
  .svc-card { padding: 24px; }

  /* Message banner & cards */
  .message-banner { font-size: 0.82rem; padding: 12px 16px; }
  .msg-cards-grid { grid-template-columns: 1fr; }
  .msg-card { padding: 24px; }

  /* Stats */
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .stat-card { padding: 24px 16px; }
  .stat-number { font-size: 2rem; }

  /* Why Us */
  .why-grid { grid-template-columns: 1fr; }
  .why-visual { display: none !important; }
  .why-list { grid-template-columns: 1fr; gap: 12px; }
  .why-item { padding: 16px; }

  /* Calculator */
  .calc-wrapper { border-radius: 16px; }
  .calc-tabs { flex-direction: column; }
  .calc-tab { padding: 14px; border-bottom: 1px solid rgba(255,255,255,0.05); border-right: none; }
  .calc-body { grid-template-columns: 1fr; }
  .calc-opts { padding: 20px 16px; }
  .calc-result-panel { padding: 20px 16px; }
  .chip { font-size: 0.75rem; padding: 6px 12px; }
  .chip-row { gap: 6px; }

  /* Testimonials */
  .testi-grid { grid-template-columns: 1fr; }
  .testi-card { padding: 24px; }

  /* Trust badges */
  .trust-badges-row { flex-direction: column !important; gap: 16px !important; }
  .trust-badges-row > a,
  .trust-badges-row > div { width: 100%; max-width: 400px; }

  /* Process steps */
  .process-steps { grid-template-columns: 1fr !important; }

  /* Pricing grid */
  .pricing-grid { grid-template-columns: 1fr !important; }
  .pricing-card { padding: 24px !important; }

  /* Features grids */
  .features-grid-3col { grid-template-columns: 1fr !important; }
  .features-grid-2col { grid-template-columns: 1fr !important; }

  /* Contact */
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .contact-form-box { padding: 24px 16px; }
  .form-row { grid-template-columns: 1fr; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .footer-bottom { flex-direction: column; text-align: center; gap: 12px; }
  .footer-policy { flex-wrap: wrap; justify-content: center; gap: 12px; }
  .footer-soc { flex-wrap: wrap; }

  /* FAQ */
  .faq-q { font-size: 0.88rem; padding: 16px; }

  /* Cube (3D) */
  .scene { width: 180px; height: 180px; }
  .cube { width: 180px; height: 180px; }
  .cube-face { width: 180px; height: 180px; line-height: 180px; }
  .face-front  { transform: rotateY(0deg)   translateZ(90px); }
  .face-back   { transform: rotateY(180deg) translateZ(90px); }
  .face-left   { transform: rotateY(-90deg) translateZ(90px); }
  .face-right  { transform: rotateY(90deg)  translateZ(90px); }
  .face-top    { transform: rotateX(90deg)  translateZ(90px); }
  .face-bottom { transform: rotateX(-90deg) translateZ(90px); }

  /* Mobile menu */
  .mobile-menu { top: 62px; height: calc(100vh - 62px); }
  .mega-cta-btn { font-size: 0.82rem; padding: 12px 20px; }

  /* Page hero (inner pages) */
  .page-hero { padding: 100px 0 60px; }
  .page-hero-title { font-size: clamp(1.8rem, 7vw, 3rem); }
  .page-hero-sub { font-size: 0.9rem; }
  .breadcrumb { font-size: 0.78rem; }
  .page-hero-actions { flex-direction: column; align-items: flex-start; gap: 12px; }

  /* Split layout inner pages */
  .split-layout { grid-template-columns: 1fr !important; gap: 32px; }
  .split-visual { display: none !important; }

  /* Tabs */
  .packages-table { font-size: 0.78rem; }
  .packages-table th, .packages-table td { padding: 8px 10px; }

  /* Modal */
  .modal-bx { padding: 28px 20px; margin: 16px; width: calc(100% - 32px); }
}

/* ============================================================
   SMALL MOBILE  (max 600px)
   ============================================================ */
@media (max-width: 600px) {
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .services-grid { grid-template-columns: 1fr; }
  .msg-cards-grid { grid-template-columns: 1fr; }
  .why-list { grid-template-columns: 1fr; }
  .content-section .container { padding: 0 14px; }
  .section { padding: 52px 0; }

  .top-bar-ticker span:nth-child(n+2) { display: none; }
  .top-bar-ticker span:first-child { display: flex; }
}

/* ============================================================
   EXTRA SMALL  (max 480px)
   ============================================================ */
@media (max-width: 480px) {
  .container { padding: 0 14px; }
  .hero-title { font-size: clamp(1.6rem, 8vw, 2.2rem); }
  .section-title { font-size: clamp(1.3rem, 7vw, 1.8rem); }
  .btn-primary-3d, .btn-glass { padding: 13px 22px; font-size: 0.88rem; }
  .hstat-value { font-size: 1.4rem; }
  .hstat-label { font-size: 0.62rem; }
  .hero-stats { gap: 8px; }
  .stat-number { font-size: 1.8rem; }
  .calc-price { font-size: 2.2rem; }
  .footer-brand { font-size: 1.3rem; }
  .testi-card { padding: 18px; }
  .section-badge { font-size: 0.68rem; }
  .nav-logo img { height: 32px; }
  .mobile-menu-inner { padding: 16px 14px 32px; }

  /* Smaller chips on calculator */
  .chip { font-size: 0.7rem; padding: 5px 10px; }
}

/* ============================================================
   ULTRA SMALL  (max 360px)
   ============================================================ */
@media (max-width: 360px) {
  .container { padding: 0 12px; }
  .hero-title { font-size: 1.5rem; }
  .hero-stats { grid-template-columns: 1fr 1fr; gap: 6px; }
  .hstat-value { font-size: 1.2rem; }
  .stat-card { padding: 16px 10px; }
  .nav-container { padding: 0 14px; }
  .btn-primary-3d, .btn-glass { padding: 12px 18px; font-size: 0.82rem; }
}

/* ============================================================
   LANDSCAPE PHONES  (height < 500px & mobile width)
   ============================================================ */
@media (max-height: 500px) and (max-width: 900px) {
  .hero { min-height: auto; padding: 80px 0 40px; }
  .hero-content { padding-top: 0; }
  .mobile-menu { overflow-y: auto; }
}

/* ============================================================
   LARGE SCREENS  (min 1600px)
   ============================================================ */
@media (min-width: 1600px) {
  .container { max-width: 1440px; }
  .hero-title { font-size: 4.5rem; }
  .mega-inner { max-width: 1440px; }
}
@keyframes scrollMarquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(calc(-100% / 3)); }
}
