﻿
/* Clean White Theme (Updated) - Professional Clean Design */
/* Fallback styles for browsers without CSS custom property support */
body { background: #ffffff; color: #1e293b; }
.nav { background: rgba(255,255,255,0.95); border-color: #e2e8f0; }
a { color: #3b82f6; }
.btn { background: #3b82f6; color: #ffffff; border-color: #e2e8f0; }
.card { background: #ffffff; border-color: #e2e8f0; }

/* Modern browsers with CSS custom properties */
:root{
  --bg:#ffffff; --panel:#f8fafc; --muted:#64748b; --text:#1e293b;
  --brand:#3b82f6; --brand-2:#60a5fa; --border:#e2e8f0; --danger:#ef4444; --success:#10b981;
  --accent:rgba(59,130,246,0.05); --shadow:rgba(0,0,0,0.1); --hover-shadow:rgba(0,0,0,0.15);
  --card-bg:#ffffff; --nav-bg:rgba(255,255,255,0.95); --nav-border:rgba(255,255,255,0.2);
  --primary:#3b82f6; --secondary:#2563eb; --tertiary:#60a5fa; --quaternary:#93c5fd;
  --neutral:#64748b; --dark:#1e293b; --darker:#0f172a;
}
/* Light theme fallback */
[data-theme="light"]{
  --bg:#fcfbf9; --panel:#f8f6f4; --muted:#64748b; --text:#0f172a;
  --brand:#3b82f6; --brand-2:#60a5fa; --border:#e2e8f0; --danger:#dc3545; --success:#198754;
  --accent:rgba(59,130,246,0.1); --shadow:rgba(0,0,0,0.06); --hover-shadow:rgba(0,0,0,0.1);
  --card-bg:#ffffff; --nav-bg:rgba(252,251,249,0.95); --nav-border:rgba(15,23,42,0.1);
  --primary:#3b82f6; --secondary:#2563eb; --tertiary:#60a5fa; --quaternary:#93c5fd;
  --neutral:#64748b; --dark:#0f172a; --darker:#020617;
}
*{box-sizing:border-box}

/* Mobile navigation - show on mobile screens */
@media (max-width: 768px) {
  .nav-toggle {
    display: flex !important;
  }
  .mobile-nav.active {
    display: block !important;
  }
}

/* Desktop: Hide mobile toggle, show nav-menu */
@media (min-width: 769px) {
  .nav-toggle,
  .quantum-mobile-toggle {
    display: none !important;
  }
  .nav-menu {
    display: flex !important;
  }
}

/* Mobile: Hide nav-menu (quantum mobile nav CSS is in worker) */
@media (max-width: 768px) {
  .nav-menu {
    display: none !important;
  }
}

html{-webkit-text-size-adjust:100%;background:#0a0e27}
body{
  margin:0;
  /* Fallback for browsers without env() support */
  padding:0;
  /* Modern browsers with safe-area-inset support */
  padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom);
  /* Fallback background and color */
  background:#ffffff;
  color:#1e293b;
  /* Modern browsers with CSS custom properties */
  background:var(--bg);
  color:var(--text);
  font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  transition:background 0.3s ease, color 0.3s ease;
  -webkit-tap-highlight-color: transparent;
}
/* Typographic hierarchy - Bold & Modern */
h1,h2,h3{margin:0 0 16px;text-wrap:balance;line-height:1.1;color:#ffffff}
/* Fallback typography for browsers without clamp() */
h1{font-size:3rem;letter-spacing:-0.03em;font-weight:900}
h2{font-size:2rem;letter-spacing:-0.02em;font-weight:800}
h3{font-size:1.5rem;font-weight:700}
/* Modern browsers with clamp() support */
@supports (font-size: clamp(1rem, 1vw, 2rem)) {
  h1{font-size:clamp(2.5rem,3rem + 1vw,4rem)}
  h2{font-size:clamp(1.75rem,2rem + 0.75vw,2.5rem)}
  h3{font-size:clamp(1.25rem,1.5rem + 0.5vw,1.75rem)}
}
p{margin:0 0 16px;max-width:72ch;line-height:1.7}
ul,ol{padding-left:1.2rem}
.lead{color:var(--muted);font-size:1.15rem;line-height:1.7}
.lead-xl{font-size:clamp(1.15rem,1.25rem + 0.5vw,1.5rem);line-height:1.6;color:var(--muted)}
.eyebrow{display:inline-block;font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-2);background:var(--accent);padding:4px 8px;border-radius:999px}
.section-rule{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:16px 0;opacity:.8}
body.cookie-open{padding-bottom:86px}
/* Premium dark gradient overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image: 
    radial-gradient(ellipse at 20% 10%, rgba(59,130,246,0.15), transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(96,165,250,0.1), transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(59,130,246,0.05), transparent 70%);
}
[data-theme="light"] body::before{
  opacity:.03;
  background-image: radial-gradient(circle at 20% 10%, var(--brand), transparent 50%),
                    radial-gradient(circle at 80% 80%, var(--brand-2), transparent 50%);
}
img,iframe{max-width:100%;display:block}
/* Reserve intrinsic ratio to reduce CLS when width/height attributes are present */
img[width][height]{height:auto;aspect-ratio: attr(width number) / attr(height number)}
.container{max-width:1200px;margin:0 auto;padding:32px 24px}
a{color:var(--brand);text-decoration:none;transition:color 0.2s ease}
a{
  color:var(--brand);
  text-decoration:none;
  background-image:linear-gradient(currentColor, currentColor);
  background-size:0% 2px; background-position:0 100%; background-repeat:no-repeat;
  transition:color 0.2s ease, background-size 0.25s ease;
}
a:hover{color:var(--brand-2);background-size:100% 2px}
a:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:6px}
/* Gradient text utility */
.grad-text, .gradient-text{background:linear-gradient(135deg,var(--brand),var(--brand-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;background:var(--text);color:var(--bg);border:2px solid var(--brand);border-radius:8px;padding:12px 16px;z-index:999;font-weight:600}
.small{font-size:0.875rem;line-height:1.5}
.center{text-align:center}
.muted{color:var(--muted)}
.error{color:var(--danger);font-weight:600}

/* Contact form status message styling */
#contact-status.status.error {
  color: var(--danger);
  font-weight: 500;
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid rgba(220, 53, 69, 0.3);
}
#contact-status.status.success {
  color: var(--success);
  font-weight: 500;
  background: rgba(25, 135, 84, 0.1);
  border: 1px solid rgba(25, 135, 84, 0.3);
}
#contact-status.status {
  font-size: 0.875rem;
  margin-top: 12px;
  padding: 8px 12px;
  border-radius: 6px;
  background: var(--panel);
  border: 1px solid var(--border);
}
.fade-in{animation:fadeIn 0.6s ease both}
@keyframes fadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-out{opacity:0;transform:translateY(-8px);transition:opacity 0.3s ease, transform 0.3s ease}
/* View Transitions API fallback is handled by fade-in/out */
:root::view-transition-old(root),:root::view-transition-new(root){
  animation-duration:0.35s;
}


/* CLOUDFLARE-INSPIRED NAVIGATION - Cross-Browser Compatible */
.cf-nav {
  position: sticky;
  position: -webkit-sticky; /* Safari */
  top: 0;
  z-index: 1000;
  background: rgba(252, 251, 249, 0.95);
  background: -webkit-linear-gradient(rgba(252, 251, 249, 0.95), rgba(252, 251, 249, 0.95)); /* Safari fallback */
  
  /* Cross-browser backdrop filter support */
  backdrop-filter: saturate(150%) blur(20px);
  -webkit-backdrop-filter: saturate(150%) blur(20px); /* Safari */
  
  /* Fallback for browsers without backdrop-filter */
  background-color: rgba(255, 255, 255, 0.98);
  
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  
  /* Cross-browser transitions */
  transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
}

.cf-nav-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  
  /* Ensure proper box model */
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

/* Flexible layouts with gap fallbacks */
.grid, .flex-grid {
  /* Fallback for browsers without gap support */
  margin: -8px;
}
.grid > *, .flex-grid > * {
  /* Fallback spacing using margins */
  margin: 8px;
}

/* Modern browsers with gap support */
@supports (gap: 1rem) {
  .grid, .flex-grid {
    margin: 0;
    gap: 16px;
  }
  .grid > *, .flex-grid > * {
    margin: 0;
  }
}

/* Cross-browser flexbox with fallbacks */
.cf-nav-inner {
  /* Cross-browser flexbox */
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -moz-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  
  height: 72px;
  min-height: 72px; /* Ensure consistent height across browsers */
  gap: 48px; /* Increased from 32px to create more space */
  
  /* Flexbox gap fallback for older browsers */
  margin-left: -24px; /* Increased for larger gap */
}

.cf-nav-inner > * {
  margin-left: 24px; /* Increased fallback gap for older browsers */
}

/* Brand Section */
.cf-nav-brand {
  -webkit-box-flex: 0;
  -webkit-flex-shrink: 0;
  -moz-box-flex: 0;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.cf-brand-link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  
  gap: 12px;
  text-decoration: none;
  color: inherit;
  
  /* Clean transitions */
  transition: opacity 0.2s ease;
  -webkit-transition: opacity 0.2s ease;
  -moz-transition: opacity 0.2s ease;
  -o-transition: opacity 0.2s ease;
  
  /* Remove default link styles */
  outline: none;
  border: none;
  
  /* Ensure clean rendering */
  background: none;
  box-shadow: none;
  filter: none;
  backdrop-filter: none;
  
  /* Clean margins and padding */
  margin: 0;
  padding: 0;
}

.cf-brand-link:hover {
  opacity: 0.8;
  text-decoration: none;
  
  /* Ensure no weird effects on hover */
  background: none;
  box-shadow: none;
  filter: none;
}

.cf-brand-link:focus {
  opacity: 0.8;
  outline: 2px solid var(--brand);
  outline-offset: 2px;
  text-decoration: none;
  
  /* Clean focus state */
  background: none;
  box-shadow: none;
  filter: none;
}

.cf-brand-logo {
  height: 32px;
  width: auto;
  transition: all 0.2s ease;
  filter: brightness(1);
  max-width: 120px; /* Prevent logo from being too wide */
  object-fit: contain; /* Maintain aspect ratio */
}

[data-theme="dark"] .cf-brand-logo {
  filter: brightness(1.1);
}

.cf-brand-link:hover .cf-brand-logo {
  transform: scale(1.05);
}

/* Mobile responsive logo sizing */
@media (max-width: 768px) {
  .cf-brand-logo {
    height: 28px;
    max-width: 100px;
  }
}

@media (max-width: 480px) {
  .cf-brand-logo {
    height: 24px;
    max-width: 80px;
  }
}

.cf-brand-logo {
  height: 32px;
  width: auto;
  
  /* Clean image rendering - remove the problematic crisp-edges */
  image-rendering: auto;
  image-rendering: -webkit-optimize-contrast;
  
  /* Better cross-browser object-fit */
  object-fit: contain;
  -o-object-fit: contain;
  
  /* Prevent image dragging */
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
  user-drag: none;
  
  /* Clean display */
  display: block;
  
  /* Remove any artifacts */
  border: none;
  outline: none;
  background: transparent;
  
  /* Ensure no weird effects */
  filter: none;
  backdrop-filter: none;
  
  /* Clean margins and padding */
  margin: 0;
  padding: 0;
}

.cf-brand-text {
  font-size: 1.125rem;
  font-weight: 600;
  color: #1a1a1a;
  letter-spacing: -0.02em;
  white-space: nowrap;
  
  /* Clean text rendering */
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  
  /* Ensure no weird effects */
  background: none;
  text-shadow: none;
  filter: none;
  
  /* Remove any potential decorations */
  text-decoration: none;
  border: none;
  outline: none;
  
  /* Clean margins and padding */
  margin: 0;
  padding: 0;
}

.cf-tm {
  font-size: 0.6em;
  vertical-align: super;
  margin-left: 2px;
  opacity: 0.7;
}

/* Clean Logo Rendering - Fix Vectorized Appearance */
.cf-brand-logo,
.brand-logo {
  /* Remove pixelated/vectorized effects */
  image-rendering: auto !important;
  -webkit-image-rendering: auto !important;
  -moz-image-rendering: auto !important;
  -o-image-rendering: auto !important;
  ms-interpolation-mode: bicubic !important;
  
  /* Ensure smooth rendering */
  filter: none !important;
  backdrop-filter: none !important;
  
  /* Clean display properties */
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  
  /* Proper sizing */
  height: 32px;
  width: auto;
  max-width: 140px;
  
  /* Clean object-fit */
  object-fit: contain;
  object-position: left center;
}

/* Ensure brand containers don't add weird effects */
.cf-brand-link,
.brand {
  background: none !important;
  box-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
  
  /* Clean positioning */
  position: relative;
  z-index: auto;
}

/* Remove any pseudo-elements that might cause artifacts */
.cf-brand-link::before,
.cf-brand-link::after,
.brand::before,
.brand::after {
  display: none !important;
  content: none !important;
}

/* Clean text rendering for brand text */
.cf-brand-text,
.brand-text {
  background: none !important;
  text-shadow: none !important;
  filter: none !important;
  
  /* Ensure clean text rendering */
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Remove any flare or gradient effects */
.brand-flare {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

/* Main Navigation */
.cf-nav-main {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -moz-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  
  gap: 48px; /* Increased spacing */
  margin-left: -24px; /* Increased fallback gap */
  padding-left: 32px; /* Add extra padding to push nav items further right */
}

/* Centered navigation when no logo is present */
.cf-nav-main.cf-nav-centered {
  justify-content: flex-end;
  -webkit-justify-content: flex-end;
  -moz-box-pack: end;
  -ms-flex-pack: end;
  
  padding-left: 0;
  margin-left: 0;
  gap: 0;
  padding-right: 280px; /* Push nav links away from right edge to leave space for actions */
}

/* Navigation with logo (standard layout) */
.cf-nav-main.cf-nav-with-logo {
  justify-content: space-between;
  -webkit-justify-content: space-between;
  -moz-box-pack: justify;
  -ms-flex-pack: justify;
  
  padding-left: 0;
  margin-left: 0;
  gap: 48px;
}

.cf-nav-main.cf-nav-centered .cf-nav-links {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -moz-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

.cf-nav-main.cf-nav-with-logo .cf-nav-links {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -moz-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

.cf-nav-main.cf-nav-centered .cf-nav-actions {
  position: absolute;
  right: 0;
}

.cf-nav-main.cf-nav-with-logo .cf-nav-actions {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -moz-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

.cf-nav-main > * {
  margin-left: 24px; /* Increased fallback gap for older browsers */
}

.cf-nav-links {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  
  gap: 8px;
  margin-left: -4px; /* Fallback gap */
}

.cf-nav-links > * {
  margin-left: 4px; /* Fallback gap for older browsers */
}

.cf-nav-item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  
  gap: 8px;
  padding: 12px 16px;
  
  /* Cross-browser border-radius */
  border-radius: 8px;
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  
  text-decoration: none;
  color: #4a4a4a;
  font-weight: 500;
  font-size: 0.95rem;
  
  /* Cross-browser transitions with fallbacks */
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  -moz-transition: all 0.2s ease; /* Fallback easing for Firefox */
  -o-transition: all 0.2s ease;
  
  position: relative;
  white-space: nowrap;
  overflow: hidden;
  
  /* Prevent text selection */
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  
  /* Better touch targets for mobile */
  min-height: 44px;
  min-width: 44px;
  
  /* Box model consistency */
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.cf-nav-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  
  /* Cross-browser gradients */
  background: linear-gradient(90deg, transparent, rgba(0, 102, 204, 0.08), transparent);
  background: -webkit-linear-gradient(left, transparent, rgba(0, 102, 204, 0.08), transparent);
  background: -moz-linear-gradient(left, transparent, rgba(0, 102, 204, 0.08), transparent);
  background: -o-linear-gradient(left, transparent, rgba(0, 102, 204, 0.08), transparent);
  
  transition: left 0.6s ease;
  -webkit-transition: left 0.6s ease;
  -moz-transition: left 0.6s ease;
  -o-transition: left 0.6s ease;
  
  border-radius: inherit;
  -webkit-border-radius: inherit;
  -moz-border-radius: inherit;
}

.cf-nav-item:hover::before {
  left: 100%;
}

.cf-nav-item:hover {
  color: #0066cc;
  background: rgba(0, 102, 204, 0.04);
  text-decoration: none;
  
  /* Cross-browser transforms */
  transform: translateY(-1px);
  -webkit-transform: translateY(-1px);
  -moz-transform: translateY(-1px);
  -o-transform: translateY(-1px);
  -ms-transform: translateY(-1px);
}

.cf-nav-item:focus {
  outline: 2px solid #0066cc;
  outline-offset: 2px;
  color: #0066cc;
  text-decoration: none;
}

.cf-nav-item.active,
.cf-nav-item[aria-current="page"] {
  color: #0066cc;
  background: rgba(0, 102, 204, 0.08);
  font-weight: 600;
  
  /* Cross-browser box-shadow */
  box-shadow: 0 2px 4px rgba(0, 102, 204, 0.1);
  -webkit-box-shadow: 0 2px 4px rgba(0, 102, 204, 0.1);
  -moz-box-shadow: 0 2px 4px rgba(0, 102, 204, 0.1);
}

.cf-nav-icon {
  width: 16px;
  height: 16px;
  opacity: 0.7;
  
  /* Cross-browser transitions */
  transition: opacity 0.2s ease;
  -webkit-transition: opacity 0.2s ease;
  -moz-transition: opacity 0.2s ease;
  -o-transition: opacity 0.2s ease;
  
  /* SVG rendering optimization */
  shape-rendering: geometricPrecision;
  
  /* Flexbox item behavior */
  -webkit-box-flex: 0;
  -webkit-flex-shrink: 0;
  -moz-box-flex: 0;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.cf-nav-item:hover .cf-nav-icon {
  opacity: 1;
}

.cf-nav-label {
  font-inherit;
  
  /* Ensure text doesn't wrap */
  white-space: nowrap;
}

/* Right Side Actions */
.cf-nav-actions {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  
  gap: 16px;
  
  -webkit-box-flex: 0;
  -webkit-flex-shrink: 0;
  -moz-box-flex: 0;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  
  margin-left: -8px; /* Fallback gap */
}

.cf-nav-actions > * {
  margin-left: 8px; /* Fallback gap for older browsers */
}

.cf-nav-secondary {
  color: #6b7280;
  text-decoration: none;
  font-weight: 500;
  font-size: 0.9rem;
  padding: 8px 12px;
  border-radius: 6px;
  transition: all 0.2s ease;
}

.cf-nav-secondary:hover {
  color: #374151;
  background: rgba(0, 0, 0, 0.04);
  text-decoration: none;
}

.cf-nav-divider {
  width: 1px;
  height: 20px;
  background: rgba(0, 0, 0, 0.1);
}

/* Login Button & Dropdown - Cross Browser */
.cf-dropdown {
  position: relative;
}

.cf-login-btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  
  gap: 8px;
  padding: 10px 16px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  
  /* Cross-browser border-radius */
  border-radius: 8px;
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  
  color: #374151;
  font-weight: 500;
  font-size: 0.9rem;
  font-family: inherit;
  cursor: pointer;
  text-decoration: none;
  
  /* Cross-browser transitions */
  transition: all 0.2s ease;
  -webkit-transition: all 0.2s ease;
  -moz-transition: all 0.2s ease;
  -o-transition: all 0.2s ease;
  
  white-space: nowrap;
  
  /* Better touch targets */
  min-height: 44px;
  
  /* Box model consistency */
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  appearance: none;
  
  /* Prevent text selection */
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.cf-login-btn:hover {
  background: #f9fafb;
  border-color: #d1d5db;
  color: #0066cc;
}

.cf-login-btn:focus {
  outline: none;
  border-color: #0066cc;
  
  /* Cross-browser box-shadow */
  box-shadow: 0 0 0 3px rgba(0, 102, 204, 0.1);
  -webkit-box-shadow: 0 0 0 3px rgba(0, 102, 204, 0.1);
  -moz-box-shadow: 0 0 0 3px rgba(0, 102, 204, 0.1);
}

.cf-login-btn:active {
  /* Cross-browser transforms */
  transform: translateY(1px);
  -webkit-transform: translateY(1px);
  -moz-transform: translateY(1px);
  -o-transform: translateY(1px);
  -ms-transform: translateY(1px);
}

.cf-login-icon {
  width: 18px;
  height: 18px;
  opacity: 0.7;
}

.cf-dropdown-arrow {
  width: 12px;
  height: 12px;
  opacity: 0.6;
  transition: transform 0.2s ease;
}

.cf-dropdown[aria-expanded="true"] .cf-dropdown-arrow {
  transform: rotate(180deg);
}

.cf-dropdown-content {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 200px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1), 0 4px 6px rgba(0, 0, 0, 0.05);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 50;
  overflow: hidden;
  padding: 8px 0;
}

.cf-dropdown[aria-expanded="true"] .cf-dropdown-content {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.cf-dropdown-content a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  color: #374151;
  text-decoration: none;
  font-weight: 500;
  font-size: 0.9rem;
  transition: all 0.15s ease;
  border: none;
  background: none;
}

.cf-dropdown-content a:hover {
  background: #f9fafb;
  color: #0066cc;
}

.cf-dropdown-content a:focus {
  outline: none;
  background: #f0f7ff;
  color: #0066cc;
}

.cf-dropdown-content a::before {
  content: "\u2192";
  opacity: 0;
  transform: translateX(-4px);
  transition: all 0.2s ease;
}

.cf-dropdown-content a:hover::before {
  opacity: 1;
  transform: translateX(0);
}

/* Dark mode dropdown */
[data-theme="dark"] .cf-dropdown-content {
  background: #1f2937;
  border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .cf-dropdown-content a {
  color: #d1d5db;
}

[data-theme="dark"] .cf-dropdown-content a:hover,
[data-theme="dark"] .cf-dropdown-content a:focus {
  background: rgba(255, 255, 255, 0.08);
  color: #4ea8ff;
}

/* Scrolled State - Cross Browser */
.cf-nav.cf-nav-scrolled {
  background: rgba(255, 255, 255, 0.98);
  background: -webkit-linear-gradient(rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.98)); /* Safari fallback */
  
  border-bottom-color: rgba(0, 0, 0, 0.12);
  
  /* Cross-browser box-shadow */
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  -moz-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

/* Dark Mode Support with Fallbacks */
.cf-nav[data-theme="dark"],
.dark-theme .cf-nav,
[data-bs-theme="dark"] .cf-nav {
  background: rgba(10, 15, 21, 0.95);
  background: -webkit-linear-gradient(rgba(10, 15, 21, 0.95), rgba(10, 15, 21, 0.95)); /* Safari fallback */
  border-bottom-color: rgba(255, 255, 255, 0.08);
}

.cf-nav[data-theme="dark"] .cf-brand-text,
.dark-theme .cf-nav .cf-brand-text,
[data-bs-theme="dark"] .cf-nav .cf-brand-text {
  color: #ffffff;
}

.cf-nav[data-theme="dark"] .cf-nav-item,
.dark-theme .cf-nav .cf-nav-item,
[data-bs-theme="dark"] .cf-nav .cf-nav-item {
  color: #d1d5db;
}

.cf-nav[data-theme="dark"] .cf-nav-item:hover,
.cf-nav[data-theme="dark"] .cf-nav-item.active,
.dark-theme .cf-nav .cf-nav-item:hover,
.dark-theme .cf-nav .cf-nav-item.active,
[data-bs-theme="dark"] .cf-nav .cf-nav-item:hover,
[data-bs-theme="dark"] .cf-nav .cf-nav-item.active {
  color: #4ea8ff;
  background: rgba(78, 168, 255, 0.08);
}

/* Internet Explorer Compatibility */
.cf-nav {
  /* IE9+ fallback background */
  background: #fafafa;
  /* Progressive enhancement */
  background: rgba(255, 255, 255, 0.95);
}

/* Fix for older Android browsers */
.cf-nav-item {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}

.cf-login-btn {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
  .cf-nav-item,
  .cf-nav-item::before,
  .cf-login-btn,
  .cf-dropdown-content,
  .cf-dropdown-arrow {
    transition: none !important;
    -webkit-transition: none !important;
    -moz-transition: none !important;
    -o-transition: none !important;
  }
  
  .cf-nav-item:hover {
    transform: none !important;
    -webkit-transform: none !important;
    -moz-transform: none !important;
    -o-transform: none !important;
    -ms-transform: none !important;
  }
}

/* Focus indicators for better accessibility */
.cf-nav-item:focus-visible,
.cf-login-btn:focus-visible {
  outline: 2px solid #0066cc;
  outline-offset: 2px;
}

/* Fallback for browsers without :focus-visible */
.cf-nav-item:focus:not(:focus-visible),
.cf-login-btn:focus:not(:focus-visible) {
  outline: none;
}

/* Legacy browser focus */
.cf-nav-item:focus,
.cf-login-btn:focus {
  outline: 2px solid #0066cc;
  outline-offset: 2px;
}

/* Mobile Navigation - Cleaned Up */

.mobile-nav-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.95);
  backdrop-filter: blur(10px);
  z-index: 1000;
  padding-top: 72px;
}

.mobile-nav-overlay.active {
  display: block;
}

.mobile-nav-content {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 2rem 1.5rem 1.5rem;
}

.mobile-nav-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: transparent;
  border: none;
  color: #ffffff;
  font-size: 2rem;
  line-height: 1;
  padding: 6px 10px;
  cursor: pointer;
  z-index: 1001;
  border-radius: 6px;
}
.mobile-nav-close:focus {
  outline: 2px solid rgba(255,255,255,0.9);
  outline-offset: 2px;
}

@media (min-width: 769px) {
  .mobile-nav-close { display: none; }
}

.mobile-nav-links {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.mobile-nav-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.5rem;
  color: var(--text);
  text-decoration: none;
  font-size: 1.125rem;
  font-weight: 500;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: all 0.3s ease;
}

.mobile-nav-item:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--brand);
  transform: translateX(4px);
}

.mobile-nav-item svg {
  color: var(--brand);
  flex-shrink: 0;
}

.mobile-nav-secondary {
  opacity: 0.8;
  font-size: 1rem;
  margin-top: 1rem;
}

.mobile-login-section {
  margin-top: auto;
  padding-top: 2rem;
}

.mobile-login-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  margin-bottom: 1.5rem;
}

.mobile-login-buttons {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.mobile-login-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 1rem 1.5rem;
  text-decoration: none;
  font-weight: 600;
  border-radius: 12px;
  transition: all 0.3s ease;
  font-size: 1rem;
}

.mobile-login-primary {
  background: var(--brand);
  color: white;
  border: 2px solid var(--brand);
}

.mobile-login-primary:hover {
  background: var(--brand-hover);
  border-color: var(--brand-hover);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 102, 204, 0.3);
}

.mobile-login-secondary {
  background: transparent;
  color: var(--text);
  border: 2px solid rgba(255, 255, 255, 0.2);
}

.mobile-login-secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.4);
  transform: translateY(-2px);
}

.mobile-login-btn svg {
  flex-shrink: 0;
}

/* Enhanced Mobile Responsiveness */
@media (max-width: 1024px) {
  .cf-nav-container {
    padding: 0 20px;
  }
  
  .cf-nav-inner {
    gap: 24px;
  }
  
  .cf-nav-item {
    padding: 10px 14px;
  }
}

@media (max-width: 768px) {
  .cf-nav-container {
    padding: 0 16px;
  }
  
  .cf-nav-inner {
    height: 60px;
    min-height: 60px;
    gap: 16px;
  }
  
  .cf-brand-text {
    font-size: 1rem;
  }
  
  /* Hide desktop navigation on mobile - handled by JavaScript */
  .cf-nav-main {
    display: none !important;
  }
}
  /* Ensure mobile overlay is properly styled for iOS */
  .mobile-nav-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.95);
    backdrop-filter: blur(10px);
    z-index: 1000;
    padding-top: 72px;
    transform: translateX(100%);
    transition: transform 0.3s ease;
    /* iOS specific */
    -webkit-overflow-scrolling: touch;
    overflow-y: auto;
  }
  
  .mobile-nav-overlay.active {
    transform: translateX(0);
  }
  
  /* Make nav items more touch-friendly on iOS */
  .mobile-nav-item {
    -webkit-tap-highlight-color: rgba(0, 102, 204, 0.3);
    touch-action: manipulation;
  }
}

@media (max-width: 480px) {
  .cf-nav-container {
    padding: 0 12px;
  }
  
  .cf-nav-inner {
    gap: 12px;
  }
}

/* High DPI Display Support */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .cf-brand-logo {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
  }
}

/* Print Styles */
@media print {
  .cf-nav {
    position: static;
    background: white;
    border-bottom: 1px solid #000;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  
  .cf-nav-item:hover::before {
    display: none;
  }
}

/* Buttons */
.btn{
  padding:12px 20px;min-height:44px;border:1px solid var(--border);border-radius:8px;
  background:var(--card-bg);color:var(--text);cursor:pointer;font-weight:500;
  transition:all 0.2s ease;box-shadow:0 1px 3px var(--shadow);
}
.btn,.btn-lg,.btn-outline,.btn-ghost,.btn-cta,.chip,.logo-chip{position:relative;overflow:hidden}
.btn:hover{box-shadow:0 2px 8px var(--hover-shadow);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-lg{
  padding:16px 24px;min-height:48px;border-radius:10px;
  background:linear-gradient(135deg,var(--brand),var(--secondary));
  color:#ffffff;font-weight:600;border:0;font-size:1.05rem;
  box-shadow:0 4px 12px rgba(14,129,232,0.3);
}
.btn-lg:hover{
  box-shadow:0 6px 20px rgba(14,129,232,0.4);
  transform:translateY(-2px);
}
.btn-cta{
  padding:12px 20px;min-height:44px;border-radius:8px;border:0;cursor:pointer;
  background:linear-gradient(135deg,var(--brand),var(--secondary));
  color:#ffffff;font-weight:600;
  box-shadow:0 3px 10px rgba(14,129,232,0.25);
  transition:all 0.2s ease;
}
.btn-cta-strong{filter:saturate(1.1) brightness(1.05)}
.btn-cta:hover{
  box-shadow:0 4px 16px rgba(14,129,232,0.35);
  transform:translateY(-1px);
} 
.btn-cta:active{transform:translateY(0)}
.btn-cta:focus-visible{outline:2px solid var(--secondary);outline-offset:2px}
.btn:focus-visible,.btn-lg:focus-visible,.btn-outline:focus-visible,.btn-ghost:focus-visible{
  outline:2px solid var(--brand);outline-offset:2px;
}
.btn-outline{
  padding:12px 20px;border-radius:8px;border:2px solid var(--brand);
  background:transparent;color:var(--brand);cursor:pointer;font-weight:500;
  transition:all 0.2s ease;
}
.btn-outline:hover{background:var(--brand);color:#ffffff}
.btn-ghost{
  padding:10px 16px;border-radius:8px;border:1px solid var(--border);
  background:var(--panel);color:var(--text);cursor:pointer;font-weight:500;
  transition:all 0.2s ease;
}
.btn-ghost:hover{background:var(--accent);color:var(--brand)}
.btn-ghost.small{padding:8px 12px;min-height:36px;border-radius:6px;font-size:0.875rem}

/* Links */
.link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--brand);
  font-weight: 500;
  text-decoration: none;
  transition: all 0.2s ease;
}

.link:hover {
  color: var(--brand-2);
  transform: translateX(4px);
  text-decoration: underline;
}

.link:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

/* Ripple effect for clickable elements */
.ripple{
  position:absolute; left:0; top:0; width:10px; height:10px; border-radius:999px;
  transform:translate(-50%,-50%); pointer-events:none; background:currentColor; opacity:.15;
  animation:ripple 600ms ease-out;
}
@keyframes ripple{to{opacity:0; transform:translate(-50%,-50%) scale(18)}}


/* Dropdown */
.dropdown{position:relative;display:inline-block;z-index:120}
.dropdown-content{
  position:absolute;right:0;top:100%;
  background:rgba(16,22,31,.92);backdrop-filter:blur(6px);
  border:1px solid rgba(137,209,255,.18);border-radius:10px;
  min-width:220px;z-index:120;padding:6px;
  pointer-events:none;
  opacity:0;transform:translateY(4px);
  transition:opacity .14s ease, transform .14s ease, visibility .14s ease;
  visibility:hidden;
}
.dropdown-content::before{content:"";position:absolute;left:0;right:0;top:-8px;height:8px}
.dropdown-content a{
  display:block;padding:10px 12px;border-radius:8px;
  color:var(--text);transition:background .12s ease;
  text-decoration:none;
}
.dropdown-content a:focus-visible{outline:2px solid #89d1ff;outline-offset:2px}
.dropdown-content a:hover{background:rgba(255,255,255,.05)}
.dropdown.open .dropdown-content{
  pointer-events:auto;
  opacity:1;transform:translateY(0);
  visibility:visible;
}
.sep-line{height:1px;background:var(--border);margin:6px 0}

/* Cards & layout */
.card{
  background:var(--card-bg);border:1px solid var(--border);border-radius:12px;
  padding:32px;box-shadow:0 2px 8px var(--shadow);
  transition:all 0.3s ease;
}
.card p{max-width:70ch}
.card{position:relative}
.card::before{
  content:""; position:absolute; inset:-1px; border-radius:12px; padding:1px;
  background:conic-gradient(from 180deg at 50% 50%, var(--brand), var(--brand-2), var(--brand));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .3s ease;
  pointer-events:none; z-index:0;
}
.card:hover::before{opacity:.75}
.card:hover{
  box-shadow:0 8px 25px var(--hover-shadow);
  border-color:var(--brand);
  transform:translateY(-2px);
}
.card h2{position:relative;margin-top:0;letter-spacing:-0.01em;color:var(--text);font-weight:600}
.card h2::after{
  content:"";position:absolute;left:0;bottom:-12px;width:48px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--brand),var(--brand-2));opacity:0.8;
}
.img-cover{width:100%;height:100%;object-fit:cover}
.radius-xl{border-radius:16px}

/* Simple reveal-on-scroll: removed duplicate - using unified version */

/* Below-the-fold rendering optimization */
.defer-vis{content-visibility:auto;contain-intrinsic-size: 700px}

/* Pro video */
.pro-video{margin-top:28px}
.video-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.video-wrap{position:relative;border:1px solid var(--border);border-radius:16px;overflow:hidden;background:#0c121a}
.video-wrap::before{content:"";display:block;padding-top:56.25%}
.video-el{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.video-toggle{position:absolute;right:10px;bottom:10px}

/* Hero Enhanced */
.hero-prime{
  /* Flexbox fallback for browsers without grid support */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top:32px;
  position:relative;overflow:hidden;padding:48px 40px;
  /* Fallback background without CSS variables */
  background:linear-gradient(135deg, rgba(59,130,246,0.05) 0%, transparent 50%);
  background:linear-gradient(135deg, var(--accent) 0%, transparent 50%),
             linear-gradient(225deg, rgba(137,209,255,0.05) 0%, transparent 70%);
  /* Fallback border */
  border:1px solid #e2e8f0;
  border:1px solid var(--border);
  border-radius:16px;
  /* Fallback for backdrop-filter */
  background-color: rgba(255,255,255,0.95);
}

/* Modern browsers with CSS Grid support */
@supports (display: grid) {
  .hero-prime{
    display:grid;
    grid-template-columns:1.1fr 0.9fr;
    gap:48px;
    -webkit-box-orient: unset;
    -webkit-box-direction: unset;
    -ms-flex-direction: unset;
    flex-direction: unset;
    -ms-flex-wrap: unset;
    flex-wrap: unset;
  }
}

/* Backdrop filter for supported browsers */
@supports (backdrop-filter: blur(20px)) {
  .hero-prime{
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    background-color: transparent;
  }
}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg, rgba(137,209,255,0.1), rgba(102,179,255,0.1));
  border:1px solid rgba(137,209,255,0.2);
  border-radius:20px;padding:6px 12px;margin-bottom:16px;
  font-size:0.85rem;font-weight:500;color:var(--brand);
}

.badge-icon{
  animation:pulse-glow 2s infinite;
}

@keyframes pulse-glow{
  0%, 100% { transform:scale(1); }
  50% { transform:scale(1.1); }
}

.hero-content h1{
  font-size:2.8rem;line-height:1.1;letter-spacing:-0.02em;margin:0 0 16px;
  font-weight:700;color:var(--text);
  background:linear-gradient(135deg, var(--text) 0%, var(--brand) 100%);
  -webkit-background-clip:text;background-clip:text;
  animation:text-shimmer 3s infinite;
}

@keyframes text-shimmer{
  0%, 100% { background-position:0% 50%; }
  50% { background-position:100% 50%; }
}

.grad-text-enhanced{
  background:linear-gradient(135deg,var(--brand) 0%, var(--brand-2) 50%, #66b3ff 100%);
  background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradient-shift 4s ease-in-out infinite;
  position:relative;
}

@keyframes gradient-shift{
  0%, 100% { background-position:0% 50%; }
  50% { background-position:100% 50%; }
}

.btn-gradient{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);
  border:none;transition:all 0.3s ease;
}

.btn-gradient:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 25px rgba(137,209,255,0.3);
}

.btn-shimmer{
  position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation:shimmer 2s infinite;
}

@keyframes shimmer{
  0% { left:-100%; }
  100% { left:100%; }
}

.btn-content{
  position:relative;z-index:2;
}

.btn-icon{
  margin-left:8px;animation:sparkle 1.5s infinite;
}

@keyframes sparkle{
  0%, 100% { opacity:1; transform:scale(1); }
  50% { opacity:0.7; transform:scale(1.2); }
}

.link-enhanced{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--brand);font-weight:500;text-decoration:none;
  transition:all 0.3s ease;
}

.link-enhanced:hover{
  color:var(--brand-2);
  transform:translateX(4px);
}

.arrow-animated{
  transition:transform 0.3s ease;
}

.link-enhanced:hover .arrow-animated{
  transform:translateX(4px);
}

.hero-points li{
  position:relative;list-style:none;margin:12px 0;padding-left:40px;
  font-weight:500;color:var(--text);
  transition:transform 0.2s ease;
}

.hero-points li:hover{
  transform:translateX(4px);
}

.point-icon{
  position:absolute;left:0;top:0;
  font-size:1.2rem;animation:bounce-icon 2s infinite;
  animation-delay:calc(var(--i, 0) * 0.2s);
}

.hero-points li:nth-child(1) .point-icon { animation-delay:0s; }
.hero-points li:nth-child(2) .point-icon { animation-delay:0.2s; }
.hero-points li:nth-child(3) .point-icon { animation-delay:0.4s; }

@keyframes bounce-icon{
  0%, 100% { transform:translateY(0); }
  50% { transform:translateY(-2px); }
}

.hero-stats{
  display:flex;gap:24px;margin-top:32px;
  padding:20px 0;border-top:1px solid var(--border);
}

.stat-item{
  text-align:center;
}

.stat-number{
  display:block;font-size:1.8rem;font-weight:700;
  color:var(--brand);margin-bottom:4px;
}

.stat-label{
  font-size:0.9rem;color:var(--muted);text-transform:uppercase;
  letter-spacing:0.5px;
}

.media-wrapper{
  position:relative;
}

.floating{
  animation:float 6s ease-in-out infinite;
}

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

.media-overlay{
  position:absolute;bottom:20px;right:20px;
}

.security-badge{
  display:flex;align-items:center;gap:8px;
  background:rgba(16,22,31,0.9);backdrop-filter:blur(10px);
  border:1px solid rgba(137,209,255,0.3);
  border-radius:20px;padding:8px 16px;
  color:var(--text);font-size:0.85rem;font-weight:500;
}

.badge-pulse{
  width:8px;height:8px;border-radius:50%;
  background:var(--brand);
  animation:pulse 2s infinite;
}

@keyframes pulse{
  0% { transform:scale(0.8); opacity:1; }
  50% { transform:scale(1.2); opacity:0.7; }
  100% { transform:scale(0.8); opacity:1; }
}

.hero-glow-enhanced{
  position:absolute;top:50%;left:50%;
  width:120%;height:120%;
  background:radial-gradient(circle, var(--brand) 0%, transparent 70%);
  opacity:0.1;transform:translate(-50%, -50%);
  animation:glow-pulse 4s ease-in-out infinite;
  z-index:-1;
}

@keyframes glow-pulse{
  0%, 100% { opacity:0.1; transform:translate(-50%, -50%) scale(1); }
  50% { opacity:0.2; transform:translate(-50%, -50%) scale(1.1); }
}

.hero-particles{
  position:absolute;top:0;left:0;width:100%;height:100%;
  pointer-events:none;z-index:1;
}

.particle{
  position:absolute;width:4px;height:4px;
  background:var(--brand);border-radius:50%;
  opacity:0.6;
  animation:float-particle 8s infinite linear;
}

.particle:nth-child(1) { left:10%; animation-delay:0s; }
.particle:nth-child(2) { left:30%; animation-delay:1s; }
.particle:nth-child(3) { left:50%; animation-delay:2s; }
.particle:nth-child(4) { left:70%; animation-delay:3s; }
.particle:nth-child(5) { left:90%; animation-delay:4s; }

@keyframes float-particle{
  0% { transform:translateY(100vh) rotate(0deg); opacity:0; }
  10% { opacity:0.6; }
  90% { opacity:0.6; }
  100% { transform:translateY(-20px) rotate(360deg); opacity:0; }
}
.hero-points li::before{
  content:"\u2713";position:absolute;left:0;top:0;
  width:20px;height:20px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#ffffff;font-size:12px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.hero-media{aspect-ratio:16/10;overflow:hidden;border-radius:12px;box-shadow:0 8px 32px var(--hover-shadow)}
.hero-glow{
  position:absolute;inset:-20% -10% auto -10%;height:200px;
  background:radial-gradient(60% 60% at 30% 30%, var(--brand), transparent 70%);
  pointer-events:none;filter:blur(40px);opacity:0.1;animation:floatGlow 10s ease-in-out infinite;
}
[data-theme="dark"] .hero-glow{opacity:0.15}
@keyframes floatGlow{0%{transform:translateY(0)}50%{transform:translateY(8px)}100%{transform:translateY(0)}}

/* Hero Split Layout */
.hero-split {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 64px;
  align-items: center;
  margin: 48px 0 64px;
  padding: 80px 48px;
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.05) 0%, transparent 50%),
              linear-gradient(225deg, rgba(137, 209, 255, 0.03) 0%, transparent 70%);
  border-radius: 24px;
  border: 1px solid var(--border);
}

.hero-split::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 50%, rgba(59, 130, 246, 0.1) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}

.hero-split-content {
  position: relative;
  z-index: 1;
}

.hero-split-content h1 {
  font-size: clamp(2.5rem, 5vw, 3.5rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 24px;
  font-weight: 700;
  color: var(--text);
}

.hero-split-content .lead-xl {
  font-size: clamp(1.15rem, 2vw, 1.35rem);
  line-height: 1.6;
  color: var(--muted);
  margin-bottom: 32px;
  max-width: 600px;
}

.hero-ctas {
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 40px;
}

.hero-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 24px;
  padding-top: 32px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.hero-stats li {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.stat-num {
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--brand);
  line-height: 1;
}

.stat-label {
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.4;
}

.hero-split-visual {
  position: relative;
  z-index: 1;
}

.hero-figure {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.figure-img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 20px;
  transform: scale(1);
  transition: transform 0.6s ease;
}

.hero-figure:hover .figure-img {
  transform: scale(1.05);
}

.figure-glow {
  position: absolute;
  inset: -40%;
  background: radial-gradient(circle, var(--brand) 0%, transparent 70%);
  opacity: 0.15;
  z-index: -1;
  animation: pulse-glow-hero 4s ease-in-out infinite;
}

@keyframes pulse-glow-hero {
  0%, 100% { opacity: 0.15; transform: scale(1); }
  50% { opacity: 0.25; transform: scale(1.1); }
}

.figure-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(10, 14, 39, 0.4) 100%);
  pointer-events: none;
}

.visual-accent {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, var(--brand) 0%, transparent 70%);
  opacity: 0.1;
  pointer-events: none;
  z-index: 0;
}

.visual-accent-1 {
  width: 300px;
  height: 300px;
  top: 10%;
  right: -10%;
  animation: float-accent 8s ease-in-out infinite;
}

.visual-accent-2 {
  width: 200px;
  height: 200px;
  bottom: 20%;
  right: 10%;
  animation: float-accent 6s ease-in-out infinite reverse;
}

@keyframes float-accent {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(-20px, -20px); }
}

/* Responsive Hero Split */
@media (max-width: 1024px) {
  .hero-split {
    grid-template-columns: 1fr;
    gap: 48px;
    padding: 60px 40px;
  }
  
  .hero-split-content h1 {
    font-size: clamp(2rem, 4vw, 2.75rem);
  }
}

@media (max-width: 768px) {
  .hero-split {
    padding: 48px 24px;
    gap: 36px;
    margin: 32px 0 48px;
  }
  
  .hero-ctas {
    flex-direction: column;
    align-items: stretch;
  }
  
  .hero-ctas .btn-lg,
  .hero-ctas .link {
    width: 100%;
    text-align: center;
  }
  
  .hero-stats {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 20px;
  }
  
  .stat-num {
    font-size: 1.75rem;
  }
}

/* Trust strip enhanced */
.enhanced-trust{
  background:linear-gradient(135deg, rgba(137,209,255,0.02) 0%, transparent 100%);
  border:1px solid rgba(137,209,255,0.1);
  position:relative;overflow:hidden;margin-top:24px;
}

.trust-header{
  text-align:center;margin-bottom:32px;
}

.trust-icon{
  font-size:2.5rem;margin-bottom:12px;
  animation:trophy-glow 3s infinite;
}

@keyframes trophy-glow{
  0%, 100% { transform:scale(1); filter:drop-shadow(0 0 10px rgba(255,215,0,0.3)); }
  50% { transform:scale(1.05); filter:drop-shadow(0 0 20px rgba(255,215,0,0.6)); }
}

.trust-title{
  font-size:1.8rem;font-weight:700;margin:0 0 8px;
  background:linear-gradient(135deg, var(--text), var(--brand));
  -webkit-background-clip:text;background-clip:text;
}

.trust-subtitle{
  color:var(--muted);font-size:1rem;margin:0;
}

.trust{margin-top:24px}
.trust-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap;justify-content:center;margin-bottom:24px}
.trust-label{color:var(--muted);font-weight:500;font-size:0.875rem}

.logo-chip{
  border:1px solid var(--border);border-radius:24px;padding:8px 14px;
  background:var(--panel);font-size:0.875rem;font-weight:500;
  transition:all 0.2s ease;
}

.logo-chip.premium{
  background:linear-gradient(135deg, var(--accent), rgba(137,209,255,0.1));
  border:1px solid rgba(137,209,255,0.3);
  color:var(--brand);font-size:0.8rem;font-weight:600;
  padding:8px 16px;border-radius:20px;
  transition:all 0.3s ease;
  position:relative;overflow:hidden;
}

.logo-chip.premium::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;
}

.logo-chip.premium:hover{
  transform:translateY(-2px);
  box-shadow:0 5px 15px rgba(137,209,255,0.3);
  border-color:var(--brand);
}

.logo-chip.premium:hover::before{
  left:100%;
}

.logo-chip:hover{background:var(--accent);border-color:var(--brand)}

.logo-reel{display:grid;grid-template-columns:repeat(auto-fit, minmax(120px, 1fr));gap:16px;margin-top:16px}

.logo-reel.enhanced{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(120px, 1fr));
  gap:16px;margin:24px 0;
}

.logo-item{
  display:grid;place-items:center;border:1px solid var(--border);border-radius:8px;
  height:64px;color:var(--muted);background:var(--panel);font-weight:600;
  transition:all 0.2s ease;font-size:0.875rem;filter:grayscale(100%) opacity(.9);
}

.logo-item.premium{
  position:relative;
  background:linear-gradient(135deg, var(--card-bg), rgba(137,209,255,0.05));
  border:1px solid rgba(137,209,255,0.2);
  border-radius:12px;padding:20px;text-align:center;height:auto;
  transition:all 0.3s ease;
  cursor:pointer;overflow:hidden;filter:none;
}

.logo-item.premium:hover{
  transform:translateY(-4px);
  border-color:var(--brand);
  box-shadow:0 8px 25px rgba(137,209,255,0.2);
}

.logo-text{
  font-weight:700;font-size:1.1rem;color:var(--text);
  position:relative;z-index:2;
}

.logo-glow{
  position:absolute;top:50%;left:50%;
  width:60%;height:60%;border-radius:50%;
  background:radial-gradient(circle, var(--brand) 0%, transparent 70%);
  opacity:0;transform:translate(-50%, -50%);
  transition:opacity 0.3s ease;
}

.logo-item.premium:hover .logo-glow{
  opacity:0.1;
}

.trust-metrics{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
  gap:24px;margin-top:32px;
  padding:24px 0;border-top:1px solid var(--border);
}

.metric{
  text-align:center;
}

.metric-value{
  font-size:2rem;font-weight:700;
  background:linear-gradient(135deg, var(--brand), var(--brand-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:4px;display:block;
}

.metric-label{
  font-size:0.9rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:0.5px;
}

.logo-item:hover{
  border-color:var(--brand);color:var(--brand);
  box-shadow:0 2px 8px var(--shadow);filter:none;
}

/* Visual strip */
.visual-strip{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:32px;margin:48px 0}
.list{padding-left:0;margin:16px 0}
.list li{
  position:relative;list-style:none;margin:12px 0;padding-left:28px;
  font-weight:400;color:var(--text);line-height:1.6;
}
.list li::before{
  content:"\u2713";position:absolute;left:0;top:2px;
  width:16px;height:16px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#ffffff;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
/* Optional SVG bullet variant */
.svg-bullets{padding-left:0;margin:16px 0}
.svg-bullets li{position:relative;list-style:none;margin:12px 0;padding-left:30px;line-height:1.6}
.svg-bullets .b{position:absolute;left:0;top:4px;width:16px;height:16px;color:var(--brand)}
.svg-bullets .b svg{display:block;width:100%;height:100%}
.media-card{display:grid;gap:16px;align-items:center}
.media-card .img-cover{border-radius:8px}
.media-copy h3{margin:0 0 8px;font-weight:600}

/* Bento Grid - Modern Card Layout */
.bento-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:24px;
  margin:64px 0;
  padding:0 24px;
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
}
@media(min-width:768px){
  .bento-grid{
    grid-template-columns:repeat(3, 1fr);
    gap:32px;
  }
}
.bento-item{
  position:relative;
  overflow:hidden;
  transition:transform 0.3s ease, box-shadow 0.3s ease;
}
.bento-item:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 40px var(--hover-shadow);
}
.bento-item.bento-large{
  grid-column:span 2;
  grid-row:span 2;
  min-height:400px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:48px;
}
.bento-item.bento-wide{
  grid-column:span 2;
  min-height:200px;
}
.bento-item.bento-tall{
  grid-row:span 2;
  min-height:400px;
}
.bento-content{
  position:relative;
  z-index:2;
  padding:24px;
}
.bento-item.bento-large .bento-content{
  padding:0;
}
.bento-bg{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
}
.bento-icon{
  display:inline-block;
  font-size:32px;
  line-height:1;
}
.stat-large{
  font-size:3rem;
  font-weight:800;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  line-height:1;
  margin-bottom:8px;
}
@media(max-width:767px){
  .bento-grid{
    grid-template-columns:1fr;
  }
  .bento-item.bento-large,
  .bento-item.bento-wide,
  .bento-item.bento-tall{
    grid-column:span 1;
    grid-row:span 1;
    min-height:280px;
  }
  .bento-item.bento-large{
    padding:32px;
  }
}

/* Process/Wins */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:14px 0 20px;padding:0;list-style:none}
.steps li{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:14px;padding:12px}
.wins-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.win{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:14px;padding:12px}

/* Metrics */
.metrics{margin-top:40px}
.metric-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:20px}
.metric{
  background:var(--card-bg);border:1px solid var(--border);border-radius:12px;
  padding:24px;text-align:center;
  box-shadow:0 2px 8px var(--shadow);
  transition:all 0.2s ease;
}
.metric:hover{
  box-shadow:0 4px 16px var(--hover-shadow);
  transform:translateY(-2px);
}
.m-num{
  font-size:2rem;font-weight:700;color:var(--brand);
  display:block;margin-bottom:8px;
}
.m-label{color:var(--muted);font-weight:500;font-size:0.875rem}

/* Values (About) */
.values{margin-top:20px}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.value{border:1px solid var(--border);border-radius:14px;padding:16px;background:rgba(255,255,255,.02);text-align:left}
.value h3{margin:8px 0 6px;position:relative}
.value h3::after{content:"";display:block;width:42px;height:3px;border-radius:3px;margin-top:6px;background:linear-gradient(90deg,var(--brand),var(--brand-2))}
.v-icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;color:var(--brand-2)}
.v-icon svg{width:28px;height:28px;display:block}

/* Small heading icons */
.h-icon{display:inline-flex;width:20px;height:20px;vertical-align:-3px;margin-right:8px;color:var(--brand-2)}
.h-icon svg{width:20px;height:20px;display:block}

/* Timeline (About) */
.timeline{margin-top:20px}
.timeline-list{list-style:none;margin:10px 0 0;padding:0;display:grid;gap:10px}
.timeline-list li{position:relative;padding-left:22px;border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:rgba(255,255,255,.02)}
.timeline-list li::before{content:"";position:absolute;left:10px;top:16px;width:6px;height:6px;border-radius:50%;background:var(--brand)}
.timeline{position:relative}
.timeline::after{content:"";position:absolute;inset:0 0 auto 0;height:140px;pointer-events:none;opacity:.12;background:radial-gradient(circle at 20% 40%, #4ea8ff 0%, transparent 60%), radial-gradient(circle at 80% 20%, #2b7bd4 0%, transparent 60%)}

/* Services */
.svc-hero{
  position:relative;
  background:linear-gradient(135deg, var(--accent) 0%, var(--panel) 100%);
  border:1px solid var(--border);border-radius:12px;
  padding:40px;margin-bottom:32px;
}
.svc-hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:0.05;
  background-image:radial-gradient(var(--brand) 1px, transparent 1px);
  background-size:24px 24px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,0.8), rgba(0,0,0,0));
}
.svc-title{margin:0 0 12px;font-size:1.875rem;font-weight:600;letter-spacing:-0.01em}
.chip-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.chip{
  border:1px solid var(--border);border-radius:24px;padding:8px 16px;
  color:var(--brand);background:var(--panel);
  transition:all 0.2s ease;font-weight:500;font-size:0.875rem;
}
.chip:active{transform:translateY(1px)}
.chip:hover{background:var(--accent);border-color:var(--brand)}
.chip.on{
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#ffffff;border-color:transparent;font-weight:600;
}
.rel-label{color:var(--brand-2);font-weight:700}
.tabs{margin-top:18px}
.tablist{display:flex;gap:8px;flex-wrap:wrap}
.tab[role="tab"]{
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
  color:var(--text);
  border-radius:999px;
  padding:10px 16px;
  cursor:pointer;
  transition: all 0.2s ease;
  font-weight: 500;
  user-select: none;
}
.tab[role="tab"]:hover {
  background: rgba(255,255,255,.08);
  border-color: var(--brand);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0,102,204,0.15);
}
.tab[aria-selected="true"]{
  background:linear-gradient(180deg,var(--brand),#2b7bd4);
  color:#001428;
  border-color:transparent;
  box-shadow: 0 2px 12px rgba(0,102,204,0.3);
  font-weight: 600;
}
.tab[aria-selected="true"]:hover {
  transform: none;
  box-shadow: 0 3px 15px rgba(0,102,204,0.4);
}
.tabpanel{margin-top:12px;border:1px solid var(--border);border-radius:14px;padding:20px;background:rgba(255,255,255,.02)}
.tabpanel .btn{display:inline-flex;align-items:center;gap:8px;margin-top:12px}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:8px}
.svc-head{display:flex;gap:12px;align-items:flex-start}
.svc-icon{line-height:1;color:var(--brand-2)}
.svc-icon svg{width:24px;height:24px;display:block}
.svc-emoji{font-size:1.6rem}
.svc-body{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:10px}
.tick{list-style:none;margin:8px 0 0;padding:0}
.tick li{display:flex;gap:8px;align-items:flex-start}
.check{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:999px;background:rgba(74,222,128,.16);color:var(--success);font-weight:700;font-size:.8rem;line-height:1;margin-top:2px}
.plans{margin-top:28px}
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:12px}
.plan{position:relative;padding-top:18px;transition:transform .12s ease}
.plan:hover{transform:translateY(-2px)}
.plan-pop{background:linear-gradient(180deg,rgba(78,168,255,.15),rgba(0,0,0,0));border-color:#2b7bd4}
.ribbon{position:absolute;top:10px;right:-6px;background:#2b7bd4;color:#001428;padding:6px 10px;border-radius:10px 0 0 10px;font-weight:700}
.plan-name{margin:0 0 6px}
.plan-cta{margin-top:10px;display:inline-block}

/* Case studies */
.case-studies{margin-top:24px;position:relative}
.case-studies::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.08;border-radius:inherit;
  background-image:radial-gradient(rgba(78,168,255,.5) 1px, transparent 1.2px);
  background-size:18px 18px;mask-image:linear-gradient(to bottom, rgba(0,0,0,.7), rgba(0,0,0,0.1));}
.case-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.case{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;align-items:stretch}
.case-media{border:1px solid var(--border);border-radius:12px;overflow:hidden}
.case-copy h3{margin-top:0}

/* Testimonial */
.testimonial {
  text-align: center;
  padding: 48px 32px;
  max-width: 900px;
  margin: 64px auto;
}

.testimonial blockquote {
  font-size: clamp(1.25rem, 2vw, 1.5rem);
  line-height: 1.6;
  font-weight: 500;
  color: var(--text);
  margin: 0 0 24px;
  font-style: italic;
  position: relative;
}

.testimonial blockquote::before {
  content: "\201C";
  position: absolute;
  left: -32px;
  top: -20px;
  font-size: 4rem;
  color: var(--brand);
  opacity: 0.3;
  font-family: Georgia, serif;
}

.testimonial .sig {
  font-size: 1rem;
  color: var(--muted);
  font-weight: 500;
}

/* Final CTA */
.final-cta {
  text-align: center;
  padding: 64px 48px;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.05) 0%, transparent 50%);
}

.final-cta h2 {
  font-size: clamp(2rem, 3vw, 2.5rem);
  margin-bottom: 16px;
}

.final-cta .lead {
  font-size: 1.15rem;
  color: var(--muted);
  margin-bottom: 32px;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.final-cta .cta-row {
  margin-bottom: 24px;
}

.final-cta .muted.small {
  font-size: 0.9rem;
  opacity: 0.7;
}

/* Contact */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:28px}
.contact-right{position:relative;z-index:5}
.contact-right .card{position:relative}
.contact-right .card input,
.contact-right .card textarea,
.contact-right .card select,
.contact-right .card button{position:relative;z-index:2;pointer-events:auto}
.mapish{position:relative;z-index:0}
.contact-right .form, .contact-right .form *{pointer-events:auto}
.contact-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0}
.badge{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:12px;padding:10px}
.badge .b-title{font-weight:700}
.badge .b-desc{color:var(--muted);font-size:.95rem}
.panel-lite{margin-top:10px;border:1px dashed var(--border);border-radius:12px;padding:12px}
.list{margin:0;padding-left:18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}
.brand-row{display:flex;align-items:center;gap:8px;margin:6px 0}
.logo-cisa{height:22px;width:auto}
 @media (max-width:600px){ .logo-cisa{height:20px} }

/* Contact page decorative map: non-interactive */
.mapish{margin-top:16px;pointer-events:none}
.map-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;opacity:.12}
.map-grid .dot{width:8px;height:8px;border-radius:50%;background:var(--brand)}
.map-overlay{margin-top:8px;color:var(--muted);font-weight:600}

/* Forms */
.form{display:grid;gap:16px}
.form-grid{grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.form-grid .span-2{grid-column:1 / -1}
/* Turnstile spacing */
.turnstile-host{margin:4px 0}
/* Helper text under inputs */
.help{margin-top:4px}
label{display:grid;gap:6px;font-weight:600;color:var(--text)}
input:not([type="checkbox"]):not([type="radio"]),textarea,select{
  background:var(--card-bg);color:var(--text);border:1.5px solid var(--border);
  border-radius:10px;padding:12px 14px;font-size:16px;width:100%;
  transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
  box-shadow:0 1px 2px rgba(0,0,0,.04);
}
select{min-height:44px}
input:focus,textarea:focus,select:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(14,129,232,.15), 0 1px 6px rgba(0,0,0,.05);
  background:linear-gradient(0deg, rgba(14,129,232,.03), rgba(14,129,232,.03)), var(--card-bg);
}
input::placeholder,textarea::placeholder{color:var(--muted);opacity:0.8}
.consent{display:flex;align-items:center;gap:8px}
.consent-row{display:flex;align-items:flex-start;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 12px}
.consent-row .consent{margin-top:6px;gap:10px}
.consent-row .consent input[type="checkbox"]{flex:0 0 auto;margin-top:3px}
.consent-row .consent span{display:inline-block;line-height:1.5}
@media (max-width:600px){
  .consent-row{flex-direction:row}
  .consent-row .consent span{display:block}
}

/* Password eye: white & inside field; hide built-ins */
.pw-wrap{position:relative;width:100%}
.pw-wrap input{padding-right:44px;height:44px}
input[type="password"]::-ms-reveal,input[type="password"]::-ms-clear{display:none}
input[type="password"]::-webkit-textfield-decoration-container{display:none}
.eye{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:8px;border:none;background:transparent;cursor:pointer;min-height:28px;
}
.eye svg path{fill:#ffffff}
.eye.on{outline:2px solid rgba(255,255,255,.25);outline-offset:2px}
.eye:focus-visible{outline:2px solid rgba(78,168,255,.6);outline-offset:2px}

/* About certs */
.certs{text-align:center}
.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:28px;margin-top:20px;justify-items:center;align-items:start}
.cert{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:280px}
.cert h3{margin:10px 0 6px}
.cert p{margin:0;color:var(--muted)}
.cert-logo{width:100px;height:100px;object-fit:contain;margin-bottom:12px;filter:drop-shadow(0 2px 6px rgba(0,0,0,0.3))}

/* Footer */
.footer{margin-top:44px;border-top:1px solid var(--border);background:#0a0f15}
.footer-grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;padding-top:20px;align-items:stretch}
.map-preview{display:flex;flex-direction:column;gap:10px}
.footer .map-preview{background:#0a0f15;border:none;box-shadow:none} /* Match footer background */
.map-aspect{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--border);background:#0c121a;transition:border-color .15s ease}
.map-aspect:hover{border-color:#2b7bd4}
.map-aspect::before{content:"";display:block;padding-top:38%} /* compact aspect ratio */
.map-aspect iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.map-cta{display:flex;justify-content:flex-start}
.map-open{display:inline-block}
.footer-info .brand-sm{font-weight:900}
.footer-info .brand-sm span{color:var(--brand)}
.footer-info .brand-sm .tm{font-size:.6em;vertical-align:super;margin-left:2px;opacity:.85}
.addr{margin-top:10px;font-style:normal;line-height:1.5}
.addr-line{display:flex;gap:10px;align-items:flex-start;margin:8px 0}
.addr-icon{opacity:.85}
.map-link{white-space:nowrap}

/* Thin bottom bar */
.subfooter{border-top:1px solid var(--border);background:#090e14}
.subfooter-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:12px 20px;color:var(--muted);font-size:.95rem
}
.subfooter nav{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.subfooter a{color:var(--muted)}
.subfooter a:hover{color:var(--text)}
.sep{opacity:.35}
.copy{white-space:nowrap}

/* Privacy choices (Cloudflare-like) */
.privacy-choices-inline{display:inline-flex;align-items:center;gap:8px}
.pc-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;
  background:linear-gradient(180deg,var(--brand),#2b7bd4);color:#001428;font-weight:800;font-size:.85rem;line-height:1;border:0}
.pc-badge .pc-check,.pc-badge .pc-x{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:4px;background:rgba(255,255,255,.15);color:#fff;font-size:.8rem;line-height:1}
.pc-badge .pc-split{display:inline-block;width:1px;height:14px;background:rgba(255,255,255,.4)}
.privacy-choices-inline:hover .pc-badge{filter:brightness(1.05)}

/* Floating Privacy FAB */
.privacy-fab-wrap{position:fixed;right:16px;bottom:16px;z-index:1000}
.privacy-fab{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:rgba(16,22,31,.92);backdrop-filter:blur(8px);color:#eef6ff;padding:8px 12px;cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.25), inset 0 0 0 1px rgba(255,255,255,.06);transition:filter .2s ease, background .2s ease, border-color .2s ease, color .2s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent;pointer-events:auto}
.privacy-fab:hover{filter:brightness(1.08);border-color:rgba(255,255,255,.25)}
.privacy-fab:focus-visible{outline:2px solid var(--brand-2);outline-offset:2px}
@media (max-width: 600px){ .privacy-fab{padding:8px 10px;font-size:.95rem} }

/* App header / dashboard shell */
.app-header{position:sticky;top:0;background:rgba(11,15,20,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);z-index:110}
.app-header.scrolled{background:rgba(11,15,20,.94);border-bottom-color:rgba(137,209,255,.25);box-shadow:0 8px 24px rgba(0,0,0,.25)}
.app-head-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
.app-head-right{display:flex;align-items:center;gap:10px}
.badge.role{display:inline-block;border:1px solid var(--border);border-radius:999px;padding:6px 10px;background:rgba(255,255,255,.03);color:var(--muted);font-size:.9rem}
.small-ghost{padding:8px 12px;min-height:36px}
.app-subhead{color:var(--muted);padding:0 0 10px}
.hr{border-top:1px solid var(--border);opacity:.6}
.app-shell{padding-top:16px}
.app-grid{display:grid;grid-template-columns:260px 1fr;gap:18px}
.app-sidebar{position:sticky;top:84px;height:fit-content}
.app-nav{display:flex;flex-direction:column;gap:8px}
.app-link{display:block;padding:10px 12px;border:1px solid var(--border);border-radius:10px;color:var(--text);background:rgba(255,255,255,.02);position:relative}
.app-link:focus-visible{outline:2px solid #89d1ff;outline-offset:2px}
.app-link:hover{background:rgba(255,255,255,.05)}
.app-link.active{border-color:rgba(137,209,255,.35);background:rgba(137,209,255,.06)}
.app-link.active::before{content:"";position:absolute;left:-1px;top:-1px;bottom:-1px;width:4px;border-radius:10px 0 0 10px;background:linear-gradient(180deg,#4ea8ff,#2b7bd4)}
.app-link:hover{border-color:rgba(78,168,255,.35)}
.app-content{display:grid;gap:18px}
@media (max-width:900px){ .app-grid{grid-template-columns:1fr} .app-sidebar{position:static} }

/* Cookie banner + modal (high contrast, glassy) */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:-260px;opacity:0;transform:translateY(10px);
  background:rgba(11,15,20,.86);backdrop-filter:blur(8px) saturate(140%);
  border-top:1px solid var(--border);transition:all .25s ease;z-index:20;pointer-events:none;visibility:hidden;
}
.cookie-banner.show{bottom:0;opacity:1;transform:none;pointer-events:auto;visibility:visible}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;pointer-events:auto}
.cookie-copy strong{display:block;margin-bottom:4px}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn-accept{padding:10px 16px;border-radius:12px;border:0;background:linear-gradient(180deg,var(--brand),#2b7bd4);color:#001428;font-weight:800;box-shadow:0 6px 16px rgba(78,168,255,.25);cursor:pointer}
.cookie-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1001;visibility:hidden}
.cookie-backdrop.show{opacity:1;pointer-events:auto;visibility:visible}
.cookie-modal{position:fixed;inset:0;display:grid;place-items:center;opacity:0;pointer-events:none;z-index:1002;transition:opacity .2s ease;visibility:hidden}
.cookie-modal.show{opacity:1;pointer-events:auto;visibility:visible}
.cookie-modal-card{width:min(640px,92vw)}
.cookie-row{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border);border-radius:12px;padding:12px;margin:10px 0}
.cookie-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}
.switch{position:relative;display:inline-block;width:44px;height:24px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#334155;border-radius:999px;transition:.2s}
.slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:white;border-radius:50%;transition:.2s}
.switch input:checked + .slider{background:var(--brand)}
.switch input:checked + .slider:before{transform:translateX(20px)}
.cookie-modal .chip{border:1px solid var(--border);border-radius:999px;padding:4px 8px}
.cookie-modal .chip.on{background:rgba(78,168,255,.12);color:var(--brand-2);border-color:#2b7bd4}

/* Breakpoints */
@media (max-width:1200px){ 
  .container{padding:24px 20px}
  .hero-prime{padding:40px 32px}
}
@media (max-width:1000px){
  .steps{grid-template-columns:repeat(2, 1fr)}
  .svc-grid{grid-template-columns:1fr}
  .svc-body{grid-template-columns:1fr}
  .plan-grid{grid-template-columns:1fr}
  .wins-grid{grid-template-columns:1fr}
  .metric-grid{grid-template-columns:repeat(2,1fr)}
  .case{grid-template-columns:1fr}
  .visual-strip{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:900px){
  .hero-prime{grid-template-columns:1fr;gap:40px;padding:40px 24px}
  .hero-media{aspect-ratio: 16 / 9;border-radius:12px}
  .hero-content h1{font-size:2.25rem;line-height:1.15}
  .lead-xl{font-size:1.2rem}
  .visual-strip{grid-template-columns:1fr;gap:20px}
  .footer-grid-2{grid-template-columns:1fr}
  .contact-wrap{grid-template-columns:1fr;gap:32px}
  .contact-badges{grid-template-columns:1fr 1fr}
  .subfooter-inner{flex-direction:column;align-items:flex-start;gap:16px}
  .cookie-inner{flex-direction:column;align-items:flex-start;gap:16px}
  .nav-inner{padding:0 20px}
  .card{padding:28px 24px}
  .wins-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr;gap:16px}
}
@media (max-width:600px){
  .container{padding:24px 16px}
  .hero-prime{padding:32px 20px;gap:32px}
  .hero-content h1{font-size:2rem}
  .lead-xl{font-size:1.125rem;line-height:1.6}
  .contact-badges{grid-template-columns:1fr}
  .btn,.btn-lg{width:100%}
  .metric-grid{grid-template-columns:1fr;gap:16px}
  .nav-inner{padding:0 16px;gap:8px}
  .chip-row{justify-content:center}
  .hero-ctas{justify-content:center;flex-direction:column;align-items:stretch}
  .card{padding:24px 16px}
  .hero-points li{padding-left:24px}
}

/* Hover support for dropdown on desktop as a fallback */
@media (hover:hover) and (pointer:fine){
  .dropdown:hover .dropdown-content{display:block}
}

/* Consistent vertical spacing between sections */
main.container > section + section{margin-top:24px}

/* Premium Visual Enhancements - Syntrix Brand */
:root {
  --glow-primary: 0 0 20px rgba(14,129,232,0.3);
  --glow-secondary: 0 0 30px rgba(64,206,250,0.4);
  --glow-tertiary: 0 0 25px rgba(113,203,241,0.35);
  --transition-smooth: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-bounce: all 0.6s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

/* Enhanced Page Entrance Animation */
body {
  animation: page-enter 0.8s ease-out;
}

@keyframes page-enter {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Global CTA row styling */
.cta-row {
  margin: 24px 0;
  text-align: center;
  display: block;
  clear: both;
  position: relative;
}

/* Fix final CTA section layout */
.final-cta.card {
  text-align: center;
  position: relative;
}

.final-cta.card h2 {
  margin-bottom: 16px;
}

.final-cta.card .lead {
  margin-bottom: 24px;
  display: block;
}

.final-cta.card .cta-row {
  margin: 32px 0 24px 0;
  text-align: center;
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
}

.final-cta.card .btn-lg {
  display: inline-block;
  position: static;
  margin: 0 auto;
}

.final-cta.card .muted.small {
  margin-top: 16px;
  display: block;
}

/* Premium Card Hover Effects - Syntrix Brand */
.card::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(64,206,250,0.08), transparent);
  transition: left 0.6s;
  pointer-events: none;
}

.card:hover::before {
  left: 100%;
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: var(--glow-primary), 0 10px 40px rgba(14,129,232,0.15);
  border-color: rgba(64,206,250,0.4);
}

/* Enhanced Media Cards */
.media-card {
  transition: var(--transition-bounce);
  transform-origin: center bottom;
}

.media-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: var(--glow-secondary), 0 20px 60px rgba(0,0,0,0.15);
}

.media-card img {
  transition: var(--transition-smooth);
}

.media-card:hover img {
  transform: scale(1.05);
  filter: brightness(1.1) saturate(1.1);
}

/* Enhanced Navigation */
.links a {
  position: relative;
  transition: var(--transition-smooth);
}

.links a::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  transition: width 0.3s ease;
}

.links a:hover::after {
  width: 100%;
}

.links a:hover {
  color: var(--brand);
  transform: translateY(-1px);
}

/* Unified Reveal Animations */
.reveal {
  opacity: 1;
  transform: none;
  transition: opacity 0.6s ease, transform 0.6s ease;
  transition-delay: var(--delay, 0s);
}

.reveal-init .reveal {
  opacity: 0;
  transform: translateY(20px);
}

.reveal-init .reveal.visible {
  opacity: 1;
  transform: none;
}

/* Enhanced Brand Elements */
.brand-text:hover {
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  -webkit-background-clip: text;
  background-clip: text;
}

/* Small Button for Error States */
.btn-sm {
  padding: 4px 8px;
  font-size: 0.8rem;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.05);
  color: var(--text);
  cursor: pointer;
  transition: all 0.2s ease;
  margin-left: 8px;
}

.btn-sm:hover {
  background: var(--brand);
  color: white;
  border-color: var(--brand);
}

/* Modern Careers Page */
.careers-hero {
  text-align: center;
  padding: 3rem 2rem;
  background: linear-gradient(135deg, rgba(0,102,204,0.05), rgba(43,123,212,0.05));
  border: 1px solid rgba(0,102,204,0.1);
}

.careers-hero .hero-content {
  max-width: 800px;
  margin: 0 auto;
}

.careers-hero .hero-badge.professional {
  background: var(--brand);
  color: white;
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 0.85rem;
  font-weight: 600;
  display: inline-block;
  margin-bottom: 1rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.careers-media {
  position: relative;
  margin: 2rem auto 0;
  max-width: 600px;
  border-radius: 16px;
  overflow: hidden;
}

.culture-values, .current-opportunities, .compensation-benefits, .application-process {
  margin-top: 2rem;
  padding: 2rem;
}

.values-grid.professional, .practice-grid, .benefits-grid.professional {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}

.value-card, .practice-item, .benefit-category {
  padding: 1.5rem;
  border-radius: 12px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.1);
  transition: all 0.3s ease;
}

.value-card:hover, .practice-item:hover, .benefit-category:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.05);
  border-color: var(--brand);
  box-shadow: 0 4px 15px rgba(0,102,204,0.1);
}

.value-header h3, .practice-header h4, .benefit-category h4 {
  margin: 0 0 0.75rem 0;
  color: var(--brand);
  font-size: 1.125rem;
  font-weight: 600;
}

.practice-subtitle {
  font-size: 0.85rem;
  color: var(--muted);
  margin: 0.25rem 0 0.75rem 0;
  font-style: italic;
}

.value-card p, .practice-item p, .benefit-category p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
  font-size: 0.9rem;
}

.opportunities-status.professional {
  margin: 2rem 0;
  padding: 2rem;
  background: rgba(255,255,255,0.02);
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.1);
}

.status-header h3 {
  color: var(--brand);
  margin-bottom: 1rem;
  font-size: 1.25rem;
}

.interest-areas h3 {
  text-align: center;
  margin-bottom: 1.5rem;
  color: var(--brand);
  font-size: 1.25rem;
}

.benefit-list {
  list-style: none;
  padding: 0;
  margin: 0.75rem 0 0 0;
}

.benefit-list li {
  padding: 0.5rem 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.4;
  position: relative;
  padding-left: 1.25rem;
}

.benefit-list li::before {
  content: "\u2022";
  color: var(--brand);
  font-weight: bold;
  position: absolute;
  left: 0;
}

.process-steps {
  margin: 2rem 0;
}

.step {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
  align-items: flex-start;
}

.step-number {
  background: var(--brand);
  color: white;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.step-content h4 {
  margin: 0 0 0.5rem 0;
  color: var(--brand);
  font-size: 1.1rem;
}

.step-content p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
  font-size: 0.9rem;
}

.contact-professional {
  margin-top: 2rem;
  padding: 2rem;
  background: rgba(255,255,255,0.02);
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.1);
  text-align: center;
}

.contact-professional h3 {
  margin-bottom: 1.5rem;
  color: var(--brand);
}

.contact-method {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

.contact-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.85rem;
  line-height: 1.4;
  max-width: 500px;
}

@media (max-width: 768px) {
  .values-grid.professional, .practice-grid, .benefits-grid.professional {
    grid-template-columns: 1fr;
  }
  
  .contact-professional .contact-method {
    flex-direction: column;
    align-items: stretch;
  }
  
  .contact-professional .btn-lg {
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
  }
  
  .step {
    gap: 0.75rem;
  }
  
  .step-number {
    width: 28px;
    height: 28px;
    font-size: 0.8rem;
  }
}

/* Why Choose Us Section */
.why-choose h2 {
  text-align: center;
  margin-bottom: 2rem;
}

.benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-top: 1.5rem;
}

.benefit {
  text-align: center;
  padding: 1.5rem;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: all 0.3s ease;
}

.benefit:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--brand);
}

.benefit-icon {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  display: block;
}

.benefit h3 {
  margin: 0 0 0.75rem 0;
  color: var(--brand);
  font-size: 1.125rem;
}

.benefit p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
  font-size: 0.9rem;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
}

/* Modern Homepage Styles */
.hero-modern {
  position: relative;
  padding: 80px 0;
  background: linear-gradient(135deg, var(--accent) 0%, var(--panel) 100%);
  border-radius: 16px;
  margin: 32px 0;
  overflow: hidden;
}

.hero-modern::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(var(--brand) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity: 0.05;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.8), rgba(0,0,0,0));
}

.hero-modern-content {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
}

.hero-modern h1 {
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin: 0 0 24px;
  background: linear-gradient(135deg, var(--text), var(--brand));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-modern-subtitle {
  font-size: 1.5rem;
  line-height: 1.4;
  color: var(--muted);
  margin: 0 0 40px;
  font-weight: 400;
}

.hero-modern-cta {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}

.services-preview {
  margin: 64px 0;
}

.services-preview h2 {
  text-align: center;
  font-size: 2.5rem;
  margin: 0 0 48px;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 32px;
}

.service-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 32px;
  text-align: center;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.service-card::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 16px;
  padding: 1px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.3s ease;
}

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

.service-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 16px 48px var(--hover-shadow);
}

.service-card-icon {
  font-size: 3rem;
  margin-bottom: 24px;
  display: block;
}

.service-card h3 {
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0 0 16px;
  color: var(--text);
}

.service-card p {
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

.why-choose-modern {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 64px 40px;
  margin: 64px 0;
  text-align: center;
}

.why-choose-modern h2 {
  font-size: 2.5rem;
  margin: 0 0 48px;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 40px;
  max-width: 1000px;
  margin: 0 auto;
}

.benefit-item {
  text-align: center;
}

.benefit-icon {
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 24px;
  font-size: 2rem;
  color: white;
}

.benefit-item h3 {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 16px;
  color: var(--text);
}

.benefit-item p {
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

.results-modern {
  margin: 64px 0;
  text-align: center;
}

.results-modern h2 {
  font-size: 2.5rem;
  margin: 0 0 48px;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 32px;
  max-width: 800px;
  margin: 0 auto;
}

.result-stat {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 32px 24px;
  transition: all 0.3s ease;
}

.result-stat:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 32px var(--hover-shadow);
}

.stat-number {
  font-size: 3rem;
  font-weight: 700;
  color: var(--brand);
  display: block;
  margin-bottom: 8px;
  line-height: 1;
}

.stat-label {
  color: var(--muted);
  font-weight: 500;
  font-size: 0.95rem;
}

.cta-modern {
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);
  border-radius: 16px;
  padding: 64px 40px;
  margin: 64px 0;
  text-align: center;
  color: white;
  position: relative;
  overflow: hidden;
}

.cta-modern::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.1) 1px, transparent 1px);
  background-size: 20px 20px;
  opacity: 0.3;
}

.cta-modern-content {
  position: relative;
  z-index: 2;
  max-width: 600px;
  margin: 0 auto;
}

.cta-modern h2 {
  font-size: 2.5rem;
  margin: 0 0 24px;
  font-weight: 600;
  color: white;
  letter-spacing: -0.02em;
}

.cta-modern p {
  font-size: 1.25rem;
  margin: 0 0 32px;
  opacity: 0.9;
  line-height: 1.5;
}

.cta-modern .btn-lg {
  background: rgba(255,255,255,0.2);
  border: 2px solid rgba(255,255,255,0.3);
  color: white;
  font-weight: 600;
  backdrop-filter: blur(10px);
}

.cta-modern .btn-lg:hover {
  background: rgba(255,255,255,0.3);
  border-color: rgba(255,255,255,0.5);
  transform: translateY(-2px);
}

/* Responsive adjustments for modern homepage */
@media (max-width: 900px) {
  .hero-modern h1 {
    font-size: 2.5rem;
  }
  
  .hero-modern-subtitle {
    font-size: 1.25rem;
  }
  
  .hero-modern {
    padding: 60px 0;
  }
  
  .services-preview h2,
  .why-choose-modern h2,
  .results-modern h2,
  .cta-modern h2 {
    font-size: 2rem;
  }
  
  .why-choose-modern,
  .cta-modern {
    padding: 48px 32px;
  }
  
  .benefits-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  
  .results-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .hero-modern h1 {
    font-size: 2rem;
  }
  
  .hero-modern-subtitle {
    font-size: 1.125rem;
  }
  
  .hero-modern {
    padding: 48px 0;
    margin: 24px 0;
  }
  
  .services-preview h2,
  .why-choose-modern h2,
  .results-modern h2 {
    font-size: 1.75rem;
  }
  
  .cta-modern h2 {
    font-size: 1.875rem;
  }
  
  .why-choose-modern,
  .cta-modern {
    padding: 40px 24px;
  }
  
  .service-card {
    padding: 24px;
  }
  
  .results-grid {
    grid-template-columns: 1fr;
  }
  
  .hero-modern-cta {
    flex-direction: column;
    align-items: stretch;
  }
}

/* Testimonial Styles */
.testimonial-quote {
  font-size: clamp(1.25rem, 1.5rem + 0.5vw, 1.75rem);
  font-style: italic;
  line-height: 1.6;
  color: var(--text);
  margin: 0 auto 24px;
  max-width: 800px;
  text-align: center;
  position: relative;
  padding: 0 32px;
}

.testimonial-quote::before {
  content: '"';
  position: absolute;
  left: 0;
  top: -12px;
  font-size: 4rem;
  color: var(--brand);
  opacity: 0.3;
  font-family: Georgia, serif;
}

.testimonial-sig {
  text-align: center;
  color: var(--muted);
  font-size: 0.95rem;
  font-weight: 600;
}

/* Case Grid Simplification */
.case {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 32px;
  transition: all 0.3s ease;
}

.case:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--brand);
  transform: translateY(-2px);
}

.case h3 {
  margin-bottom: 16px;
  color: var(--brand-2);
}

/* ==================== BROWSER COMPATIBILITY FIXES ==================== */

/* Edge-specific fixes */
@supports (-ms-ime-align: auto) {
  .hero-prime {
    display: -ms-flexbox;
    -ms-flex-wrap: wrap;
  }
  .cf-nav-inner {
    -ms-flex-align: center;
    -ms-flex-pack: justify;
  }
}

/* Internet Explorer fixes */
@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) {
  /* IE11 flexbox fixes */
  .hero-prime {
    display: -ms-flexbox;
    -ms-flex-direction: row;
    -ms-flex-wrap: wrap;
  }
  
  .cf-nav-inner {
    display: -ms-flexbox;
    -ms-flex-align: center;
    -ms-flex-pack: justify;
  }
  
  /* IE11 CSS variable fallbacks */
  body { background: #ffffff; color: #1e293b; }
  .cf-nav { background: rgba(255,255,255,0.95); }
  a { color: #3b82f6; }
  .btn { background: #3b82f6; color: #ffffff; }
  h1, h2, h3 { color: #1e293b; }
}

/* Safari-specific fixes */
@media not all and (min-resolution: 0.001dpcm) {
  @supports (-webkit-appearance: none) {
    .hero-prime {
      -webkit-backdrop-filter: blur(20px);
    }
  }
}

/* Firefox-specific fixes */
@-moz-document url-prefix() {
  .hero-prime {
    /* Fallback background for Firefox without backdrop-filter */
    background-color: rgba(255,255,255,0.95);
  }
}

/* Old browser class-based fallbacks */
.browser-ie .hero-prime,
.browser-old-chrome .hero-prime,
.browser-old-firefox .hero-prime {
  display: block;
  background: #ffffff;
  border: 1px solid #e2e8f0;
}

.browser-ie .cf-nav,
.browser-old-chrome .cf-nav,
.browser-old-firefox .cf-nav {
  background: rgba(255,255,255,0.98);
}

/* No CSS Grid fallbacks */
.no-css-grid .hero-prime {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.no-css-grid .hero-content {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 300px;
  flex: 1 1 300px;
  margin-right: 20px;
}

.no-css-grid .hero-visual {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 300px;
  flex: 1 1 300px;
}

/* ==================== CONTACT PAGE LAYOUT FIXES ==================== */

/* Force proper desktop layout for contact page */
@media (min-width: 769px) {
  .quantum-contact .hero-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 60px;
    align-items: center;
  }
  
  .quantum-contact .contact-container {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 80px;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 40px;
  }
  
  /* Hide mobile navigation on desktop */
  .mobile-nav {
    display: none !important;
  }
  
  .nav-toggle {
    display: none !important;
  }
  
  .nav-menu {
    display: flex !important;
  }
}

/* Mobile responsive fixes */
@media (max-width: 768px) {
  .quantum-contact .hero-grid {
    display: block;
  }
  
  .quantum-contact .hero-content,
  .quantum-contact .hero-visual {
    margin-bottom: 2rem;
  }
  
  .quantum-contact .contact-container {
    display: block;
    padding: 0 20px;
  }
  
  .quantum-contact .contact-info {
    margin-bottom: 2rem;
  }
  
  /* Show mobile navigation on mobile */
  .nav-toggle {
    display: flex !important;
  }
  
  .nav-menu {
    display: none !important;
  }
}

/* End browser-specific fixes */


