/* ============================================
   CANOPUS — Premium Design System
   Version 2.1 - 10/10 Hero Transformation
   Blue #1783f7 → Coral #f2644b gradient
   Dark-first, glass morphism, premium aesthetics
   ============================================ */

/* ----- DESIGN TOKENS ----- */
:root {
  --blue: #1783f7;
  --coral: #f2644b;
  --purple: #8b5cf6;
  --green: #22c55e;
  --gradient: linear-gradient(135deg, #1783f7 0%, #f2644b 100%);
  --gradient-alt: linear-gradient(135deg, #f2644b 0%, #1783f7 100%);
  --gradient-emerald: linear-gradient(135deg, #22c55e 0%, #10b981 100%);
  --gradient-purple: linear-gradient(135deg, #8b5cf6 0%, #6366f1 100%);
  --gradient-soft: linear-gradient(135deg, rgba(23,131,247,0.15) 0%, rgba(242,100,75,0.15) 100%);
  --gradient-animated: conic-gradient(from 0deg, var(--blue), var(--coral), var(--purple), var(--blue));
  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --radius-full: 9999px;
  --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Dark Theme (default) */
[data-theme="dark"] {
  --bg: #050509;
  --bg-elevated: #0d0d14;
  --bg-card: rgba(255,255,255,0.03);
  --bg-glass: rgba(17,17,24,0.6);
  --bg-glass-hover: rgba(17,17,24,0.8);
  --bg-glass-strong: rgba(23,131,247,0.08);
  --border: rgba(255,255,255,0.06);
  --border-hover: rgba(255,255,255,0.12);
  --border-glow: rgba(23,131,247,0.3);
  --text: #f0f0f5;
  --text-secondary: #a0a0b5;
  --text-muted: #606078;
  --text-inverse: #0a0a0f;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 24px rgba(0,0,0,0.5);
  --shadow-lg: 0 12px 48px rgba(0,0,0,0.6);
  --shadow-glow: 0 0 60px rgba(23,131,247,0.12);
  --shadow-neon: 0 0 20px rgba(23,131,247,0.4);
}

/* Light Theme */
[data-theme="light"] {
  --bg: #f8f9fc;
  --bg-elevated: #ffffff;
  --bg-card: rgba(0,0,0,0.02);
  --bg-glass: rgba(255,255,255,0.7);
  --bg-glass-hover: rgba(255,255,255,0.9);
  --bg-glass-strong: rgba(23,131,247,0.04);
  --border: rgba(0,0,0,0.06);
  --border-hover: rgba(0,0,0,0.12);
  --border-glow: rgba(23,131,247,0.2);
  --text: #0a0a14;
  --text-secondary: #505060;
  --text-muted: #888898;
  --text-inverse: #ffffff;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 24px rgba(0,0,0,0.08);
  --shadow-lg: 0 12px 48px rgba(0,0,0,0.12);
  --shadow-glow: 0 0 60px rgba(23,131,247,0.06);
  --shadow-neon: 0 0 20px rgba(23,131,247,0.2);
}

/* ----- CUSTOM CURSOR (Disabled) ----- */
.cursor {
  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); 
  background:var(--bg); 
  color:var(--text); 
  line-height:1.6; 
  overflow-x:hidden; 
  -webkit-font-smoothing:antialiased; 
  transition:background var(--transition-slow),color var(--transition-slow);
  background-image: 
    radial-gradient(ellipse at top left, rgba(23,131,247,0.04) 0%, transparent 60%),
    radial-gradient(ellipse at bottom right, rgba(242,100,75,0.04) 0%, transparent 60%);
}
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul,ol { list-style:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
h1,h2,h3,h4 { line-height:1.15; font-weight:700; letter-spacing:-0.02em; }
h1 { font-size:clamp(2.8rem,5vw,5rem); letter-spacing:-0.04em; }
h2 { font-size:clamp(2rem,3.5vw,3.2rem); letter-spacing:-0.02em; }
h3 { font-size:1.25rem; }

/* ----- LAYOUT ----- */
.container { max-width:1280px; margin:0 auto; padding:0 24px; }
.section { padding:80px 0; position:relative; }
.section-header { text-align:center; margin-bottom:48px; position:relative; }
.section-header::before {
  content: '';
  position: absolute;
  width: 60px;
  height: 1px;
  background: var(--gradient);
  top: -24px;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0.4;
}
.section-title { margin-bottom:12px; position:relative; }
.section-title .text-gradient {
  background-size: 200% 200%;
  animation: gradientShift 8s ease infinite;
}
@keyframes gradientShift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
.section-description { max-width:620px; margin:0 auto; color:var(--text-secondary); font-size:1.05rem; font-weight:300; line-height:1.7; }

/* ----- TYPOGRAPHY HELPERS ----- */
.eyebrow { 
  display:inline-block; 
  font-size:0.8rem; 
  font-weight:600; 
  text-transform:uppercase; 
  letter-spacing:0.15em; 
  color:var(--blue); 
  margin-bottom:16px;
  position:relative;
  padding-left: 12px;
}
.eyebrow::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 4px;
  background: var(--coral);
  border-radius: 50%;
}

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

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

/* ----- BUTTONS ----- */
.btn { 
  display:inline-flex; 
  align-items:center; 
  justify-content:center; 
  gap:8px; 
  padding:12px 28px; 
  border-radius:var(--radius-md); 
  font-weight:600; 
  font-size:0.95rem; 
  transition:all var(--transition); 
  white-space:nowrap; 
  line-height:1;
  position:relative;
  overflow:hidden;
  letter-spacing: -0.01em;
}
.btn::before { content:''; position:absolute; inset:0; background:var(--gradient); opacity:0; transition:opacity var(--transition); z-index: 0; }
.btn > span { position: relative; z-index: 1; }
.btn-primary { background:var(--gradient); color:#fff; box-shadow:0 4px 20px rgba(23,131,247,0.25); border:1px solid var(--border); }
.btn-primary:hover { transform:translateY(-2px) scale(1.02); box-shadow:0 8px 32px rgba(23,131,247,0.4), var(--shadow-neon); filter: brightness(1.1); }
.btn-outline { border:1.5px solid var(--border-hover); color:var(--text); background:transparent; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.btn-outline:hover { border-color:var(--blue); color:var(--blue); transform:translateY(-2px); box-shadow: var(--shadow-neon); }
.btn-white { background:#fff; color:#0a0a0f; box-shadow:0 4px 16px rgba(0,0,0,0.1); border:1px solid rgba(255,255,255,0.2); }
.btn-white:hover { transform:translateY(-2px) scale(1.02); box-shadow:0 8px 28px rgba(0,0,0,0.18), 0 0 30px rgba(255,255,255,0.2); }
.btn-outline-white { border:1.5px solid rgba(255,255,255,0.3); color:#fff; background:transparent; }
.btn-outline-white:hover { background:rgba(255,255,255,0.1); border-color:#fff; box-shadow: 0 0 20px rgba(255,255,255,0.15); }
.btn-lg { padding:16px 38px; font-size:1.08rem; border-radius:var(--radius-lg); }
.btn-sm { padding:9px 22px; font-size:0.88rem; }

.btn-shimmer::after { content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%; background:linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent); transform:translateX(-100%) rotate(15deg); transition:transform 0.6s; }
.btn-shimmer:hover::after { transform:translateX(100%) rotate(15deg); }

/* ----- NAVBAR & MOBILE ----- */
.navbar { 
  position:fixed; 
  top:0; 
  left:0; 
  right:0; 
  z-index:9999; 
  padding:14px 0; 
  transition:all var(--transition); 
  background:var(--bg-elevated);
  border-bottom:1px solid var(--border);
}
.navbar.scrolled { 
  background:var(--bg-glass); 
  backdrop-filter:blur(24px); 
  -webkit-backdrop-filter:blur(24px); 
  border-bottom:1px solid var(--border); 
  padding:8px 0; 
  box-shadow:var(--shadow-md); 
}
.nav-container { 
  display:flex; 
  align-items:center; 
  justify-content:space-between; 
  max-width:1280px; 
  margin:0 auto; 
  padding:0 24px; 
}
.nav-logo { 
  display:flex; 
  align-items:center; 
  gap:12px; 
  font-weight:700; 
  font-size:1.25rem; 
  transition:transform var(--transition); 
}
.nav-logo:hover { 
  transform:translateY(-2px); 
}
.logo-icon { 
  border-radius:var(--radius-sm); 
  filter:drop-shadow(0 0 10px rgba(23,131,247,0.3)); 
  transition:filter var(--transition); 
}
.nav-logo:hover .logo-icon { 
  filter:drop-shadow(0 0 20px rgba(23,131,247,0.5)); 
}
.logo-text { 
  font-size:1.25rem; 
  font-weight:700; 
  letter-spacing:-0.02em; 
}
.nav-links { 
  display:flex; 
  align-items:center; 
  gap:36px; 
}
.nav-link { 
  font-size:0.9rem; 
  font-weight:500; 
  color:var(--text-secondary); 
  transition:all var(--transition); 
  position:relative; 
  padding:8px 12px; 
  min-height:44px; 
  display:flex; 
  align-items:center; 
  gap:4px; 
}

/* Very clear active/hover states for important nav links */
.nav-link.active, .nav-link:hover, a.nav-link[href="services.html"]:hover, a.nav-link[href="products.html"]:hover, a.nav-link[href="about.html"]:hover, a.nav-link[href="contact.html"]:hover {
  color:var(--text);
  background:rgba(23,131,247,0.1);
  border-radius:4px;
}
.nav-link:hover, .nav-link.active { 
  color:var(--text); 
  transform:translateY(-1px); 
}
.nav-link::after { 
  content:''; 
  position:absolute; 
  bottom:0; 
  left:0; 
  right:0; 
  height:2px; 
  background:var(--gradient); 
  border-radius:2px; 
  transform:scaleX(0) translateY(4px); 
  transform-origin:center; 
  transition:transform var(--transition); 
}
.nav-link:hover::after, .nav-link.active::after { 
  transform:scaleX(1) translateY(0); 
}

/* Main menu links with emphasis to make them easily clickable */
.nav-link.nav-link-parent { 
  padding-right:20px; 
}
.nav-link-parent .chevron { 
  transition:transform 0.2s ease; 
  margin-left:4px; 
}
.nav-item-dropdown:hover .nav-link-parent .chevron { 
  transform:rotate(180deg); 
}
.nav-item-dropdown:hover .nav-link { 
  color:var(--text); 
}
.nav-item-dropdown:hover .nav-link::after { 
  transform:scaleX(1) translateY(0); 
}

/* Dropdown Menu Styles */
.nav-item-dropdown { 
  position:relative; 
}
.dropdown-menu { 
  position:absolute; top:calc(100% - 2px); left:50%; transform:translateX(-50%);
  background:rgba(13,13,22,0.98); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(23,131,247,0.35); border-radius:var(--radius-md); padding:8px 0;
  min-width:220px; display:flex; flex-direction:column; gap:2px;
  opacity:0; visibility:hidden; transition:opacity 0.2s ease, visibility 0.2s;
  z-index:9999; box-shadow:0 20px 40px rgba(0,0,0,0.5), 0 0 20px rgba(23,131,247,0.15);
}
.dropdown-menu::before { 
  content:''; 
  position:absolute; 
  top:-20px; 
  left:0; 
  right:0; 
  height:20px; 
  background:transparent; 
}
[data-theme="light"] .dropdown-menu { 
  background:rgba(255,255,255,0.98); 
  border-color:rgba(23,131,247,0.2); 
  box-shadow:0 20px 40px rgba(0,0,0,0.1), 0 0 15px rgba(23,131,247,0.05); 
}
.nav-item-dropdown:hover .dropdown-menu { 
  opacity:1; 
  visibility:visible; 
}
.dropdown-menu li { 
  list-style:none; 
  padding:0 4px; 
  margin:2px 0; 
}
.dropdown-menu a { 
  padding:10px 16px; 
  color:var(--text-secondary); 
  font-size:0.9rem; 
  font-weight:500; 
  transition:all var(--transition); 
  display:block; 
  text-decoration:none; 
  border-radius:4px; 
  margin:0 4px;
}
.dropdown-menu a:hover, .dropdown-menu a.active { 
  color:var(--text); 
  background:rgba(23,131,247,0.15); 
  transform:translateX(4px); 
}

/* Non-dropdown main nav links */
.navbar .nav-link:not(.nav-link-parent):not(.dropdown-menu a) { 
  padding:8px 12px; 
  border-radius:4px; 
  margin:0 2px;
}
.navbar .nav-link:not(.nav-link-parent):not(.dropdown-menu a):hover { 
  background:rgba(23,131,247,0.1); 
  color:var(--text-secondary);
}

.nav-actions { 
  display:flex; 
  align-items:center; 
  gap:16px; 
}
.theme-toggle { 
  width:42px; 
  height:42px; 
  border-radius:50%; 
  display:flex; 
  align-items:center; 
  justify-content:center; 
  background:var(--bg-card); 
  border:1px solid var(--border); 
  transition:all var(--transition); 
  position:relative; 
  overflow:hidden; 
  min-width:44px; 
  min-height:44px; 
}
.theme-toggle:hover { 
  border-color:var(--blue); 
  background:var(--bg-glass); 
  transform:rotate(15deg); 
}
.theme-toggle svg { 
  width:20px; 
  height:20px; 
  stroke:var(--text-secondary); 
  transition:transform var(--transition); 
}
.theme-toggle:hover svg { 
  transform:scale(1.1); 
}
[data-theme="dark"] .sun-icon { 
  display:block; 
}
[data-theme="dark"] .moon-icon { 
  display:none; 
}
[data-theme="light"] .sun-icon { 
  display:none; 
}
[data-theme="light"] .moon-icon { 
  display:block; 
}

.hamburger { 
  display:none; 
  flex-direction:column; 
  gap:6px; 
  padding:6px; 
  cursor:pointer; 
  min-width:44px; 
  min-height:44px; 
  justify-content:center; 
  align-items:center; 
}
.hamburger span { 
  width:24px; 
  height:2px; 
  background:var(--text); 
  border-radius:2px; 
  transition:all var(--transition); 
  display:block; 
  transform-origin:center; 
}
.hamburger.active span:nth-child(1) { 
  transform:rotate(45deg) translate(5px,5px); 
}
.hamburger.active span:nth-child(2) { 
  opacity:0; 
  transform:scaleX(0); 
}
.hamburger.active span:nth-child(3) { 
  transform:rotate(-45deg) translate(5px,-5px); 
}
.nav-container { display:flex; align-items:center; justify-content:space-between; max-width:1280px; margin:0 auto; padding:0 24px; }
.nav-logo { display:flex; align-items:center; gap:12px; font-weight:700; font-size:1.25rem; transition:transform var(--transition); }
.nav-logo:hover { transform:translateY(-2px); }
.logo-icon { border-radius:var(--radius-sm); filter:drop-shadow(0 0 10px rgba(23,131,247,0.3)); transition:filter var(--transition); }
.nav-logo:hover .logo-icon { filter:drop-shadow(0 0 20px rgba(23,131,247,0.5)); }
.logo-text { font-size:1.25rem; font-weight:700; letter-spacing:-0.02em; }
.nav-links { display:flex; align-items:center; gap:36px; }
.nav-link { font-size:0.9rem; font-weight:500; color:var(--text-secondary); transition:all var(--transition); position:relative; padding:8px 12px; min-height:44px; display:flex; align-items:center; gap:4px; }
.nav-link:hover, .nav-link.active { color:var(--text); transform:translateY(-1px); }
.nav-link::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--gradient); border-radius:2px; transform:scaleX(0) translateY(4px); transform-origin:center; transition:transform var(--transition); }
.nav-link:hover::after, .nav-link.active::after { transform:scaleX(1) translateY(0); }

/* Main menu links with emphasis to make them easily clickable */
.nav-link.nav-link-parent { padding-right:20px; }
.nav-link-parent .chevron { transition:transform 0.2s ease; margin-left:4px; }
.nav-item-dropdown:hover .nav-link-parent .chevron { transform:rotate(180deg); }
.nav-item-dropdown:hover .nav-link { color:var(--text); }
.nav-item-dropdown:hover .nav-link::after { transform:scaleX(1) translateY(0); }

/* Dropdown Menu Styles */
.nav-item-dropdown { position:relative; }
.dropdown-menu {
  position:absolute; top:calc(100% - 2px); left:50%; transform:translateX(-50%);
  background:rgba(13,13,22,0.98); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(23,131,247,0.35); border-radius:var(--radius-md); padding:8px 0;
  min-width:220px; display:flex; flex-direction:column; gap:2px;
  opacity:0; visibility:hidden; transition:opacity 0.2s ease, visibility 0.2s;
  z-index:9999; box-shadow:0 20px 40px rgba(0,0,0,0.5), 0 0 20px rgba(23,131,247,0.15);
}
.dropdown-menu::before { content:''; position:absolute; top:-20px; left:0; right:0; height:20px; background:transparent; }
[data-theme="light"] .dropdown-menu { background:rgba(255,255,255,0.98); border-color:rgba(23,131,247,0.2); box-shadow:0 20px 40px rgba(0,0,0,0.1), 0 0 15px rgba(23,131,247,0.05); }
.nav-item-dropdown:hover .dropdown-menu { opacity:1; visibility:visible; }
.dropdown-menu li { list-style:none; padding:0 4px; margin:2px 0; }
.dropdown-menu a { 
  padding:10px 16px; color:var(--text-secondary); font-size:0.9rem; font-weight:500; 
  transition:all var(--transition); display:block; text-decoration:none; 
  border-radius:4px; margin:0 4px;
}
.dropdown-menu a:hover, .dropdown-menu a.active { 
  color:var(--text); background:rgba(23,131,247,0.15); 
  transform:translateX(4px); 
}

/* Non-dropdown main nav links */
.navbar .nav-link:not(.nav-link-parent):not(.dropdown-menu a) { 
  padding:8px 12px; 
  border-radius:4px; 
  margin:0 2px;
}
.navbar .nav-link:not(.nav-link-parent):not(.dropdown-menu a):hover { 
  background:rgba(23,131,247,0.1); 
  color:var(--text-secondary);
}

.nav-actions { display:flex; align-items:center; gap:16px; }
.theme-toggle { width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--bg-card); border:1px solid var(--border); transition:all var(--transition); position:relative; overflow:hidden; min-width:44px; min-height:44px; }
.theme-toggle:hover { border-color:var(--blue); background:var(--bg-glass); transform:rotate(15deg); }
.theme-toggle svg { width:20px; height:20px; stroke:var(--text-secondary); transition:transform var(--transition); }
.theme-toggle:hover svg { transform:scale(1.1); }
[data-theme="dark"] .sun-icon { display:block; }
[data-theme="dark"] .moon-icon { display:none; }
[data-theme="light"] .sun-icon { display:none; }
[data-theme="light"] .moon-icon { display:block; }

.hamburger { display:none; flex-direction:column; gap:6px; padding:6px; cursor:pointer; min-width:44px; min-height:44px; justify-content:center; align-items:center; }
.hamburger span { width:24px; height:2px; background:var(--text); border-radius:2px; transition:all var(--transition); display:block; transform-origin:center; }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ===== HERO SECTION - 10/10 ULTRA-AGRESSIVE ===== */
.hero { 
  position:relative; 
  min-height:100vh; 
  min-height:100dvh; 
  display:flex; 
  align-items:center; 
  padding:130px 0 70px; 
  overflow:hidden;
  /* No isolation - let navbar sit completely above */
}

/* ULTRA-AGRESSIVE Animated Background Orbs & Video */
.hero-bg { position:absolute; inset:0; pointer-events:none; z-index:0; }
.hero-video-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.16;
  z-index: 0;
  pointer-events: none;
}
[data-theme="light"] .hero-video-bg {
  opacity: 0.08;
}
.hero-orb { position:absolute; border-radius:50%; filter:blur(120px); opacity:0.25; z-index: 0; pointer-events:none; }
.orb-1 { width:700px; height:700px; background:var(--blue); top:-100px; right:-250px; animation:orbHyperFloat 25s ease-in-out infinite, orbHyperPulse 15s ease infinite, orbColorShift 20s ease infinite; }
.orb-2 { width:550px; height:550px; background:var(--coral); bottom:-180px; left:-200px; animation:orbHyperFloat 30s ease-in-out infinite reverse, orbHyperPulse 18s ease infinite; }
.orb-3 { width:450px; height:450px; background:radial-gradient(circle, var(--blue), var(--coral)); top:50%; left:50%; transform:translate(-50%,-50%); animation:orbHyperPulse 22s ease-in-out infinite; opacity:0.2; }
.orb-4 { width:400px; height:400px; background:var(--purple); top:15%; left:5%; animation:orbHyperFloat 35s ease-in-out infinite; opacity:0.18; }
.orb-5 { width:350px; height:350px; background:var(--green); bottom:20%; right:15%; animation:orbHyperFloat 28s ease-in-out infinite reverse; opacity:0.15; }

@keyframes orbHyperFloat { 
  0%,100% { transform:translateY(0) scale(1) rotate(0deg); } 
  20% { transform:translateY(-60px) scale(1.08) rotate(3deg); }
  40% { transform:translateY(-100px) scale(1.12) rotate(0deg); } 
  60% { transform:translateY(-40px) scale(1.06) rotate(-3deg); }
  80% { transform:translateY(20px) scale(1.04) rotate(1deg); }
}
@keyframes orbHyperPulse { 
  0%,100% { transform:translate(-50%,-50%) scale(1); opacity:0.15; } 
  25% { transform:translate(-50%,-50%) scale(1.12); opacity:0.25; }
  50% { transform:translate(-50%,-50%) scale(1.25); opacity:0.35; }
  75% { transform:translate(-50%,-50%) scale(1.15); opacity:0.3; }
}
@keyframes orbColorShift {
  0%, 100% { background:var(--blue); }
  33% { background:var(--coral); }
  66% { background:var(--purple); }
}

/* Animated Grid Background */
.hero-grid { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px); background-size:50px 50px; mask-image:radial-gradient(ellipse at center, black 50%, transparent 80%); -webkit-mask-image:radial-gradient(ellipse at center, black 50%, transparent 80%); animation:gridHyperPulse 8s ease-in-out infinite, gridMove 15s linear infinite; }
@keyframes gridHyperPulse { 0%, 100% { opacity:0.4; } 50% { opacity:0.9; } }
@keyframes gridMove { 0% { background-position:0 0; } 100% { background-position:50px 50px; } }
[data-theme="light"] .hero-grid { background-image:linear-gradient(rgba(0,0,0,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(0,0,0,0.06) 1px, transparent 1px); }

.hero-content { position:relative; z-index:10; max-width:950px; margin:0 auto; text-align:center; padding:0 24px; }

/* Enhanced Badge */
.badge { display:inline-flex; align-items:center; gap:12px; padding:10px 24px; border-radius:100px; background:var(--bg-glass); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border:1px solid var(--border); font-size:0.85rem; font-weight:600; color:var(--text-secondary); margin-bottom:24px; transition:all var(--transition); box-shadow:var(--shadow-md); animation:badgeGlow 3s ease-in-out infinite; }
.badge:hover { transform:translateY(-3px) scale(1.02); box-shadow:var(--shadow-lg), var(--shadow-neon); border-color:var(--blue); }
@keyframes badgeGlow { 0%, 100% { box-shadow:var(--shadow-md); } 50% { box-shadow:0 0 30px rgba(23,131,247,0.5), var(--shadow-md); } }
.badge-dot { width:12px; height:12px; border-radius:50%; background:var(--coral); animation:pulseDot 1.5s ease-in-out infinite; box-shadow:0 0 15px var(--coral); }
@keyframes pulseDot { 0%,100% { opacity:1; transform:scale(1); } 50% { opacity:0.4; transform:scale(1.2); } }

.hero-title { margin-bottom:20px; font-weight:900; font-size:clamp(2.8rem,5.5vw,5rem); line-height:1.08; }
.hero-title span { display:block; text-shadow:0 4px 30px rgba(0,0,0,0.3); filter:drop-shadow(0 2px 10px rgba(23,131,247,0.2)); }
.hero-subtitle { font-size:1.15rem; color:var(--text-secondary); max-width:680px; margin:0 auto 40px; font-weight:400; line-height:1.7; text-shadow:0 2px 15px rgba(0,0,0,0.2); }
.hero-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-bottom:52px; }

/* Hero Metrics - Ultra-Enhanced */
.hero-metrics { display:flex; align-items:center; justify-content:center; gap:0; padding:24px 40px; border-radius:var(--radius-xl); background:var(--bg-glass); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border:1px solid var(--border); max-width:800px; margin:0 auto; box-shadow:var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,0.05); animation:metricsPulse 4s ease-in-out infinite; }
.hero-metrics:hover { box-shadow:0 0 80px rgba(23,131,247,0.3), var(--shadow-lg); transform:scale(1.02); }
@keyframes metricsPulse { 0%, 100% { transform:scale(1); } 50% { transform:scale(1.01); } }
.metric { padding:0 28px; text-align:center; transition:all var(--transition); }
.metric:hover { transform:translateY(-4px) scale(1.05); }
.metric-value { display:block; font-size:1.5rem; font-weight:900; background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; color:transparent; letter-spacing:-0.03em; text-shadow:0 2px 10px rgba(0,0,0,0.2); }
.metric-label { font-size:0.8rem; color:var(--text-muted); font-weight:600; display:block; margin-top:4px; text-transform:uppercase; letter-spacing:0.08em; }
.metric-divider { width:1px; height:36px; background:var(--border); flex-shrink:0; box-shadow:0 0 10px var(--border); }

/* ===== GLASS CARDS ===== */
.cards-grid { display:grid; gap:24px; }
.cards-3col { grid-template-columns:repeat(3, 1fr); }
.glass-card { background:var(--bg-glass); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px; transition:all var(--transition); position:relative; overflow:hidden; isolation:isolate; }
.glass-card:hover { border-color:var(--border-hover); transform:translateY(-6px) scale(1.01); box-shadow:var(--shadow-lg), var(--shadow-neon); }
.glass-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--gradient); opacity:0; transition:opacity var(--transition); z-index:1; }
.glass-card:hover::before { opacity:1; }
.glass-card::after { content:''; position:absolute; inset:-1px; border-radius:var(--radius-lg); background:var(--gradient-animated); opacity:0; transition:opacity var(--transition); z-index:-1; filter:blur(10px); }
.glass-card:hover::after { opacity:0.3; }

.card-icon { width:52px; height:52px; border-radius:var(--radius-sm); background:var(--bg-card); display:flex; align-items:center; justify-content:center; margin-bottom:18px; transition:all var(--transition); border:1px solid var(--border); }
.glass-card:hover .card-icon { background:var(--gradient-soft); transform:scale(1.05); box-shadow:var(--shadow-neon); }
.card-title { margin-bottom:10px; font-size:1.15rem; transition:color var(--transition); }
.glass-card:hover .card-title { color:var(--blue); }
.card-text { color:var(--text-secondary); font-size:0.95rem; font-weight:300; margin-bottom:14px; line-height:1.65; }
.card-link { font-size:0.9rem; font-weight:600; color:var(--blue); transition:gap var(--transition); display:inline-flex; align-items:center; gap:4px; }
.card-link:hover { gap:10px; color:var(--coral); }

.featured-card { padding-top:44px; position:relative; }
.featured-card::before { content:''; position:absolute; inset:0; border-radius:var(--radius-lg); padding:1px; background:var(--gradient); -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite:destination-out; mask-composite:exclude; opacity:0.3; }
.card-badge { position:absolute; top:16px; right:16px; padding:5px 16px; border-radius:100px; font-size:0.75rem; font-weight:600; background:var(--gradient); color:#fff; z-index:1; box-shadow:0 2px 8px rgba(23,131,247,0.3); }
.badge-new { background:linear-gradient(135deg, #22c55e, #10b981); }
.card-features { margin:14px 0 18px; display:flex; flex-direction:column; gap:8px; }
.card-features li { font-size:0.88rem; color:var(--text-secondary); padding-left:22px; position:relative; transition:color var(--transition); }
.card-features li:hover { color:var(--text); }
.card-features li::before { content:'✓'; position:absolute; left:0; color:var(--green); font-weight:700; }

.section-cta { text-align:center; margin-top:40px; }

/* ===== PARTICLE EFFECTS ===== */
.particles { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.particle { position:absolute; width:3px; height:3px; background:var(--blue); border-radius:50%; opacity:0; animation:particleFloat linear infinite; box-shadow:0 0 8px var(--blue); }
.particle:nth-child(4n) { background:var(--coral); box-shadow:0 0 8px var(--coral); }
.particle:nth-child(4n+1) { background:var(--purple); box-shadow:0 0 8px var(--purple); }
.particle:nth-child(4n+2) { background:var(--green); box-shadow:0 0 8px var(--green); }
.particle:nth-child(4n+3) { background:var(--blue); box-shadow:0 0 8px var(--blue); }

@keyframes particleFloat { 
  0% { transform:translateY(0) translateX(var(--drift, 0)); opacity:0; }
  8% { opacity:0.7; }
  92% { opacity:0.6; }
  100% { transform:translateY(-100vh) translateX(calc(var(--drift, 0) * 1.5)); opacity:0; }
}

/* ===== TESTIMONIALS & FAQ ===== */
.testimonials-carousel { overflow:hidden; position:relative; perspective:1000px; }
.testimonial-track { display:flex; transition:transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
.testimonial-card { flex:0 0 calc(100%); min-width:100%; padding:36px; transform:translateZ(0) rotateX(0deg); transition:transform 0.5s ease; }
.testimonial-quote { font-size:1.1rem; font-weight:300; color:var(--text); margin-bottom:22px; line-height:1.8; font-style:italic; quotes:"\201C" "\201D"; position:relative; padding-left:22px; }
.testimonial-quote::before { content:''; position:absolute; left:0; top:-10px; font-size:4rem; color:var(--blue); line-height:0; opacity:0.2; }
.testimonial-author { display:flex; align-items:center; gap:16px; }
.author-avatar { width:48px; height:48px; border-radius:50%; background:var(--gradient); display:flex; align-items:center; justify-content:center; font-size:1rem; font-weight:700; color:#fff; flex-shrink:0; box-shadow:0 0 15px rgba(23,131,247,0.3); }
.author-info strong { display:block; font-size:1rem; color:var(--text); }
.author-info span { font-size:0.88rem; color:var(--text-muted); }
.carousel-dots { display:flex; justify-content:center; gap:8px; margin-top:28px; }
.dot { width:10px; height:10px; border-radius:50%; background:var(--border-hover); transition:all var(--transition); cursor:pointer; }
.dot.active { background:var(--gradient); width:32px; border-radius:5px; box-shadow:0 0 10px var(--blue); }
.dot:hover { background:var(--blue); transform:scale(1.2); }

.faq-list { display:flex; flex-direction:column; gap:12px; max-width:800px; margin:0 auto; }
.faq-item { border:1px solid var(--border); border-radius:var(--radius-md); overflow:hidden; transition:all var(--transition); background:var(--bg-glass); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.faq-item:hover { border-color:var(--blue); }
.faq-question { width:100%; text-align:left; padding:18px 24px; display:flex; justify-content:space-between; align-items:center; gap:16px; font-weight:600; font-size:0.95rem; background:var(--bg-card); transition:background var(--transition); cursor:pointer; }
.faq-question:hover { background:var(--bg-glass); }
.faq-icon { flex-shrink:0; width:22px; height:22px; transition:transform var(--transition); }
.faq-item.active .faq-icon { transform:rotate(45deg); }
.faq-item.active .faq-answer { max-height:300px; }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
.faq-answer p { padding:0 24px 18px; color:var(--text-secondary); font-size:0.95rem; line-height:1.8; }

/* ===== CTA SECTION ===== */
.cta-section { position:relative; padding:100px 0; overflow:hidden; background:var(--bg-elevated); isolation:isolate; }
.cta-bg { position:absolute; inset:0; pointer-events:none; }
.cta-orb { position:absolute; border-radius:50%; filter:blur(80px); animation:orbPulse 20s ease-in-out infinite; }
.cta-orb-1 { width:550px; height:550px; background:var(--blue); top:-250px; left:50%; transform:translateX(-50%); opacity:0.12; }
.cta-orb-2 { width:450px; height:450px; background:var(--coral); bottom:-200px; right:10%; opacity:0.1; }
.cta-orb-3 { width:350px; height:350px; background:var(--purple); bottom:-150px; left:15%; opacity:0.08; }
.cta-content { position:relative; z-index:2; text-align:center; max-width:700px; margin:0 auto; }
.cta-title { font-size:clamp(2rem,3.5vw,3rem); margin-bottom:18px; font-weight:800; }
.cta-text { color:var(--text-secondary); font-size:1.1rem; font-weight:300; margin-bottom:32px; line-height:1.7; }
.cta-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

@keyframes pulse { 0% { box-shadow:0 0 0 0 rgba(23,131,247,0.4); } 70% { box-shadow:0 0 0 15px rgba(23,131,247,0); } 100% { box-shadow:0 0 0 0 rgba(23,131,247,0); } }
.btn-primary.btn-lg { animation:pulse 3s ease-in-out infinite; }

/* ===== WHY CANOPUS ===== */
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.why-content { display:flex; flex-direction:column; }
.why-content .section-description { margin:0 0 28px; text-align:left; }
.why-stats { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.stat-card { padding:24px 20px; text-align:center; border-radius:var(--radius-lg); transition:all var(--transition); background:var(--bg-glass); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border:1px solid var(--border); }
.stat-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md), var(--shadow-neon); border-color:var(--border-hover); }
.stat-value { display:block; font-size:2rem; font-weight:800; background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; color:transparent; margin-bottom:6px; letter-spacing:-0.03em; }
.stat-label { font-size:0.85rem; color:var(--text-muted); font-weight:500; }
.feature-checklist { display:flex; flex-direction:column; gap:12px; margin-top:8px; }
.feature-checklist li { display:flex; align-items:flex-start; gap:12px; font-size:0.95rem; color:var(--text-secondary); line-height:1.6; transition:all var(--transition); padding:6px 0; }
.feature-checklist li:hover { color:var(--text); transform:translateX(6px); }
.check-icon { color:var(--green); font-weight:700; font-size:1.15rem; flex-shrink:0; text-shadow:0 0 10px var(--green); }

/* ===== PAGE HERO ===== */
.page-hero { padding:140px 0 70px; text-align:center; position:relative; overflow:hidden; }
.page-hero .hero-bg { position:absolute; inset:0; z-index:0; }
.page-hero .hero-orb { position:absolute; border-radius:50%; filter:blur(80px); animation:orbFloat 15s ease-in-out infinite; pointer-events:none; }
.page-hero .container { position:relative; z-index:1; }
.page-hero-title { font-size:clamp(2.4rem,4vw,3.5rem); margin-bottom:14px; font-weight:800; }
.page-hero-subtitle { color:var(--text-secondary); font-size:1.1rem; max-width:600px; margin:0 auto; font-weight:300; line-height:1.7; }

/* ===== DETAIL CARDS ===== */
.detail-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
.detail-card { padding:36px 32px; }
.detail-card .card-icon { width:60px; height:60px; margin-bottom:22px; }
.detail-card .card-title { font-size:1.25rem; margin-bottom:14px; }
.detail-card.featured { border-color:var(--border-hover); }
.detail-card.featured::after { content:''; position:absolute; inset:0; border-radius:var(--radius-lg); background:var(--gradient); opacity:0.04; pointer-events:none; }

/* ===== PROCESS SECTION ===== */
.process-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:24px; }
.process-step { padding:32px 28px; text-align:center; position:relative; }
.process-number { font-size:2.5rem; font-weight:900; background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; color:transparent; margin-bottom:16px; letter-spacing:-0.04em; line-height:1; }
.process-title { font-size:1.1rem; margin-bottom:10px; font-weight:700; }
.process-text { color:var(--text-secondary); font-size:0.9rem; line-height:1.65; font-weight:300; }

/* ===== REVEAL ANIMATIONS ===== */
.reveal { opacity:0; transform:translateY(40px); transition:opacity 1s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal:nth-child(1) { transition-delay:0ms; }
.reveal:nth-child(2) { transition-delay:50ms; }
.reveal:nth-child(3) { transition-delay:100ms; }
.reveal:nth-child(4) { transition-delay:150ms; }

/* ===== CLIENTS STRIP ===== */
.clients-strip { padding:28px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--bg-elevated); position:relative; overflow:hidden; }
.clients-strip::before { content:''; position:absolute; inset:0; background:linear-gradient(90deg, transparent, var(--border), transparent); opacity:0.3; animation:scanline 8s linear infinite; }
@keyframes scanline { 0% { transform:translateX(-100%); } 100% { transform:translateX(100%); } }
.clients-label { text-align:center; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.12em; color:var(--text-muted); margin-bottom:18px; font-weight:600; position:relative; }
.clients-logos { display:flex; justify-content:center; align-items:center; gap:40px; flex-wrap:wrap; user-select:none; }
.client-logo { font-size:0.95rem; font-weight:600; color:var(--text-muted); transition:all var(--transition); opacity:0.6; position:relative; }
.client-logo:hover { color:var(--text); opacity:1; transform:translateY(-2px); }

/* ===== FOOTER ===== */
.footer { background:var(--bg); padding:72px 0 32px; border-top:1px solid var(--border); position:relative; }
.footer::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:var(--gradient); opacity:0.15; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.footer-brand { display:flex; flex-direction:column; gap:14px; }
.footer-logo { display:flex; align-items:center; gap:10px; font-weight:700; font-size:1.2rem; transition:transform var(--transition); }
.footer-logo:hover { transform:translateY(-2px); }
.footer-desc { color:var(--text-muted); font-size:0.9rem; line-height:1.7; max-width:260px; }
.footer-social { display:flex; gap:12px; }
.footer-social a { color:var(--text-muted); transition:all var(--transition); display:flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; background:var(--bg-card); border:1px solid var(--border); }
.footer-social a:hover { color:#fff; background:var(--gradient); transform:translateY(-3px) rotate(5deg); }
.footer-col h4 { font-size:0.82rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--text); margin-bottom:18px; font-weight:600; }
.footer-col ul { display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { font-size:0.9rem; color:var(--text-muted); transition:color var(--transition); position:relative; padding-left:12px; }
.footer-col ul li a::before { content:'→'; position:absolute; left:0; top:50%; transform:translateY(-50%) translateX(-8px); opacity:0; transition:all var(--transition); color:var(--blue); }
.footer-col ul li a:hover { color:var(--text); padding-left:20px; }
.footer-col ul li a:hover::before { opacity:1; transform:translateY(-50%) translateX(0); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:28px; border-top:1px solid var(--border); flex-wrap:wrap; gap:16px; font-size:0.85rem; color:var(--text-muted); }
.footer-bottom p { margin:0; }
.footer-legal { display:flex; gap:20px; }
.footer-legal a { color:var(--text-muted); transition:color var(--transition); position:relative; }
.footer-legal a:hover { color:var(--text); }

/* ===== INDUSTRY CLIENTS ===== */
.clients-section { padding:36px 0 28px; border-bottom:1px solid var(--border); background:var(--bg-elevated); }
.industry-clients { display:flex; flex-direction:column; gap:24px; }
.industry-group { display:flex; align-items:center; gap:16px; }
.industry-tag { font-size:0.72rem; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-muted); min-width:140px; flex-shrink:0; padding:6px 14px; border:1px solid var(--border); border-radius:var(--radius-full); background:var(--bg-card); text-align:center; }
.industry-logos { display:flex; gap:24px; flex-wrap:wrap; align-items:center; }
.client-logo-wrap { display:flex; align-items:center; gap:8px; opacity:0.5; transition:all var(--transition); cursor:default; }
.client-logo-wrap:hover { opacity:1; transform:translateY(-1px); }
.client-logo-wrap svg { color:var(--text-muted); transition:color var(--transition); }
.client-logo-wrap:hover svg { color:var(--blue); }
.client-name { font-size:0.9rem; font-weight:600; color:var(--text-muted); transition:color var(--transition); }
.client-logo-wrap:hover .client-name { color:var(--text); }

/* ===== SERVICES GRID ===== */
.services-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:20px; }
.service-block { display:flex; flex-direction:column; gap:12px; text-decoration:none; padding:28px; }
.service-icon { width:48px; height:48px; border-radius:var(--radius-sm); background:var(--gradient-soft); display:flex; align-items:center; justify-content:center; transition:all var(--transition); }
.service-block:hover .service-icon { transform:scale(1.08) rotate(-3deg); box-shadow:var(--shadow-neon); }
.service-block h3 { font-size:1.1rem; font-weight:700; transition:color var(--transition); }
.service-block:hover h3 { color:var(--blue); }
.service-block p { color:var(--text-secondary); font-size:0.9rem; line-height:1.65; font-weight:300; flex:1; }
.service-arrow { font-size:0.85rem; color:var(--blue); font-weight:600; opacity:0; transform:translateX(-8px); transition:all var(--transition); }
.service-block:hover .service-arrow { opacity:1; transform:translateX(0); }

/* ===== PRODUCT SHOWCASE ===== */
.products-section { background:var(--bg-elevated); }
.product-showcase { margin-top:20px; }
.product-tabs { display:flex; gap:12px; margin-bottom:32px; justify-content:center; }
.product-tab { display:flex; flex-direction:column; align-items:center; gap:4px; padding:16px 32px; border-radius:var(--radius-lg); border:1.5px solid var(--border); background:var(--bg-glass); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); transition:all var(--transition); cursor:pointer; min-width:160px; }
.product-tab:hover { border-color:var(--border-hover); transform:translateY(-2px); }
.product-tab.active { border-color:var(--blue); background:var(--bg-glass-strong); box-shadow:var(--shadow-neon), var(--shadow-md); }
.tab-icon { font-size:1.2rem; transition:transform var(--transition); }
.product-tab.active .tab-icon { transform:scale(1.15); }
.tab-name { font-size:1rem; font-weight:700; }
.tab-desc { font-size:0.75rem; color:var(--text-muted); font-weight:500; }
.product-panels { position:relative; }
.product-panel { display:none; animation:panelFade 0.4s ease; }
.product-panel.active { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; background:var(--bg-glass); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border:1px solid var(--border); border-radius:var(--radius-xl); padding:40px; }
@keyframes panelFade { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.panel-badge { display:inline-block; padding:5px 16px; border-radius:var(--radius-full); font-size:0.75rem; font-weight:600; background:var(--gradient); color:#fff; margin-bottom:14px; box-shadow:0 2px 8px rgba(23,131,247,0.3); }
.badge-new { background:linear-gradient(135deg, #22c55e, #10b981); }
.panel-content h3 { font-size:1.6rem; font-weight:800; margin-bottom:12px; }
.panel-desc { color:var(--text-secondary); font-size:0.95rem; line-height:1.7; margin-bottom:20px; }
.panel-features { display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.panel-features li { display:flex; align-items:center; gap:10px; font-size:0.9rem; color:var(--text-secondary); line-height:1.5; }
.pf-icon { color:var(--green); font-weight:700; font-size:1rem; flex-shrink:0; }

/* Product Visual Dashboards */
.panel-visual { position:relative; }
.visual-dashboard { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); }
.dash-header { display:flex; align-items:center; gap:12px; padding:12px 16px; border-bottom:1px solid var(--border); background:var(--bg-elevated); }
.dash-dots { display:flex; gap:6px; }
.dash-dots span { width:10px; height:10px; border-radius:50%; }
.dash-dots span:nth-child(1) { background:#ff5f57; }
.dash-dots span:nth-child(2) { background:#febc2e; }
.dash-dots span:nth-child(3) { background:#28c840; }
.dash-title { font-size:0.8rem; color:var(--text-muted); font-weight:500; }
.dash-body { padding:20px; display:flex; flex-direction:column; gap:16px; }
.dash-metric { display:flex; justify-content:space-between; align-items:center; padding:10px 14px; background:var(--bg-card); border-radius:var(--radius-sm); border:1px solid var(--border); }
.dm-val { font-size:1.1rem; font-weight:800; background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; color:transparent; }
.dm-label { font-size:0.8rem; color:var(--text-muted); }
.dash-chart { display:flex; align-items:end; gap:6px; height:80px; padding:10px 0; }
.chart-bar { flex:1; background:var(--gradient); border-radius:3px 3px 0 0; opacity:0.8; transition:opacity var(--transition); animation:barGrow 1.5s ease-out; }
.chart-bar:hover { opacity:1; }
@keyframes barGrow { from { height:0; } }

/* Nexus Data Flow */
.data-flow { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; }
.flow-source, .flow-dest { padding:8px 14px; border-radius:var(--radius-sm); font-size:0.8rem; font-weight:600; border:1px solid var(--border); background:var(--bg-card); }
.flow-source { border-color:var(--blue); color:var(--blue); }
.flow-dest { border-color:var(--coral); color:var(--coral); }
.flow-arrow { color:var(--text-muted); font-size:1.2rem; display:flex; align-items:center; }
.flow-center { display:flex; justify-content:center; padding:16px 0; }
.flow-hub { padding:14px 40px; border-radius:var(--radius-md); background:var(--gradient); color:#fff; font-weight:800; font-size:1.1rem; box-shadow:var(--shadow-neon), var(--shadow-md); animation:pulse 3s ease-in-out infinite; }

/* Prism Workbench */
.prism-prompt, .prism-response { padding:14px; border-radius:var(--radius-sm); border:1px solid var(--border); background:var(--bg-card); }
.prompt-label, .response-label { font-size:0.7rem; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; margin-bottom:8px; display:block; }
.prompt-label { color:var(--blue); }
.response-label { color:var(--coral); }
.prompt-text, .response-text { font-size:0.85rem; color:var(--text-secondary); line-height:1.6; }

/* ===== INDUSTRIES GRID ===== */
.industries-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:20px; }
.industry-card { padding:28px; text-align:left; }
.ic-icon { font-size:2rem; margin-bottom:14px; }
.industry-card h3 { font-size:1.1rem; font-weight:700; margin-bottom:10px; transition:color var(--transition); }
.industry-card:hover h3 { color:var(--blue); }
.industry-card p { color:var(--text-secondary); font-size:0.9rem; line-height:1.65; font-weight:300; }

/* ===== FOOTER ADDRESS ===== */
.footer-address { font-style:normal; font-size:0.88rem; color:var(--text-muted); line-height:1.7; max-width:280px; }
.footer-address a { color:var(--blue); transition:color var(--transition); }
.footer-address a:hover { color:var(--coral); }

/* ===== CONTACT FORM ===== */
.contact-form { display:flex; flex-direction:column; gap:18px; }
.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.82rem; font-weight:600; color:var(--text-secondary); text-transform:uppercase; letter-spacing:0.06em; }
.form-group input, .form-group select, .form-group textarea {
  padding:12px 16px; border-radius:var(--radius-sm); border:1.5px solid var(--border);
  background:var(--bg-card); color:var(--text); font-family:var(--font); font-size:0.95rem;
  transition:all var(--transition); outline:none;
}
.form-group input::placeholder, .form-group textarea::placeholder { color:var(--text-muted); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color:var(--blue); box-shadow:0 0 0 3px rgba(23,131,247,0.15);
}
.form-group select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%23888898' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:40px; }
.form-group textarea { resize:vertical; min-height:120px; }

/* ===== CONTACT INFO ===== */
.contact-info-list { display:flex; flex-direction:column; gap:14px; }
.contact-info-item { display:flex; gap:16px; align-items:flex-start; padding:20px; }
.ci-icon { font-size:1.4rem; flex-shrink:0; margin-top:2px; }
.contact-info-item h4 { font-size:0.95rem; font-weight:700; margin-bottom:4px; }
.contact-info-item p { color:var(--text-secondary); font-size:0.9rem; line-height:1.6; }
.contact-info-item a { color:var(--blue); transition:color var(--transition); }
.contact-info-item a:hover { color:var(--coral); }

/* ===== RESPONSIVE ===== */
@media (max-width:1200px) {
  .hero-title { font-size:clamp(2.4rem,4.5vw,4rem); }
  .footer-grid { grid-template-columns:1.5fr 1fr 1fr 1fr; }
}
@media (max-width:1024px) {
  .cards-3col, .detail-grid { grid-template-columns:repeat(2, 1fr); }
  .process-grid { grid-template-columns:repeat(2, 1fr); }
  .footer-grid { grid-template-columns:repeat(3, 1fr); }
  .why-grid { grid-template-columns:1fr; gap:48px; }
  .hero-metrics { flex-wrap:wrap; gap:16px; padding:20px; }
  .metric-divider { display:none; }
  .metric { padding:0 16px; }
  .services-grid { grid-template-columns:repeat(2, 1fr); }
  .industries-grid { grid-template-columns:repeat(2, 1fr); }
  .product-panel.active { grid-template-columns:1fr; }
  .industry-group { flex-direction:column; align-items:flex-start; gap:10px; }
  .careers-grid { grid-template-columns:1fr; }
}
@media (max-width:768px) {
  .section, .page-hero { padding:60px 0; }
  .hero { padding:120px 0 60px; min-height:auto; }

  /* Mobile Navigation - Improved for clicking */
  .nav-links {
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--bg-elevated);
    border-bottom:1px solid var(--border);
    padding:16px 24px;
    gap:0;
    flex-direction:column;
    align-items:stretch;
    backdrop-filter:blur(24px);
    -webkit-backdrop-filter:blur(24px);
    box-shadow:var(--shadow-lg);
    max-height:calc(100vh - 70px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .nav-links.active { display:flex; }
  .nav-cta { display:none; }
  .hamburger { display:flex; }

  /* Mobile nav links - emphasized for clicking */
  .nav-links li { margin-bottom:8px; }
  .nav-links .nav-link {
    display:block;
    padding:16px 20px;
    border-radius:var(--radius-sm);
    background:var(--bg-card);
    border:1px solid var(--border);
    font-size:1rem;
    min-height:52px;
    display:flex;
    align-items:center;
    transition:all var(--transition);
  }
  .nav-links .nav-link:hover {
    background:var(--gradient-soft);
    border-color:var(--blue);
    color:var(--text);
    transform:translateX(4px);
  }

  /* Grids */
  .cards-3col, .detail-grid, .process-grid { grid-template-columns:1fr; }
  .services-grid { grid-template-columns:1fr; }
  .industries-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:32px; }

  /* Hero */
  .hero-metrics { padding:18px; flex-wrap:wrap; justify-content:center; }
  .metric { padding:0 10px; min-width:100px; }
  .hero-actions { flex-direction:column; align-items:center; gap:12px; }
  .hero-actions .btn { width:100%; max-width:320px; }

  /* Product Tabs */
  .product-tabs { flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:8px; gap:10px; justify-content:flex-start; scrollbar-width:none; }
  .product-tabs::-webkit-scrollbar { display:none; }
  .product-tab { min-width:140px; padding:14px 20px; flex-shrink:0; }
  .product-panel.active { padding:24px; }

  /* Testimonial */
  .testimonial-card { flex:0 0 100%; padding:28px; }

  /* Why Stats */
  .why-stats { grid-template-columns:1fr 1fr; gap:14px; }

  /* Clients */
  .clients-logos { gap:20px; }
  .industry-clients { gap:16px; }

  /* Contact Form */
  .form-row { grid-template-columns:1fr; }

  /* Buttons: full width on mobile */
  .cta-actions { flex-direction:column; align-items:center; }
  .cta-actions .btn { width:100%; max-width:320px; }
}
@media (max-width:480px) {
  .container { padding:0 16px; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .footer-legal { justify-content:center; flex-wrap:wrap; }
  .why-stats { grid-template-columns:1fr; }
  .hero-metrics { flex-direction:column; gap:14px; }
  .hero-metrics .metric { padding:0; }
  .product-panel.active { padding:16px; }
  .stat-value { font-size:1.6rem; }
  .section-title { font-size:clamp(1.6rem,6vw,2.2rem); }
  .hero-title { font-size:clamp(2rem,8vw,3rem); }
  .page-hero-title { font-size:clamp(1.8rem,7vw,2.6rem); }
  .glass-card { padding:20px; }
  .btn-lg { padding:14px 28px; font-size:1rem; }
  .badge { padding:8px 16px; font-size:0.8rem; }
}

/* ===== RESPONSIVE OPTIMIZED IMAGE UTILITIES ===== */

/* Touch device optimizations */
@media (hover:none) and (pointer:coarse) {
  /* Remove hover-only transforms that interfere with touch */
  .glass-card:hover { transform:none; }
  .service-block:hover { transform:none; }
  .btn:hover { transform:none; }
  .btn-primary:hover { transform:none; filter:none; }
  .stat-card:hover { transform:none; }
  .industry-card:hover { transform:none; }
  .metric:hover { transform:none; }
  .client-logo-wrap:hover { transform:none; }
  .product-tab:hover { transform:none; }

  /* Ensure tap targets are at least 44px */
  .nav-link { min-height:44px; display:flex; align-items:center; }
  .btn { min-height:44px; }
  .product-tab { min-height:48px; }
  .faq-question { min-height:52px; }
  .hamburger { min-width:44px; min-height:44px; }
  .theme-toggle { min-width:44px; min-height:44px; }
}

/* 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-video-bg { display:none; }
  .particles { display:none; }
}

.responsive-img-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--bg-card);
  aspect-ratio: 16/10;
}
.responsive-img-wrapper img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}
.responsive-img-wrapper:hover img {
  transform: scale(1.04);
}

/* Service visual card blocks styling */
.service-visual-block {
  margin-top: 16px;
  height: 200px;
  width: 100%;
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
  border: 1px solid var(--border);
  background: var(--bg-card);
}
.service-visual-block img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.85;
  transition: opacity var(--transition), transform var(--transition-slow);
}
.service-block:hover .service-visual-block img {
  transform: scale(1.05);
  opacity: 1;
}
@media (max-width:768px) {
  .service-visual-block { height:160px; }
}

/* Story and Careers image cards */
.story-image-wrap, .careers-image-wrap {
  width: 100%;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  aspect-ratio: 4/3;
  background: var(--bg-card);
}
.story-image-wrap img, .careers-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}
.story-image-wrap:hover img, .careers-image-wrap:hover img {
  transform: scale(1.03);
}

/* Product image banners/visuals */
.product-visual-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  opacity: 0.9;
}

/* Careers Grid Layout */
.careers-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.8fr 1.1fr;
  gap: 40px;
  align-items: start;
}
@media (max-width: 1024px) {
  .careers-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
}