/*
 * Dev-Binary-X — Corporate Design System
 * Enterprise Tech / Cloud / Software
 * v3.0 | 2025
 * Inspired by: AWS, Azure, Datadog, Vercel, Linear
 */

/* ═══════════════════════════════════════════════════════
   DESIGN TOKENS
   ═══════════════════════════════════════════════════════ */
:root {
  /* Background layers */
  --c-bg-0:        #020c1e;   /* deepest dark */
  --c-bg-1:        #030f26;   /* hero bg */
  --c-bg-2:        #081528;   /* section dark */
  --c-bg-3:        #0d1e38;   /* card bg */
  --c-bg-4:        #122545;   /* card hover */
  --c-bg-light:    #f4f7fc;   /* light section */
  --c-bg-white:    #ffffff;

  /* Brand colors */
  --c-blue:        #0066ff;
  --c-blue-light:  #3b82f6;
  --c-blue-dark:   #0047cc;
  --c-violet:      #7c3aed;
  --c-cyan:        #06b6d4;
  --c-cyan-bright: #00d9ff;
  --c-green:       #10b981;
  --c-orange:      #f59e0b;

  /* ── Dev-Binary-X Official Brand Palette (from logo) ── */
  --brand-navy:    #1B3068;   /* DEV-BINARY- dark navy text */
  --brand-blue:    #2E7DC5;   /* icon primary blue arc     */
  --brand-orange:  #F5A421;   /* X accent + icon orange    */
  --brand-orange-dark: #D4891A;
  --g-brand:       linear-gradient(135deg, #2E7DC5 0%, #1B3068 100%);
  --g-brand-warm:  linear-gradient(135deg, #1B3068 0%, #F5A421 100%);
  --g-brand-full:  linear-gradient(90deg, #2E7DC5 0%, #1B3068 50%, #F5A421 100%);

  /* Gradients */
  --g-primary:     linear-gradient(135deg, #0047cc 0%, #7c3aed 100%);
  --g-hero:        linear-gradient(135deg, #020c1e 0%, #0a1e45 50%, #020c1e 100%);
  --g-blue-cyan:   linear-gradient(135deg, #0066ff 0%, #06b6d4 100%);
  --g-blue-violet: linear-gradient(135deg, #0066ff 0%, #7c3aed 100%);
  --g-text:        linear-gradient(135deg, #60a5fa 0%, #a78bfa 100%);
  --g-text-cyan:   linear-gradient(135deg, #22d3ee 0%, #3b82f6 100%);

  /* Text */
  --c-text-1:      #f0f6ff;   /* primary on dark */
  --c-text-2:      #94a3b8;   /* secondary on dark */
  --c-text-3:      #64748b;   /* tertiary on dark */
  --c-text-dark:   #0f172a;   /* primary on light */
  --c-text-muted:  #475569;   /* secondary on light */

  /* Borders */
  --c-border:      rgba(255,255,255,0.07);
  --c-border-2:    rgba(255,255,255,0.12);
  --c-border-blue: rgba(0,102,255,0.25);
  --c-border-light: rgba(0,0,0,0.06);

  /* Shadows */
  --s-sm:  0 2px 12px rgba(0,0,0,0.4);
  --s-md:  0 8px 32px rgba(0,0,0,0.45);
  --s-lg:  0 16px 64px rgba(0,0,0,0.5);
  --s-glow: 0 0 60px rgba(0,102,255,0.25);
  --s-glow-cyan: 0 0 40px rgba(6,182,212,0.2);
  --s-blue: 0 8px 32px rgba(0,102,255,0.35);

  /* Spacing scale */
  --sp-1: 0.25rem;  --sp-2: 0.5rem;  --sp-3: 0.75rem;
  --sp-4: 1rem;     --sp-5: 1.25rem; --sp-6: 1.5rem;
  --sp-8: 2rem;     --sp-10: 2.5rem; --sp-12: 3rem;
  --sp-16: 4rem;    --sp-20: 5rem;   --sp-24: 6rem;

  /* Radius */
  --r-sm:  8px;  --r-md: 12px;  --r-lg: 16px;
  --r-xl:  24px; --r-2xl: 32px; --r-full: 9999px;

  /* Transitions */
  --t-fast: all 0.2s cubic-bezier(0.4,0,0.2,1);
  --t-base: all 0.35s cubic-bezier(0.4,0,0.2,1);
  --t-slow: all 0.5s cubic-bezier(0.4,0,0.2,1);

  /* Typography */
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* ═══════════════════════════════════════════════════════
   RESET & BASE
   ═══════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }

/* Fix: evitar fondo blanco al final del scroll — triple seguro */
html, body {
  background: var(--c-bg-0) !important;
}
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  min-height: 100%;
}

body {
  font-family: var(--font) !important;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--c-text-dark);
  background: var(--c-bg-0);   /* ← dark base: evita blanco al fondo */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--c-bg-1); }
::-webkit-scrollbar-thumb {
  background: var(--g-blue-violet);
  border-radius: var(--r-full);
}
::selection { background: rgba(0,102,255,0.2); color: #fff; }

/* ═══════════════════════════════════════════════════════
   PRELOADER
   ═══════════════════════════════════════════════════════ */
#preloader {
  position: fixed; inset: 0;
  background: var(--c-bg-0);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 20px;
}
#preloader::before {
  content: '';
  width: 52px; height: 52px;
  border: 3px solid rgba(255,255,255,0.08);
  border-top-color: var(--c-blue);
  border-radius: 50%;
  animation: spin 0.75s linear infinite;
}
#preloader::after {
  content: 'Dev-Binary-X';
  font-family: var(--font);
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.2em;
  color: var(--c-text-2);
  text-transform: uppercase;
  animation: pulseOpacity 1.5s ease-in-out infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes pulseOpacity { 0%,100%{opacity:.4} 50%{opacity:1} }

/* ═══════════════════════════════════════════════════════
   NAVBAR
   ═══════════════════════════════════════════════════════ */
.corp-nav {
  position: fixed !important;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 18px 0;
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: var(--t-base);
}
.corp-nav.scrolled {
  background: rgba(2,12,30,0.92) !important;
  backdrop-filter: blur(24px) saturate(1.4);
  -webkit-backdrop-filter: blur(24px) saturate(1.4);
  border-bottom-color: var(--c-border);
  padding: 12px 0;
}
.corp-nav .navbar-brand img {
  height: 44px;
  filter: brightness(1.1);
  transition: var(--t-fast);
}
.corp-nav .navbar-brand:hover img { filter: brightness(1.3) drop-shadow(0 0 12px rgba(0,102,255,0.5)); }

.corp-nav .nav-link {
  color: rgba(255,255,255,0.75) !important;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 6px 16px !important;
  border-radius: var(--r-full);
  transition: var(--t-fast);
  position: relative;
}
.corp-nav .nav-link:hover,
.corp-nav .nav-link:focus {
  color: #fff !important;
  background: rgba(255,255,255,0.06);
}
.corp-nav .dropdown-menu {
  background: rgba(8,21,40,0.98);
  backdrop-filter: blur(24px);
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-lg);
  padding: 8px;
  min-width: 220px;
  margin-top: 8px;
  box-shadow: var(--s-lg);
}
.corp-nav .dropdown-item {
  color: var(--c-text-2) !important;
  border-radius: var(--r-sm);
  padding: 9px 14px;
  font-size: 0.875rem;
  transition: var(--t-fast);
}
.corp-nav .dropdown-item:hover {
  background: rgba(0,102,255,0.12) !important;
  color: #fff !important;
}
.corp-nav .navbar-toggler {
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-sm);
  padding: 6px 10px;
}
.corp-nav .navbar-toggler-icon {
  filter: brightness(0) invert(1);
}

/* CTA nav button */
.corp-nav .btn-nav-cta {
  background: var(--g-blue-violet) !important;
  color: #fff !important;
  border: none;
  border-radius: var(--r-full);
  padding: 8px 22px;
  font-size: 0.85rem;
  font-weight: 600;
  transition: var(--t-base);
  box-shadow: var(--s-blue);
}
.corp-nav .btn-nav-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(0,102,255,0.45);
}

/* ═══════════════════════════════════════════════════════
   HERO SECTION
   ═══════════════════════════════════════════════════════ */
.corp-hero {
  min-height: 100vh;
  background: var(--c-bg-0);
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding-top: 80px;
}

/* Grid dot pattern — more visible */
.corp-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(rgba(0,102,255,0.18) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
  opacity: 0.7;
}

/* Gradient orbs — stronger, more colourful */
.corp-hero__orb-1 {
  position: absolute;
  width: 800px; height: 800px;
  top: -250px; right: -200px;
  background: radial-gradient(ellipse, rgba(124,58,237,0.28) 0%, rgba(0,102,255,0.12) 40%, transparent 68%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  animation: floatOrb 8s ease-in-out infinite;
}
.corp-hero__orb-2 {
  position: absolute;
  width: 600px; height: 600px;
  bottom: -150px; left: -120px;
  background: radial-gradient(ellipse, rgba(6,182,212,0.22) 0%, rgba(0,102,255,0.1) 40%, transparent 68%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  animation: floatOrb 10s ease-in-out infinite reverse;
}
@keyframes floatOrb {
  0%,100% { transform: translate(0,0) scale(1); }
  33%  { transform: translate(20px,-30px) scale(1.05); }
  66%  { transform: translate(-15px,20px) scale(0.96); }
}

/* Horizontal line accent */
.corp-hero::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  bottom: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,102,255,0.4) 30%, rgba(124,58,237,0.4) 70%, transparent);
}

.corp-hero__inner { position: relative; z-index: 1; width: 100%; }

/* Badge */
.corp-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(0,102,255,0.1);
  border: 1px solid rgba(0,102,255,0.3);
  border-radius: var(--r-full);
  padding: 6px 16px;
  font-size: 0.78rem;
  font-weight: 600;
  color: #60a5fa;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.corp-hero__badge span {
  width: 7px; height: 7px;
  background: var(--c-cyan-bright);
  border-radius: 50%;
  animation: pulseDot 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes pulseDot {
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:0.4;transform:scale(1.4)}
}

/* Hero h1 */
.corp-hero__h1 {
  font-size: clamp(2.4rem, 5.5vw, 4.2rem) !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.03em !important;
  color: var(--c-text-1) !important;
  margin-bottom: 24px !important;
}
.corp-hero__h1 .grad-text {
  background: var(--g-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.corp-hero__p {
  font-size: 1.05rem !important;
  line-height: 1.8 !important;
  color: var(--c-text-2) !important;
  max-width: 520px;
  margin-bottom: 36px !important;
}

/* Hero form */
.corp-hero__form {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-xl);
  padding: 24px;
  backdrop-filter: blur(12px);
}
.corp-hero__form label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-text-2);
  margin-bottom: 6px;
  display: block;
}
.corp-hero__form .form-control,
.corp-hero__form .form-select {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid var(--c-border-2) !important;
  border-radius: var(--r-md) !important;
  color: #fff !important;
  padding: 11px 16px !important;
  font-size: 0.875rem !important;
  transition: var(--t-fast);
}
.corp-hero__form .form-control::placeholder { color: rgba(255,255,255,0.35); }
.corp-hero__form .form-select option { background: var(--c-bg-2); color: #fff; }
.corp-hero__form .form-control:focus,
.corp-hero__form .form-select:focus {
  background: rgba(255,255,255,0.09) !important;
  border-color: var(--c-blue) !important;
  box-shadow: 0 0 0 3px rgba(0,102,255,0.15) !important;
  outline: none;
}

.corp-btn-primary {
  background: var(--g-blue-violet) !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 0.9rem !important;
  padding: 13px 28px !important;
  letter-spacing: 0.03em;
  transition: var(--t-base) !important;
  box-shadow: var(--s-blue) !important;
  position: relative;
  overflow: hidden;
}
.corp-btn-primary::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.15), transparent);
  opacity: 0;
  transition: opacity 0.25s;
}
.corp-btn-primary:hover { transform: translateY(-2px) !important; box-shadow: 0 12px 40px rgba(0,102,255,0.45) !important; }
.corp-btn-primary:hover::after { opacity: 1; }

.corp-btn-outline {
  background: transparent !important;
  border: 1px solid var(--c-border-2) !important;
  border-radius: var(--r-full) !important;
  color: var(--c-text-2) !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
  padding: 12px 28px !important;
  transition: var(--t-base) !important;
}
.corp-btn-outline:hover {
  background: rgba(255,255,255,0.07) !important;
  border-color: var(--c-border-2) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

/* Hero image area */
.corp-hero__img-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.corp-hero__img-glow {
  position: absolute;
  width: 520px; height: 520px;
  background: radial-gradient(circle, rgba(0,102,255,0.22) 0%, rgba(124,58,237,0.12) 40%, transparent 70%);
  border-radius: 50%;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  animation: glowPulse 4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes glowPulse {
  0%,100%{opacity:0.6;transform:translate(-50%,-50%) scale(1)}
  50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}
}
.corp-hero__img {
  position: relative;
  z-index: 1;
  max-width: 100%;
  width: 520px;
  filter: drop-shadow(0 20px 60px rgba(0,102,255,0.3));
  animation: heroFloat 6s ease-in-out infinite;
}
@keyframes heroFloat {
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-16px)}
}

/* Hero trust badge row */
.corp-hero__trust {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-top: 36px;
  flex-wrap: wrap;
}
.corp-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--c-text-2);
}
.corp-hero__trust-item i {
  color: var(--c-green);
  font-size: 1rem;
}
.corp-hero__trust-sep {
  width: 1px; height: 18px;
  background: var(--c-border-2);
}

/* ═══════════════════════════════════════════════════════
   STATS BAR
   ═══════════════════════════════════════════════════════ */
.corp-stats {
  background: var(--c-bg-2);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  padding: 40px 0;
}
.corp-stats__item {
  text-align: center;
  padding: 0 20px;
  border-right: 1px solid var(--c-border);
}
.corp-stats__item:last-child { border-right: none; }
.corp-stats__num {
  font-size: 2.4rem;
  font-weight: 900;
  background: var(--g-text-cyan);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: 6px;
  letter-spacing: -0.03em;
}
.corp-stats__label {
  font-size: 0.8rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-text-2);
}

/* ═══════════════════════════════════════════════════════
   SECTION COMMON
   ═══════════════════════════════════════════════════════ */
.corp-section { padding: 96px 0; }
.corp-section--dark { background: var(--c-bg-1); }
.corp-section--surface { background: var(--c-bg-light); }
.corp-section--white { background: var(--c-bg-white); }

.corp-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-blue-light);
  margin-bottom: 12px;
}
.corp-eyebrow::before {
  content: '';
  display: block;
  width: 24px; height: 2px;
  background: var(--g-blue-cyan);
  border-radius: var(--r-full);
}

.corp-h2 {
  font-size: clamp(1.75rem, 3.5vw, 2.75rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.025em !important;
  line-height: 1.2 !important;
  margin-bottom: 16px !important;
}
/* Gradient span — always inherit parent alignment */
.corp-h2 .grad,
.corp-h2 .grad-b {
  display: inline-block;
}
/* tech-section heading always centered */
.corp-tech .corp-h2 { text-align: center; }
.corp-h2--dark { color: var(--c-text-1) !important; }
.corp-h2--light { color: var(--c-text-dark) !important; }
.corp-h2 .grad { background: var(--g-text); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.corp-h2 .grad-b { background: var(--g-blue-violet); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

.corp-lead {
  font-size: 1.025rem;
  line-height: 1.8;
  color: var(--c-text-2);
  max-width: 600px;
}
.corp-lead--dark { color: var(--c-text-muted); }

/* ═══════════════════════════════════════════════════════
   SERVICE TABS
   ═══════════════════════════════════════════════════════ */
.corp-tabs {
  border: none !important;
  background: rgba(255,255,255,0.03);
  border-radius: var(--r-xl);
  padding: 6px;
  gap: 4px;
  flex-wrap: wrap;
  justify-content: center;
  border: 1px solid var(--c-border-light) !important;
  margin-bottom: 48px;
}
.corp-section--white .corp-tabs,
.corp-section--surface .corp-tabs {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.06) !important;
}

.corp-tabs .nav-link {
  border: none !important;
  border-radius: var(--r-lg) !important;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--c-text-muted) !important;
  padding: 9px 18px !important;
  letter-spacing: 0.02em;
  transition: var(--t-fast);
  white-space: nowrap;
  background: transparent;
}
.corp-section--dark .corp-tabs .nav-link { color: var(--c-text-2) !important; }

.corp-tabs .nav-link:hover {
  background: var(--sc-tint, rgba(0,102,255,0.08)) !important;
  color: var(--sc-accent, var(--c-blue)) !important;
}
.corp-tabs .nav-link.active {
  background: var(--sc-accent, var(--g-blue-violet)) !important;
  color: #fff !important;
  box-shadow: 0 4px 16px var(--sc-tint, rgba(0,102,255,0.35));
}

.corp-tab-pane { animation: tabIn 0.35s ease; }
@keyframes tabIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:none; } }

/* Service cards */
.corp-service-card {
  background: var(--c-bg-white);
  border: 1px solid var(--c-border-light);
  border-radius: var(--r-lg);
  padding: 28px;
  height: 100%;
  transition: var(--t-base);
  position: relative;
  overflow: hidden;
}
.corp-section--dark .corp-service-card {
  background: var(--c-bg-3);
  border-color: var(--c-border);
}
.corp-service-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--sc-accent, var(--g-blue-violet));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
  border-radius: 0 0 3px 3px;
}
.corp-service-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--s-md);
  border-color: var(--sc-tint, rgba(0,102,255,0.2));
}
.corp-section--dark .corp-service-card:hover {
  background: var(--c-bg-4);
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  border-color: rgba(0,102,255,0.3);
}
.corp-service-card:hover::before { transform: scaleX(1); }

.corp-service-card__icon {
  width: 52px; height: 52px;
  background: var(--sc-tint, linear-gradient(135deg, rgba(0,102,255,0.12), rgba(124,58,237,0.08)));
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
  transition: var(--t-base);
}
.corp-service-card:hover .corp-service-card__icon {
  background: var(--sc-accent, var(--g-blue-violet));
  box-shadow: 0 4px 14px var(--sc-tint, rgba(0,102,255,0.4));
}
.corp-service-card__icon i {
  font-size: 1.4rem;
  color: var(--sc-accent, var(--c-blue));
  transition: var(--t-base);
}
.corp-service-card:hover .corp-service-card__icon i { color: #fff; }

.corp-service-card__title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--c-text-dark);
  margin-bottom: 8px;
  line-height: 1.3;
}
.corp-section--dark .corp-service-card__title { color: var(--c-text-1); }

.corp-service-card__text {
  font-size: 0.82rem;
  line-height: 1.7;
  color: var(--c-text-muted);
  margin-bottom: 16px;
}
.corp-section--dark .corp-service-card__text { color: var(--c-text-2); }

.corp-service-card__link {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--sc-accent, var(--c-blue));
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: var(--t-fast);
}
.corp-service-card__link:hover { gap: 8px; color: var(--sc-accent, var(--c-violet)); opacity: 0.8; }

/* ═══════════════════════════════════════════════════════
   ABOUT / METRICS
   ═══════════════════════════════════════════════════════ */
/* ════ ABOUT SECTION — white background ════ */
.corp-about {
  background: #ffffff;
  position: relative;
}
/* Subtle top accent line for about */
.corp-about::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,102,255,0.3) 50%, transparent);
}

/* Scoped overrides for light bg */
.corp-about .corp-lead      { color: var(--c-text-muted) !important; }
.corp-about .corp-eyebrow   { /* stays blue — fine on white */ }

/* Metric cards on white bg */
.corp-metric-card {
  background: var(--c-bg-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: 24px;
  text-align: center;
  transition: var(--t-base);
}
.corp-metric-card:hover {
  background: var(--c-bg-4);
  border-color: rgba(0,102,255,0.3);
  transform: translateY(-4px);
  box-shadow: var(--s-md);
}
.corp-metric-card__num {
  font-size: 2.2rem;
  font-weight: 900;
  background: var(--g-text-cyan);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: 6px;
  letter-spacing: -0.03em;
}
.corp-metric-card__label {
  font-size: 0.78rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--c-text-2);
}

/* Light-mode metric card */
.corp-about .corp-metric-card {
  background: #f4f7fc;
  border-color: rgba(0,0,0,0.07);
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.corp-about .corp-metric-card:hover {
  background: #eef3ff;
  border-color: rgba(0,102,255,0.2);
  box-shadow: 0 10px 28px rgba(0,102,255,0.12);
}
.corp-about .corp-metric-card__label { color: var(--c-text-muted); }

/* About info panel (right column) */
.corp-about__panel {
  background: #f8faff !important;
  border: 1px solid rgba(0,0,0,0.07) !important;
  border-radius: var(--r-xl);
  padding: 36px;
}
.corp-about__panel h5 { color: var(--c-text-dark) !important; }
.corp-about__panel p  { color: var(--c-text-muted) !important; }

/* List on white bg */
.corp-about__list { list-style: none; padding: 0; margin: 0; }
.corp-about__list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(0,0,0,0.07);
  color: var(--c-text-muted);
  font-size: 0.9rem;
}
.corp-about__list li:last-child { border-bottom: none; }
.corp-about__list li i {
  color: var(--c-blue);
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: 2px;
}

/* ═══════════════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════════════ */
.corp-testi { background: var(--c-bg-light); }

.corp-testi-card {
  background: #fff;
  border: 1px solid var(--c-border-light);
  border-radius: var(--r-xl);
  padding: 32px;
  transition: var(--t-base);
  position: relative;
  overflow: hidden;
  height: 100%;
}
.corp-testi-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--g-blue-violet);
  transform: scaleX(0);
  transition: transform 0.4s ease;
  transform-origin: left;
}
.corp-testi-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 48px rgba(0,102,255,0.1);
}
.corp-testi-card:hover::after { transform: scaleX(1); }

.corp-testi-card__quote {
  font-size: 3rem;
  line-height: 1;
  background: var(--g-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0.3;
  font-family: Georgia, serif;
  margin-bottom: -8px;
}
.corp-testi-card__text {
  font-size: 0.9rem;
  line-height: 1.8;
  color: #555;
  margin-bottom: 20px;
}
.corp-testi-card__stars { color: #f59e0b; font-size: 0.85rem; margin-bottom: 12px; letter-spacing: 2px; }
.corp-testi-card__avatar {
  width: 42px; height: 42px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(0,102,255,0.2);
  box-shadow: 0 4px 12px rgba(0,102,255,0.15);
}
.corp-testi-card__name { font-weight: 700; font-size: 0.9rem; color: var(--c-text-dark); }
.corp-testi-card__role { font-size: 0.78rem; color: var(--c-text-muted); }

/* Featured testimonial */
.corp-testi-card--featured {
  background: linear-gradient(135deg, #fff 60%, rgba(0,102,255,0.03));
  border-left: 4px solid var(--c-blue);
}
.corp-testi-card--featured:hover { box-shadow: 0 12px 48px rgba(0,102,255,0.12); }

.corp-testi-metric {
  background: var(--c-bg-light);
  border: 1px solid var(--c-border-light);
  border-radius: var(--r-lg);
  padding: 18px 14px;
  text-align: center;
  transition: var(--t-fast);
}
.corp-testi-metric:hover { border-color: rgba(0,102,255,0.2); }
.corp-testi-metric__val {
  font-size: 1.6rem;
  font-weight: 900;
  background: var(--g-blue-violet);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: 4px;
}
.corp-testi-metric__lbl {
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--c-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ═══════════════════════════════════════════════════════
   PROJECTS
   ═══════════════════════════════════════════════════════ */
.corp-projects { background: #ffffff; }

.corp-project-card {
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--c-border-light);
  transition: var(--t-base);
  display: block;
}
.corp-project-card:hover { transform: translateY(-6px); box-shadow: var(--s-md); }

.corp-project-card__img {
  position: relative;
  overflow: hidden;
}
.corp-project-card__img img {
  width: 100%;
  display: block;
  transition: transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.corp-project-card:hover .corp-project-card__img img { transform: scale(1.06); }
.corp-project-card__img::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(3,15,38,0.8) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 0.4s;
}
.corp-project-card:hover .corp-project-card__img::after { opacity: 1; }

.corp-project-card__body {
  padding: 18px 20px;
  background: #fff;
  border-top: 2px solid transparent;
  transition: var(--t-base);
}
.corp-project-card:hover .corp-project-card__body { border-top-color: var(--c-blue); }
.corp-project-card__title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--c-text-dark);
  margin: 0 0 4px;
  text-decoration: none;
  display: block;
  transition: color 0.2s;
}
.corp-project-card:hover .corp-project-card__title { color: var(--c-blue); }
.corp-project-card__cat {
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--c-blue);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ═══════════════════════════════════════════════════════
   SUCCESS CASES
   ═══════════════════════════════════════════════════════ */
/* ── Section background — multi-radial ambient ── */
.corp-cases {
  background: var(--c-bg-1);
  position: relative;
  overflow: hidden;
}
.corp-cases::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 65% 55% at 8%  85%, rgba(0,102,255,0.09)   0%, transparent 55%),
    radial-gradient(ellipse 55% 45% at 93% 10%, rgba(124,58,237,0.08)  0%, transparent 55%),
    radial-gradient(ellipse 40% 35% at 55% 52%, rgba(6,182,212,0.04)   0%, transparent 60%);
  pointer-events: none; z-index: 0;
}
.corp-cases .container { position: relative; z-index: 1; }

/* Section meta badges */
.corp-cases__meta {
  display: flex; gap: 20px; justify-content: center;
  flex-wrap: wrap; margin-top: 18px;
  font-size: 0.77rem; font-weight: 500;
  color: var(--c-text-3);
}
.corp-cases__meta span { display: inline-flex; align-items: center; gap: 6px; }
.corp-cases__meta i    { color: var(--c-green); font-size: 0.88rem; }

/* ── Gradient-border wrapper ───────────────────────── */
.corp-cc-wrap {
  --cc-r: 0; --cc-g: 102; --cc-b: 255;        /* default blue */
  padding: 1px;
  border-radius: var(--r-xl);
  height: 100%;
  background: linear-gradient(
    145deg,
    rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.38),
    rgba(255,255,255,0.05) 45%,
    rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.20)
  );
  transition: background 0.35s ease, box-shadow 0.35s ease;
}
.corp-cc-wrap:hover {
  background: linear-gradient(
    145deg,
    rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.80),
    rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.25) 50%,
    rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.55)
  );
  box-shadow:
    0 0 70px rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.22),
    0 28px 64px rgba(0,0,0,0.52);
}

/* ── Per-card RGB components ───────────────────────── */
.corp-cc-wrap--emerald { --cc-r:16;  --cc-g:185; --cc-b:129; }
.corp-cc-wrap--amber   { --cc-r:245; --cc-g:158; --cc-b:11;  }
.corp-cc-wrap--orange  { --cc-r:249; --cc-g:115; --cc-b:22;  }
.corp-cc-wrap--violet  { --cc-r:139; --cc-g:92;  --cc-b:246; }
.corp-cc-wrap--cyan    { --cc-r:6;   --cc-g:182; --cc-b:212; }
.corp-cc-wrap--indigo  { --cc-r:99;  --cc-g:102; --cc-b:241; }

/* ── Card body ─────────────────────────────────────── */
.corp-case-card {
  /* computed accent colour from RGB components */
  --cc-accent: rgb(var(--cc-r),var(--cc-g),var(--cc-b));

  background: linear-gradient(
    155deg,
    var(--c-bg-3) 0%,
    rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.04) 100%
  );
  border-radius: calc(var(--r-xl) - 1px);
  padding: 24px;
  height: 100%;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  transition: background 0.35s ease;
}
.corp-cc-wrap:hover .corp-case-card {
  background: linear-gradient(
    155deg,
    var(--c-bg-4) 0%,
    rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.09) 100%
  );
}

/* ── Head row: logo + sector badge ─────────────────── */
.corp-case-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 18px;
}

/* Logo box — clean white container */
.corp-case-card__logo-box {
  background: #ffffff;
  border-radius: var(--r-md);
  padding: 8px 14px;
  height: 46px;
  min-width: 88px; max-width: 130px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: box-shadow 0.3s ease;
}
.corp-cc-wrap:hover .corp-case-card__logo-box {
  box-shadow: 0 4px 22px rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.32);
}
.corp-case-card__logo {
  height: 28px; max-width: 100px; object-fit: contain;
}
/* Text wordmark for clients without logo files */
.corp-cc-wordmark {
  font-family: var(--font-display);
  font-size: 0.74rem; font-weight: 900;
  letter-spacing: -0.02em; white-space: nowrap;
}

/* Sector badge — accent-tinted, not gray */
.corp-case-card__sector {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.14);
  border: 1px solid rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.28);
  border-radius: var(--r-full);
  font-size: 0.59rem; font-weight: 700;
  color: var(--cc-accent);
  letter-spacing: 0.07em; text-transform: uppercase;
  padding: 4px 10px;
  white-space: nowrap;
  align-self: flex-start;
  flex-shrink: 0;
}
.corp-case-card__sector i { font-size: 0.7rem; }

/* ── Title & description ────────────────────────────── */
.corp-case-card__title {
  font-size: 1.05rem; font-weight: 800;
  color: var(--c-text-1);
  margin-bottom: 8px;
  line-height: 1.28;
  letter-spacing: -0.015em;
}
.corp-case-card__text {
  font-size: 0.835rem; line-height: 1.72;
  color: var(--c-text-2);
  flex: 1; margin-bottom: 0;
}

/* ── KPI strip — 3 large impact numbers ─────────────── */
.corp-case-card__kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 20px;
  padding: 14px 0;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.corp-case-card__kpi {
  text-align: center;
  padding: 0 6px;
  border-right: 1px solid rgba(255,255,255,0.07);
}
.corp-case-card__kpi:last-child { border-right: none; }
.corp-case-card__kpi-val {
  font-family: var(--font-display);
  font-size: 1.5rem; font-weight: 900;
  color: var(--cc-accent);
  line-height: 1; letter-spacing: -0.03em;
  margin-bottom: 4px; display: block;
}
.corp-case-card__kpi-lbl {
  font-size: 0.57rem; font-weight: 600;
  color: var(--c-text-3);
  text-transform: uppercase; letter-spacing: 0.07em;
  display: block; line-height: 1.3;
}

/* ── Footer: tech pills + CTA button ───────────────── */
.corp-case-card__footer {
  display: flex; align-items: center;
  justify-content: space-between;
  gap: 10px; margin-top: 16px;
}
.corp-case-card__techs {
  display: flex; flex-wrap: wrap; gap: 5px; flex: 1;
}
.corp-case-card__tech {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: var(--r-full);
  font-size: 0.62rem; font-weight: 600;
  color: var(--c-text-3); padding: 2px 9px;
  letter-spacing: 0.03em;
  transition: border-color 0.2s, color 0.2s;
}
.corp-cc-wrap:hover .corp-case-card__tech {
  border-color: rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.3);
  color: var(--c-text-2);
}

/* CTA — solid accent pill button */
.corp-case-card__cta {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.67rem; font-weight: 700;
  color: #fff;
  background: var(--cc-accent);
  border-radius: var(--r-full);
  padding: 6px 13px;
  white-space: nowrap; flex-shrink: 0;
  letter-spacing: 0.03em; text-transform: uppercase;
  transition: filter 0.2s, box-shadow 0.2s;
  box-shadow: 0 2px 10px rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.32);
}
.corp-cc-wrap:hover .corp-case-card__cta {
  filter: brightness(1.12);
  box-shadow: 0 4px 18px rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.48);
}
.corp-case-card__cta i { font-size: 1rem; transition: transform 0.2s; }
.corp-cc-wrap:hover .corp-case-card__cta i { transform: translateX(3px); }

/* ── Mobile ─────────────────────────────────────────── */
@media (max-width: 575.98px) {
  .corp-case-card { padding: 18px; }
  .corp-case-card__kpi-val { font-size: 1.25rem; }
  .corp-case-card__footer { flex-wrap: wrap; }
}

/* ── Aggregate impact bar ──────────────────────────────
   Shows 4 headline stats above the cards grid           */
.corp-cc-impact-bar {
  display: flex;
  align-items: stretch;
  max-width: 640px;
  margin: 0 auto 44px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--r-xl);
  overflow: hidden;
}
.corp-cc-impact-bar__item {
  flex: 1;
  text-align: center;
  padding: 18px 10px 14px;
  border-right: 1px solid rgba(255,255,255,0.07);
  position: relative;
}
.corp-cc-impact-bar__item:last-child { border-right: none; }
.corp-cc-impact-bar__item::before {
  content: '';
  position: absolute;
  top: 0; left: 50%; transform: translateX(-50%);
  width: 32px; height: 2px;
  background: var(--g-blue-violet);
  border-radius: 0 0 var(--r-full) var(--r-full);
}
.corp-cc-impact-bar__val {
  font-family: var(--font-display);
  font-size: 1.3rem; font-weight: 900;
  color: var(--c-text-1);
  letter-spacing: -0.04em;
  line-height: 1;
  display: block;
  margin-bottom: 5px;
}
.corp-cc-impact-bar__lbl {
  font-size: 0.58rem; font-weight: 600;
  color: var(--c-text-3);
  text-transform: uppercase; letter-spacing: 0.07em;
  display: block; line-height: 1.3;
}
@media (max-width: 575.98px) {
  .corp-cc-impact-bar { flex-wrap: wrap; }
  .corp-cc-impact-bar__item { flex: 0 0 50%; border-bottom: 1px solid rgba(255,255,255,0.07); }
  .corp-cc-impact-bar__item:nth-child(even) { border-right: none; }
  .corp-cc-impact-bar__item:nth-child(n+3) { border-bottom: none; }
}

/* ── Case-number watermark inside card ─────────────── */
.corp-case-card__num {
  position: absolute;
  bottom: 16px; right: 16px;
  font-family: var(--font-display);
  font-size: 4.8rem; font-weight: 900;
  color: rgba(255,255,255,0.03);
  line-height: 1;
  pointer-events: none; user-select: none;
  letter-spacing: -0.06em; z-index: 0;
  transition: color 0.35s ease;
}
.corp-cc-wrap:hover .corp-case-card__num {
  color: rgba(var(--cc-r),var(--cc-g),var(--cc-b),0.07);
}

/* ── KPI spring pop-in when card enters viewport ───── */
@keyframes kpiPop {
  from { opacity: 0; transform: translateY(10px) scale(0.82); }
  to   { opacity: 1; transform: none; }
}
.corp-reveal.visible .corp-case-card__kpi-val {
  animation: kpiPop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.corp-reveal.visible .corp-case-card__kpi:nth-child(2) .corp-case-card__kpi-val {
  animation-delay: 0.1s;
}
.corp-reveal.visible .corp-case-card__kpi:nth-child(3) .corp-case-card__kpi-val {
  animation-delay: 0.2s;
}

/* ── Diagonal shimmer sweep on hover ───────────────── */
@keyframes ccShimmer {
  from { transform: translateX(-180%) skewX(-10deg); }
  to   { transform: translateX(280%)  skewX(-10deg); }
}
.corp-case-card::after {
  content: '';
  position: absolute;
  inset: 0; width: 50%;
  background: linear-gradient(
    90deg, transparent, rgba(255,255,255,0.05), transparent
  );
  transform: translateX(-180%) skewX(-10deg);
  pointer-events: none; border-radius: inherit;
}
.corp-cc-wrap:hover .corp-case-card::after {
  animation: ccShimmer 0.75s ease-out forwards;
}

/* ── Section CTA row ───────────────────────────────── */
.corp-cases__cta-row {
  display: flex; align-items: center;
  justify-content: center; gap: 20px;
  margin-top: 52px; flex-wrap: wrap; text-align: center;
}
.corp-cases__cta-note {
  font-size: 0.82rem; color: var(--c-text-3);
  display: flex; align-items: center; gap: 7px;
}
.corp-cases__cta-note i { color: var(--c-green); }

/* ═══════════════════════════════════════════════════════
   PRICING / CLOUD ARCHITECTURE
   ═══════════════════════════════════════════════════════ */
.corp-pricing { background: var(--c-bg-light); }

.corp-pricing-card {
  background: #fff;
  border: 1px solid var(--c-border-light);
  border-radius: var(--r-xl);
  overflow: hidden;
  transition: var(--t-base);
}
.corp-pricing-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 48px rgba(0,102,255,0.12);
  border-color: rgba(0,102,255,0.2);
}
.corp-pricing-card__head {
  padding: 24px 28px;
  background: linear-gradient(135deg, rgba(0,102,255,0.05), rgba(124,58,237,0.04));
  border-bottom: 1px solid var(--c-border-light);
}
.corp-pricing-card__head h4 {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--c-text-dark);
  margin: 0 0 4px;
}
.corp-pricing-card__head small { color: var(--c-blue); font-weight: 600; font-size: 0.8rem; }
.corp-pricing-card__body { padding: 24px 28px; }
.corp-pricing-card__body ul { list-style: none; padding: 0; margin: 0 0 20px; }
.corp-pricing-card__body li {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 9px 0;
  border-bottom: 1px solid var(--c-border-light);
  font-size: 0.86rem;
  color: var(--c-text-muted);
}
.corp-pricing-card__body li:last-child { border-bottom: none; }
.corp-pricing-card__body li i { color: var(--c-blue); font-size: 1rem; flex-shrink: 0; margin-top: 1px; }

.corp-pricing-card--dark {
  background: linear-gradient(145deg, var(--c-bg-0) 0%, #0a1e45 100%);
  border-color: var(--c-border);
}
.corp-pricing-card--dark .corp-pricing-card__head {
  background: rgba(255,255,255,0.05);
  border-bottom-color: var(--c-border);
}
.corp-pricing-card--dark .corp-pricing-card__head h4 { color: #fff; }
.corp-pricing-card--dark .corp-pricing-card__head small { color: var(--c-cyan); }
.corp-pricing-card--dark li { color: rgba(255,255,255,0.7); border-bottom-color: var(--c-border); }
.corp-pricing-card--dark li i { color: var(--c-cyan); }

/* ═══════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════ */
.corp-faq { background: var(--c-bg-white); }

.corp-accordion .accordion-item {
  border: 1px solid var(--c-border-light) !important;
  border-radius: var(--r-lg) !important;
  margin-bottom: 10px !important;
  overflow: hidden;
  transition: var(--t-fast);
}
.corp-accordion .accordion-item:hover {
  box-shadow: 0 4px 20px rgba(0,102,255,0.07);
}
.corp-accordion .accordion-button {
  font-weight: 600 !important;
  font-size: 0.93rem !important;
  color: var(--c-text-dark) !important;
  background: #fff !important;
  padding: 18px 22px !important;
  border-radius: var(--r-lg) !important;
  box-shadow: none !important;
}
.corp-accordion .accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, rgba(0,102,255,0.04), rgba(124,58,237,0.03)) !important;
  color: var(--c-blue) !important;
}
.corp-accordion .accordion-button::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%230066ff' viewBox='0 0 16 16'%3E%3Cpath d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E") !important;
}
.corp-accordion .accordion-body {
  padding: 14px 22px 22px !important;
  font-size: 0.875rem;
  line-height: 1.8;
  color: var(--c-text-muted);
  background: rgba(0,102,255,0.01);
}

/* ═══════════════════════════════════════════════════════
   CTA BANNER
   ═══════════════════════════════════════════════════════ */
.corp-cta {
  background: var(--c-bg-0);
  position: relative;
  overflow: hidden;
  padding: 96px 0;
}
.corp-cta::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 80% at 50% 50%, rgba(0,102,255,0.12) 0%, transparent 70%);
  pointer-events: none;
}
.corp-cta::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,102,255,0.4) 50%, transparent);
}
.corp-cta__inner {
  position: relative;
  z-index: 1;
  text-align: center;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(0,102,255,0.18);
  border-radius: var(--r-2xl);
  padding: 72px 48px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 0 80px rgba(0,102,255,0.06), inset 0 1px 0 rgba(255,255,255,0.05);
}
.corp-cta__h2 {
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 900;
  color: var(--c-text-1);
  letter-spacing: -0.03em;
  margin-bottom: 16px;
  line-height: 1.15;
}
.corp-cta__h2 span {
  background: var(--g-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.corp-cta__sub {
  font-size: 1.05rem;
  color: var(--c-text-2);
  margin-bottom: 40px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.7;
}
.corp-cta__btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
.corp-footer {
  background: #ffffff;
  border-top: 1px solid var(--c-border-light);
  padding: 0;
  position: relative;
}
.corp-footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-blue) 0%, var(--c-violet) 100%);
  opacity: 1;
}
.corp-footer > .container {
  padding-top: 72px;
  padding-bottom: 0;
}
.corp-footer__brand { margin-bottom: 20px; }
.corp-footer__brand img { height: 42px; }
.corp-footer__desc {
  font-size: 0.85rem;
  line-height: 1.8;
  color: var(--c-text-muted);
  max-width: 280px;
  margin-bottom: 20px;
}
.corp-footer__social {
  display: flex; gap: 10px;
}
.corp-footer__social a {
  width: 36px; height: 36px;
  background: var(--c-bg-light);
  border: 1px solid var(--c-border-light);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--c-text-muted);
  font-size: 0.9rem;
  text-decoration: none;
  transition: var(--t-fast);
}
.corp-footer__social a:hover {
  background: var(--c-blue);
  border-color: var(--c-blue);
  color: #fff;
  transform: translateY(-2px);
}

.corp-footer__title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-text-dark);
  margin-bottom: 20px;
}
.corp-footer__links { list-style: none; padding: 0; margin: 0; }
.corp-footer__links li { margin-bottom: 10px; }
.corp-footer__links a {
  font-size: 0.85rem;
  color: var(--c-text-muted);
  text-decoration: none;
  transition: var(--t-fast);
  display: inline-flex; align-items: center; gap: 6px;
}
.corp-footer__links a::before { content: '›'; color: var(--c-blue); }
.corp-footer__links a:hover { color: var(--c-blue); gap: 10px; }

.corp-footer__contact-item {
  display: flex; gap: 12px; align-items: flex-start;
  margin-bottom: 12px;
  font-size: 0.85rem;
  color: var(--c-text-muted);
}
.corp-footer__contact-item i { color: var(--c-blue); font-size: 0.9rem; margin-top: 2px; flex-shrink: 0; }

.corp-footer__bottom {
  margin-top: 56px;
  padding: 20px 0 28px;
  border-top: 1px solid var(--c-border-light);
  background: #f4f7fc;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.corp-footer__copy {
  font-size: 0.8rem;
  color: var(--c-text-muted);
}
.corp-footer__copy a { color: var(--c-blue); text-decoration: none; font-weight: 600; }
.corp-footer__copy a:hover { text-decoration: underline; }
.corp-footer__badges {
  display: flex; gap: 8px;
}
.corp-footer__badge {
  background: #ffffff;
  border: 1px solid var(--c-border-light);
  border-radius: var(--r-full);
  padding: 4px 12px;
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--c-text-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════
   WHATSAPP FLOAT
   ═══════════════════════════════════════════════════════ */
.whatsapp-float {
  position: fixed !important;
  bottom: 28px !important;
  left: 28px !important;
  width: 58px !important;
  height: 58px !important;
  background: linear-gradient(135deg, #25D366, #128C7E) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  padding: 0 !important;
  z-index: 9000 !important;
  box-shadow: 0 4px 24px rgba(37,211,102,0.45) !important;
  transition: var(--t-base) !important;
  text-decoration: none !important;
}
.whatsapp-float::before {
  content: '';
  position: absolute; inset: -7px;
  border-radius: 50%;
  border: 2px solid rgba(37,211,102,0.45);
  animation: waPulse 2.2s ease-out infinite;
}
.whatsapp-float::after {
  content: '';
  position: absolute; inset: -14px;
  border-radius: 50%;
  border: 2px solid rgba(37,211,102,0.2);
  animation: waPulse 2.2s ease-out 0.35s infinite;
}
@keyframes waPulse { 0%{transform:scale(1);opacity:1} 100%{transform:scale(1.7);opacity:0} }
.whatsapp-float:hover { transform: scale(1.1) translateY(-4px) !important; }

/* ═══════════════════════════════════════════════════════
   TO TOP
   ═══════════════════════════════════════════════════════ */
.to_top {
  background: var(--g-blue-violet) !important;
  box-shadow: var(--s-blue) !important;
  border: none !important;
  transition: var(--t-base) !important;
}
.to_top:hover { transform: translateY(-4px) !important; }
.to_top i { color: #fff !important; }

/* ═══════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════ */
.corp-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.65s cubic-bezier(0.4,0,0.2,1);
}
.corp-reveal.visible { opacity: 1; transform: none; }
.corp-reveal:nth-child(2) { transition-delay: 0.08s; }
.corp-reveal:nth-child(3) { transition-delay: 0.16s; }
.corp-reveal:nth-child(4) { transition-delay: 0.24s; }
.corp-reveal:nth-child(5) { transition-delay: 0.32s; }
.corp-reveal:nth-child(6) { transition-delay: 0.40s; }
.corp-reveal:nth-child(7) { transition-delay: 0.48s; }
.corp-reveal:nth-child(8) { transition-delay: 0.56s; }

/* ═══════════════════════════════════════════════════════
   TRUSTED BY — Infinite marquee carousel
   ═══════════════════════════════════════════════════════ */
.corp-trusted {
  background: #ffffff;
  padding: 32px 0 36px;
  border-top: 1px solid var(--c-border-light);
  border-bottom: 1px solid var(--c-border-light);
  overflow: hidden;
}
.corp-trusted__header {
  text-align: center;
  margin-bottom: 24px;
}
.corp-trusted__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--c-text-muted);
}
.corp-trusted__label::before,
.corp-trusted__label::after {
  content: '';
  display: inline-block;
  width: 32px;
  height: 1px;
  background: var(--c-text-muted);
  opacity: 0.35;
}

/* Marquee wrapper */
.corp-trusted__track-wrap {
  display: flex;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}
.corp-trusted__track {
  display: flex;
  gap: 20px;
  align-items: center;
  animation: marquee 30s linear infinite;
  flex-shrink: 0;
}
.corp-trusted__track--reverse {
  animation: marqueeReverse 32s linear infinite;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes marqueeReverse {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}
.corp-trusted__track:hover,
.corp-trusted__track--reverse:hover { animation-play-state: paused; }

/*
 * Logo pill strategy:
 *  - Dark background (#0d1828) works for EVERY logo format:
 *    • white/light logos (designed for dark bg)  → clearly visible
 *    • coloured logos (purple, teal, orange…)    → clearly visible
 *    • dark logos (black text etc.)              → use brightness filter to lighten
 *  - No greyscale filter — logos show in natural colours
 */
.corp-trusted__logo-item {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 10px 28px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: var(--r-md);
  box-shadow: 0 1px 6px rgba(0,0,0,0.06);
  transition: var(--t-base);
  cursor: default;
  min-width: 120px;
  height: 54px;
  position: relative;
  overflow: hidden;
}
.corp-trusted__logo-item:hover {
  border-color: rgba(0,102,255,0.18);
  box-shadow: 0 6px 20px rgba(0,0,0,0.1);
  transform: translateY(-2px) scale(1.03);
}

.corp-trusted__logo-item img {
  height: 28px;
  max-width: 110px;
  width: auto;
  object-fit: contain;
  filter: none !important;
  transition: opacity 0.25s;
  position: relative; z-index: 1;
  opacity: 0.85;
}
.corp-trusted__logo-item:hover img { opacity: 1; }

/* Mexican company wordmarks */
.corp-mx-logo {
  font-family: 'Arial Black', 'Helvetica Neue', Arial, sans-serif;
  font-weight: 900;
  line-height: 1;
  display: inline-block;
  opacity: 0.82;
  transition: opacity 0.2s;
  white-space: nowrap;
}
.corp-trusted__logo-item:hover .corp-mx-logo { opacity: 1; }
.corp-trusted__logo-item:hover img {
  filter: brightness(1.15) !important;  /* slight brightening on hover */
}
.corp-trusted__logo-item .logo-name {
  font-size: 0.78rem;
  font-weight: 800;
  color: rgba(255,255,255,0.85);     /* white text on dark pill */
  white-space: nowrap;
  letter-spacing: 0.04em;
  transition: var(--t-fast);
  position: relative; z-index: 1;
}
.corp-trusted__logo-item:hover .logo-name {
  color: #ffffff;
}

/* ═══════════════════════════════════════════════════════
   PROJECTS — SVG showcase cards
   ═══════════════════════════════════════════════════════ */
.corp-project-svg-wrap {
  background: var(--c-bg-2);
  border-radius: 10px 10px 0 0;
  overflow: hidden;
  aspect-ratio: 16/9;
  display: flex;
  align-items: stretch;
  position: relative;
  transition: transform 0.5s cubic-bezier(0.4,0,0.2,1);
}
.corp-project-svg-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.25) 100%);
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
}
.corp-project-card:hover .corp-project-svg-wrap::after { opacity: 1; }

/* Project card view overlay */
.corp-project-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,40,100,0.0);
  opacity: 0;
  transition: all 0.4s ease;
  z-index: 2;
}
.corp-project-card__overlay span {
  background: var(--g-blue-violet);
  color: #fff;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 9px 22px;
  border-radius: var(--r-full);
  transform: translateY(12px);
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
  box-shadow: var(--s-blue);
}
.corp-project-card:hover .corp-project-card__overlay {
  opacity: 1;
  background: rgba(0,15,40,0.2);
}
.corp-project-card:hover .corp-project-card__overlay span { transform: none; }
.corp-project-card:hover .corp-project-svg-wrap svg { transform: scale(1.02); }
.corp-project-svg-wrap svg {
  width: 100%;
  height: 100%;
  display: block;
  transition: transform 0.55s cubic-bezier(0.4,0,0.2,1);
  transform-origin: center;
}

/* ═══════════════════════════════════════════════════════
   PROJECT MODALS — Enterprise style
   ═══════════════════════════════════════════════════════ */
.corp-modal .modal-dialog { max-width: 860px; }
.corp-modal .modal-content {
  background: var(--c-bg-2);
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-xl);
  box-shadow: 0 40px 100px rgba(0,0,0,0.75), 0 0 0 1px rgba(255,255,255,0.04);
  color: var(--c-text-1);
  overflow: hidden;
}
.corp-modal .modal-header {
  background: linear-gradient(135deg, rgba(0,102,255,0.06) 0%, rgba(8,21,40,1) 100%);
  border-bottom: 1px solid var(--c-border);
  padding: 24px 32px 20px;
  align-items: flex-start;
}
.corp-modal__client-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(0,102,255,0.1);
  border: 1px solid rgba(0,102,255,0.25);
  border-radius: var(--r-full);
  padding: 4px 14px;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--c-cyan);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.corp-modal .modal-title {
  font-size: 1.25rem;
  font-weight: 900;
  color: var(--c-text-1);
  letter-spacing: -0.025em;
  line-height: 1.2;
  margin-bottom: 4px;
}
.corp-modal__subtitle {
  font-size: 0.82rem;
  color: var(--c-text-2);
  line-height: 1.5;
}
.corp-modal .btn-close { filter: invert(1) opacity(0.55); transition: opacity 0.2s; }
.corp-modal .btn-close:hover { opacity: 1; filter: invert(1) opacity(1); }
.corp-modal .modal-body { padding: 28px 32px; background: var(--c-bg-2); }
.corp-modal .modal-footer {
  background: var(--c-bg-1);
  border-top: 1px solid var(--c-border);
  padding: 18px 32px;
  align-items: center;
}

/* Modal sections */
.corp-modal__section { margin-bottom: 26px; }
.corp-modal__section:last-child { margin-bottom: 0; }
.corp-modal__section-title {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--c-text-3);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.corp-modal__section-title i { color: var(--c-blue); font-size: 0.9rem; }
.corp-modal__section-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--c-border);
}

/* Metrics grid */
.corp-modal__metrics {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
}
.corp-modal__metric {
  background: var(--c-bg-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: 16px 14px;
  text-align: center;
  transition: var(--t-fast);
}
.corp-modal__metric:hover { border-color: var(--c-border-blue); background: var(--c-bg-4); }
.corp-modal__metric-val {
  font-size: 1.65rem;
  font-weight: 900;
  background: var(--g-text-cyan);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: 5px;
  letter-spacing: -0.02em;
}
.corp-modal__metric-lbl {
  font-size: 0.68rem;
  color: var(--c-text-2);
  font-weight: 500;
  line-height: 1.3;
}

/* Tech pills */
.corp-modal__techs { display: flex; flex-wrap: wrap; gap: 7px; }
.corp-modal__tech {
  background: rgba(0,102,255,0.08);
  border: 1px solid rgba(0,102,255,0.2);
  border-radius: var(--r-full);
  padding: 5px 13px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--c-cyan);
  transition: var(--t-fast);
}
.corp-modal__tech:hover { background: rgba(0,102,255,0.18); color: #fff; }

/* Deliverables list */
.corp-modal__deliverables {
  list-style: none;
  padding: 0; margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.corp-modal__deliverables li {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  font-size: 0.83rem;
  color: var(--c-text-2);
  padding: 10px 13px;
  background: var(--c-bg-3);
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
  line-height: 1.4;
}
.corp-modal__deliverables li i { color: var(--c-green); flex-shrink: 0; margin-top: 1px; }
.corp-modal__deliverables li strong { color: var(--c-text-1); font-weight: 600; }

/* Project cards → clickable */
.corp-project-card { cursor: pointer; }

/* ═══════════════════════════════════════════════════════
   SERVICE FINDER BUTTON (hero)
   ═══════════════════════════════════════════════════════ */
.corp-finder-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(0,102,255,0.07);
  border: 1px solid rgba(0,102,255,0.22);
  border-radius: var(--r-full);
  color: var(--c-text-1);
  font-size: 0.88rem;
  font-weight: 600;
  padding: 11px 20px 11px 18px;
  cursor: pointer;
  transition: var(--t-base);
  margin-top: 22px;
  letter-spacing: 0.01em;
  position: relative;
  overflow: hidden;
}
.corp-finder-btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(0,102,255,0.12), rgba(124,58,237,0.12));
  opacity: 0;
  transition: opacity 0.3s;
}
.corp-finder-btn:hover { border-color: rgba(0,102,255,0.5); transform: translateY(-2px); box-shadow: 0 6px 24px rgba(0,102,255,0.2); }
.corp-finder-btn:hover::before { opacity: 1; }
.corp-finder-btn__pill {
  background: rgba(0,102,255,0.18);
  color: #60a5fa;
  font-size: 0.7rem;
  font-weight: 800;
  padding: 2px 9px;
  border-radius: var(--r-full);
  letter-spacing: 0.04em;
}
.corp-finder-btn__arrow { transition: transform 0.25s; }
.corp-finder-btn:hover .corp-finder-btn__arrow { transform: translateX(4px); }

/* ═══════════════════════════════════════════════════════
   SERVICE FINDER MODAL
   ═══════════════════════════════════════════════════════ */
.corp-finder-modal .modal-content {
  background: var(--c-bg-2);
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-xl);
  box-shadow: 0 48px 120px rgba(0,0,0,0.85), 0 0 0 1px rgba(255,255,255,0.04);
  overflow: hidden;
}
.corp-finder-modal .modal-header {
  background: linear-gradient(135deg, #050f28 0%, #0a1e45 60%, #0d1e38 100%);
  border-bottom: 1px solid var(--c-border);
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  align-items: flex-start;
}
.corp-finder-modal .modal-header::before {
  content: '';
  position: absolute; top: -80px; right: -80px;
  width: 260px; height: 260px;
  background: radial-gradient(circle, rgba(0,102,255,0.18) 0%, transparent 70%);
  pointer-events: none;
}
.corp-finder-modal .modal-header::after {
  content: '';
  position: absolute; bottom: -40px; left: 30%;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(124,58,237,0.12) 0%, transparent 70%);
  pointer-events: none;
}
.corp-finder__header-content { flex: 1; position: relative; z-index: 1; }
.corp-finder__tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(0,102,255,0.14);
  border: 1px solid rgba(0,102,255,0.28);
  border-radius: var(--r-full);
  color: #93c5fd;
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.09em; text-transform: uppercase;
  padding: 4px 14px;
  margin-bottom: 14px;
}
.corp-finder__tag i { font-size: 0.8rem; }
.corp-finder__h {
  font-size: clamp(1.25rem, 2.8vw, 1.7rem);
  font-weight: 900;
  color: var(--c-text-1);
  margin: 0 0 10px;
  letter-spacing: -0.025em;
  line-height: 1.2;
}
.corp-finder__sub {
  font-size: 0.875rem; color: var(--c-text-2); margin: 0;
}
.corp-finder-modal .btn-close {
  filter: invert(1) opacity(0.5);
  transition: opacity 0.2s;
  flex-shrink: 0;
  margin-top: 4px;
}
.corp-finder-modal .btn-close:hover { opacity: 1; filter: invert(1) opacity(0.9); }
.corp-finder-modal .modal-body { padding: 28px 32px 24px; background: var(--c-bg-2); }

/* Card grid */
.corp-finder__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.corp-finder__card {
  background: var(--c-bg-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: 22px 18px 20px;
  cursor: pointer;
  text-decoration: none !important;
  color: inherit;
  transition: var(--t-base);
  display: flex; flex-direction: column; gap: 10px;
  position: relative; overflow: hidden;
}
.corp-finder__card::before {
  content: '';
  position: absolute; inset: 0;
  background: var(--card-glow, rgba(0,102,255,0.05));
  opacity: 0; transition: opacity 0.35s;
}
.corp-finder__card:hover {
  transform: translateY(-5px);
  border-color: var(--card-accent, rgba(0,102,255,0.4));
  box-shadow: 0 20px 50px rgba(0,0,0,0.55);
  color: inherit;
  text-decoration: none;
}
.corp-finder__card:hover::before { opacity: 1; }
.corp-finder__icon-wrap {
  width: 50px; height: 50px;
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.45rem;
  background: var(--card-icon-bg, rgba(0,102,255,0.1));
  transition: transform 0.3s, box-shadow 0.3s;
  position: relative; z-index: 1;
}
.corp-finder__card:hover .corp-finder__icon-wrap {
  transform: scale(1.1) rotate(-3deg);
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.corp-finder__name {
  font-size: 0.875rem; font-weight: 800;
  color: var(--c-text-1); line-height: 1.3;
  position: relative; z-index: 1;
}
.corp-finder__desc {
  font-size: 0.75rem; color: var(--c-text-2);
  line-height: 1.55; flex: 1;
  position: relative; z-index: 1;
}
.corp-finder__arrow {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.76rem; font-weight: 700;
  color: var(--card-color, var(--c-blue-light));
  opacity: 0; transform: translateY(4px);
  transition: all 0.22s;
  position: relative; z-index: 1;
}
.corp-finder__card:hover .corp-finder__arrow { opacity: 1; transform: none; }

/* Modal footer */
.corp-finder-modal .modal-footer {
  background: var(--c-bg-1);
  border-top: 1px solid var(--c-border);
  padding: 16px 32px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.corp-finder__footer-text {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.8rem; color: var(--c-text-2); flex: 1;
}

/* Responsive */
@media (max-width: 991.98px) {
  .corp-finder__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575.98px) {
  .corp-finder-modal .modal-header { padding: 22px 18px 18px; }
  .corp-finder-modal .modal-body { padding: 16px; }
  .corp-finder__grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .corp-finder__card { padding: 16px 13px 14px; }
  .corp-finder-modal .modal-footer { padding: 14px 16px; flex-direction: column; }
  .corp-finder__footer-text { text-align: center; }
}

/* ═══════════════════════════════════════════════════════
   CASOS DE ÉXITO — v4.0 supplementary (legacy removed)
   ═══════════════════════════════════════════════════════ */
/* Responsive KPI on very small screens */
@media (max-width: 380px) {
  .corp-case-card__kpi-val { font-size: 1.1rem; }
  .corp-case-card__kpi-lbl { font-size: 0.52rem; }
  .corp-cases__meta { gap: 12px; font-size: 0.72rem; }
}

@media (max-width: 575px) {
  .corp-modal__deliverables { grid-template-columns: 1fr; }
  .corp-modal .modal-body { padding: 20px; }
  .corp-modal .modal-header { padding: 18px 20px; }
  .corp-modal__metrics { grid-template-columns: repeat(2, 1fr); }
}

/* ─── Section separators ─────────────────────────── */
.corp-about      { border-top: 1px solid var(--c-border); }
.corp-process    { border-top: 1px solid var(--c-border); border-bottom: 1px solid var(--c-border); }
.corp-projects   { border-top: 1px solid var(--c-border); }
.corp-cases      { border-top: 1px solid var(--c-border); }

/* ─── Hero floating metric cards ──────────────────── */
.corp-hero__float-card {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(8,21,40,0.88);
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-lg);
  padding: 12px 16px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.45);
  z-index: 3;
  animation: heroFloat 6s ease-in-out infinite;
}
.corp-hero__float-card--tl {
  top: 18%;
  left: -40px;
  animation-delay: -2s;
}
.corp-hero__float-card--br {
  bottom: 22%;
  right: -30px;
  animation-delay: -4s;
}
.corp-hero__float-dot {
  width: 8px; height: 8px;
  background: var(--c-green);
  border-radius: 50%;
  flex-shrink: 0;
  animation: pulseDot 2s ease-in-out infinite;
  box-shadow: 0 0 8px var(--c-green);
}
.corp-hero__float-val {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--c-text-1);
  line-height: 1;
  background: var(--g-text-cyan);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.corp-hero__float-lbl {
  font-size: 0.68rem;
  color: var(--c-text-2);
  font-weight: 500;
  margin-top: 2px;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════
   PROJECTS — white background (natural card styles apply)
   ═══════════════════════════════════════════════════════ */
.corp-projects .corp-project-card {
  border-color: var(--c-border-light);
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.corp-projects .corp-project-card:hover {
  box-shadow: 0 16px 48px rgba(0,0,0,0.14), 0 0 0 1px rgba(0,102,255,0.12);
}
.corp-projects .corp-project-card:hover .corp-project-card__body {
  border-top-color: var(--c-blue);
}

/* ═══════════════════════════════════════════════════════
   CASO DE ÉXITO — Detail Modal
   ═══════════════════════════════════════════════════════ */
.corp-casemodal-wrapper .modal-content {
  background: #0d1828;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--r-xl);
  overflow: hidden;
}

/* Accent header */
.corp-casemodal__head {
  --cm-accent: #0066ff;
  background: linear-gradient(135deg, #080f1c 0%, #0d1828 60%, color-mix(in srgb, var(--cm-accent) 12%, #0d1828) 100%);
  padding: 36px 36px 28px;
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.corp-casemodal__head::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 4px;
  background: var(--cm-accent);
}

.corp-casemodal__sector-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--r-full);
  font-size: 0.65rem; font-weight: 700;
  color: var(--c-text-2);
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 14px;
  margin-bottom: 18px;
}
.corp-casemodal__sector-badge i { color: var(--cm-accent); font-size: 0.75rem; }

.corp-casemodal__logo-box {
  background: rgba(255,255,255,0.94);
  border-radius: var(--r-md);
  padding: 10px 20px;
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 130px; height: 56px;
  margin-bottom: 18px;
}

.corp-casemodal__title {
  font-size: 1.35rem; font-weight: 800;
  color: var(--c-text-1);
  margin: 0;
}

/* Body */
.corp-casemodal__body { padding: 30px 36px 24px; }

.corp-casemodal__block {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--r-lg);
  padding: 20px;
  height: 100%;
}
.corp-casemodal__block-icon {
  width: 32px; height: 32px;
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.07);
  margin-bottom: 10px;
  font-size: 0.9rem;
}
.corp-casemodal__block--challenge .corp-casemodal__block-icon i { color: #f59e0b; }
.corp-casemodal__block--solution  .corp-casemodal__block-icon i { color: #10b981; }
.corp-casemodal__block-ttl {
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--c-text-2);
  margin-bottom: 8px;
}
.corp-casemodal__block-txt {
  font-size: 0.86rem; line-height: 1.8;
  color: var(--c-text-2);
  margin: 0;
}

/* Stats strip */
.corp-casemodal__stats {
  display: flex; gap: 0;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--r-lg);
  margin: 20px 0;
  overflow: hidden;
}
.corp-casemodal__stat {
  flex: 1; padding: 16px 12px;
  text-align: center;
  border-right: 1px solid rgba(255,255,255,0.07);
}
.corp-casemodal__stat:last-child { border-right: none; }
.corp-casemodal__stat-val {
  font-size: 1.45rem; font-weight: 900;
  line-height: 1;
}
.corp-casemodal__stat-lbl {
  font-size: 0.62rem; font-weight: 600;
  color: var(--c-text-3); text-transform: uppercase;
  letter-spacing: 0.06em; margin-top: 4px;
}

/* Result paragraph */
.corp-casemodal__result-block {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--r-lg);
  padding: 16px 20px;
  font-size: 0.86rem; line-height: 1.8;
  color: var(--c-text-2);
  margin-bottom: 20px;
  display: flex; gap: 10px; align-items: flex-start;
}
.corp-casemodal__result-block i { font-size: 1rem; margin-top: 2px; flex-shrink: 0; }

/* Tech stack */
.corp-casemodal__techs-wrap { margin-bottom: 8px; }
.corp-casemodal__techs-ttl {
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--c-text-2);
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}
.corp-casemodal__techs { display: flex; flex-wrap: wrap; gap: 7px; }
.corp-casemodal__tech {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r-full);
  font-size: 0.67rem; font-weight: 700;
  color: var(--c-text-1);
  padding: 4px 12px;
  letter-spacing: 0.04em;
}

/* Footer */
.corp-casemodal__footer {
  background: rgba(255,255,255,0.03);
  border-top: 1px solid rgba(255,255,255,0.07) !important;
  padding: 16px 36px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.corp-casemodal__footer-txt {
  font-size: 0.82rem;
  color: var(--c-text-2);
  flex: 1;
}

/* Mobile adjustments */
@media (max-width: 767px) {
  .corp-casemodal__head { padding: 28px 20px 22px; }
  .corp-casemodal__body { padding: 22px 20px 20px; }
  .corp-casemodal__footer { padding: 14px 20px; }
  .corp-casemodal__stats { flex-wrap: wrap; }
  .corp-casemodal__stat { min-width: 50%; border-bottom: 1px solid rgba(255,255,255,0.07); }
  .corp-casemodal__title { font-size: 1.1rem; }
}

/* ═══════════════════════════════════════════════════════
   HOW WE WORK — PROCESS STEPS
   ═══════════════════════════════════════════════════════ */
/* ════ PROCESS SECTION — light grey background ════ */
.corp-process {
  background: var(--c-bg-light);
  position: relative;
}
.corp-process::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,102,255,0.25) 50%, transparent);
}
.corp-process .corp-lead    { color: var(--c-text-muted) !important; }

.corp-process__steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  position: relative;
}
.corp-process__steps::before {
  content: '';
  position: absolute;
  top: 39px;
  left: calc(12.5% + 4px);
  right: calc(12.5% + 4px);
  height: 2px;
  background: linear-gradient(90deg, var(--c-blue) 0%, var(--c-violet) 50%, var(--c-cyan) 100%);
  opacity: 0.45;   /* more visible on light bg */
  z-index: 0;
}
.corp-process__step {
  text-align: center;
  padding: 0 12px;
  position: relative;
  z-index: 1;
}
.corp-process__step-num {
  width: 80px; height: 80px;
  background: #ffffff;          /* white circle on light bg */
  border: 2px solid rgba(0,102,255,0.18);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 28px;
  position: relative;
  transition: var(--t-base);
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
.corp-process__step:hover .corp-process__step-num {
  background: var(--g-primary);
  border-color: transparent;
  box-shadow: 0 0 36px rgba(0,102,255,0.35);
}
.corp-process__step-num i {
  font-size: 1.55rem;
  color: var(--c-blue);
  transition: color 0.3s;
}
.corp-process__step:hover .corp-process__step-num i { color: #fff; }
.corp-process__step-badge {
  position: absolute;
  top: -10px; right: -8px;
  width: 24px; height: 24px;
  background: var(--g-blue-violet);
  border-radius: 50%;
  font-size: 0.65rem;
  font-weight: 800;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.corp-process__step-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--c-text-dark);   /* dark text on light bg */
  margin-bottom: 12px;
  line-height: 1.3;
}
.corp-process__step-desc {
  font-size: 0.81rem;
  line-height: 1.75;
  color: var(--c-text-muted);  /* readable on light bg */
}

/* ═══════════════════════════════════════════════════════
   TECH STACK SECTION
   ═══════════════════════════════════════════════════════ */
/* Tech: dark section with subtle dot grid — visually breaks up the navy */
.corp-tech {
  background: var(--c-bg-2);
  position: relative;
}
.corp-tech::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(124,58,237,0.12) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
}
.corp-tech > .container { position: relative; z-index: 1; }

/* Category row label — full-width inside flex */
.corp-tech__cat {
  width: 100%;
  font-size: 0.65rem;
  font-weight: 800;
  color: var(--c-blue-light);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 20px 2px 8px;
  border-bottom: 1px solid var(--c-border);
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.corp-tech__cat:first-child { padding-top: 0; }
.corp-tech__cat i { font-size: 0.85rem; }

.corp-tech__items {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.corp-tech__item {
  flex: 0 0 118px;
  width: 118px;
  background: var(--c-bg-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: 22px 10px 16px;
  text-align: center;
  transition: var(--t-base);
  cursor: default;
  position: relative;
  overflow: hidden;
}
.corp-tech__item:hover {
  background: var(--c-bg-4);
  border-color: var(--c-border-blue);
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.4);
}
.corp-tech__icon {
  font-size: 2rem;
  margin-bottom: 10px;
  display: block;
  line-height: 1;
  transition: transform 0.3s ease;
}
.corp-tech__item:hover .corp-tech__icon { transform: scale(1.15); }
.corp-tech__name {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--c-text-2);
  letter-spacing: 0.02em;
  display: block;
  transition: color 0.25s;
  line-height: 1.3;
}
.corp-tech__item:hover .corp-tech__name { color: var(--c-text-1); }

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
@media (max-width: 991.98px) {
  .corp-hero { padding-top: 100px; min-height: auto; padding-bottom: 60px; }
  .corp-hero__img-wrap { margin-top: 48px; }
  .corp-hero__img { width: 360px; }
  .corp-section { padding: 72px 0; }
  .corp-stats__item { border-right: none; border-bottom: 1px solid var(--c-border); padding: 16px 0; }
  .corp-stats__item:last-child { border-bottom: none; }
  .corp-cta__btns { flex-direction: column; align-items: center; }
  .corp-footer__bottom { flex-direction: column; text-align: center; }
  .corp-process__steps { grid-template-columns: repeat(2, 1fr); gap: 40px; }
  .corp-process__steps::before { display: none; }
  .corp-tech__item { flex: 0 0 100px; width: 100px; }
  .corp-hero__float-card { display: none; }
}

@media (max-width: 575.98px) {
  .corp-hero__h1 { font-size: 2rem !important; }
  .corp-hero__img { width: 280px; }
  .corp-h2 { font-size: 1.7rem !important; }
  .corp-tabs .nav-link { font-size: 0.75rem !important; padding: 7px 12px !important; }
  .corp-service-card { padding: 20px; }
  .corp-process__steps { grid-template-columns: 1fr 1fr; gap: 28px; }
  .corp-tech__item { flex: 0 0 88px; width: 88px; padding: 16px 8px 12px; }
  .corp-tech__icon { font-size: 1.6rem; }
}

/* ═══════════════════════════════════════════════════════
   THEME TOGGLE BUTTON
   ═══════════════════════════════════════════════════════ */
.corp-theme-toggle {
  width: 36px; height: 36px;
  border-radius: var(--r-full);
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.07);
  color: rgba(255,255,255,0.8);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.88rem;
  transition: var(--t-fast);
  flex-shrink: 0;
  margin-left: 8px;
}
.corp-theme-toggle:hover {
  background: rgba(0,102,255,0.18);
  border-color: rgba(0,102,255,0.5);
  color: #60a5fa;
  transform: rotate(20deg);
}

/* ── Light mode overrides ─────────────────────────────── */
body.site-light .corp-nav {
  background: rgba(255,255,255,0.96) !important;
  box-shadow: 0 2px 24px rgba(0,0,0,0.08);
}
body.site-light .corp-nav.scrolled {
  background: rgba(255,255,255,0.99) !important;
  backdrop-filter: blur(24px);
}
body.site-light .corp-nav .nav-link { color: #334155 !important; }
body.site-light .corp-nav .nav-link:hover,
body.site-light .corp-nav .nav-link:focus { color: var(--c-blue) !important; background: rgba(0,102,255,0.06); }
body.site-light .corp-nav .dropdown-menu { background: rgba(255,255,255,0.99); }
body.site-light .corp-nav .dropdown-item { color: #334155 !important; }
body.site-light .corp-nav .dropdown-item:hover { background: rgba(0,102,255,0.08) !important; color: var(--c-blue) !important; }
body.site-light .corp-theme-toggle {
  border-color: rgba(0,0,0,0.12);
  background: rgba(0,0,0,0.04);
  color: #334155;
}
body.site-light .corp-theme-toggle:hover {
  background: rgba(0,102,255,0.1);
  border-color: rgba(0,102,255,0.35);
  color: var(--c-blue);
}
body.site-light .corp-hero__img {
  filter: drop-shadow(0 20px 60px rgba(0,102,255,0.18)) brightness(1.04);
}
body.site-light .corp-hero__orbit { border-color: rgba(0,102,255,0.18); }
body.site-light .corp-hero__img-glow {
  background: radial-gradient(circle, rgba(0,102,255,0.14) 0%, rgba(124,58,237,0.07) 40%, transparent 70%);
}

/* ═══════════════════════════════════════════════════════
   HERO GLOBE — Orbital rings
   ═══════════════════════════════════════════════════════ */
.corp-hero__orbit {
  position: absolute;
  border-radius: 50%;
  border: 1px dashed rgba(0,102,255,0.28);
  pointer-events: none;
  z-index: 0;
}
.corp-hero__orbit--1 {
  width: 400px; height: 400px;
  animation: orbitSpin 12s linear infinite;
}
.corp-hero__orbit--2 {
  width: 500px; height: 500px;
  border-color: rgba(124,58,237,0.18);
  animation: orbitSpin 20s linear infinite reverse;
}
.corp-hero__orbit--3 {
  width: 300px; height: 300px;
  border-color: rgba(0,217,255,0.2);
  animation: orbitSpin 8s linear infinite;
}
/* Glowing dot on each orbit */
.corp-hero__orbit::before {
  content: '';
  position: absolute;
  width: 8px; height: 8px;
  border-radius: 50%;
  top: -4px; left: 50%;
  transform: translateX(-50%);
}
.corp-hero__orbit--1::before {
  background: var(--c-blue);
  box-shadow: 0 0 10px var(--c-blue), 0 0 20px rgba(0,102,255,0.4);
}
.corp-hero__orbit--2::before {
  background: var(--c-violet);
  box-shadow: 0 0 10px var(--c-violet), 0 0 20px rgba(124,58,237,0.4);
}
.corp-hero__orbit--3::before {
  background: var(--c-cyan);
  box-shadow: 0 0 10px var(--c-cyan);
  width: 6px; height: 6px; top: -3px;
}
@keyframes orbitSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* ═══════════════════════════════════════════════════════
   CODING ANIMATION — "Soluciones Tecnológicas"
   ═══════════════════════════════════════════════════════ */
.corp-code-terminal {
  background: #0d1117;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 14px;
  font-family: 'Fira Code', 'Cascadia Code', 'Consolas', monospace;
  font-size: 0.76rem;
  box-shadow: 0 8px 32px rgba(0,0,0,0.45), 0 0 0 1px rgba(0,102,255,0.12);
}
.corp-code-terminal__bar {
  background: #161b22;
  padding: 8px 14px;
  display: flex; align-items: center; gap: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.corp-code-terminal__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--d, #555);
  flex-shrink: 0;
}
.corp-code-terminal__filename {
  font-size: 0.68rem;
  color: rgba(255,255,255,0.35);
  margin-left: 4px;
  letter-spacing: 0.04em;
}
.corp-code-terminal__body {
  padding: 12px 16px;
  line-height: 1.9;
}
/* Each line animates in sequentially */
.corp-code-terminal__line {
  opacity: 0;
  white-space: pre;
  overflow: hidden;
  max-width: 0;
  animation: codeReveal 0.6s ease forwards;
}
.corp-code-line--1 { animation-delay: 0.3s; }
.corp-code-line--2 { animation-delay: 0.9s; }
.corp-code-line--3 { animation-delay: 1.5s; }
.corp-code-line--4 { animation-delay: 2.1s; }
.corp-code-line--5 { animation-delay: 2.7s; }
@keyframes codeReveal {
  from { opacity: 0; max-width: 0; }
  to   { opacity: 1; max-width: 320px; }
}
/* Blinking cursor on last line */
.corp-code-terminal__cursor {
  display: inline-block;
  width: 2px; height: 0.9em;
  background: var(--c-blue);
  vertical-align: middle;
  margin-left: 2px;
  animation: blink 1s step-end infinite;
  opacity: 0;
  animation-delay: 3.4s;
}
@keyframes blink {
  0%,100% { opacity: 1; }
  50%      { opacity: 0; }
}
/* Syntax colours */
.ct-kw   { color: #ff7b72; }  /* keyword — red */
.ct-fn   { color: #d2a8ff; }  /* function — purple */
.ct-str  { color: #a5d6ff; }  /* string — blue */
.ct-var  { color: #ffa657; }  /* variable — orange */
.ct-prop { color: #79c0ff; }  /* property — cyan */
.ct-op   { color: #ff7b72; }  /* operator */
.ct-comment { color: #8b949e; font-style: italic; } /* comment */
.ct-punct{ color: #e6edf3; }  /* punctuation */

/* ═══════════════════════════════════════════════════════
   DESIGN UPGRADE — v4.0 — Premium Enhancement Layer
   ═══════════════════════════════════════════════════════ */

/* ── 1. EXPANDED TOKEN SET ──────────────────────────── */
:root {
  /* Display font for headings */
  --font-display: 'Plus Jakarta Sans', 'Inter', -apple-system, sans-serif;

  /* Inset highlight tokens */
  --inset-top:        inset 0 1px 0 rgba(255,255,255,0.07);
  --inset-top-strong: inset 0 1px 0 rgba(255,255,255,0.13);
  --inset-rim:        inset 0 0 0 1px rgba(255,255,255,0.06);

  /* Premium card shadows */
  --s-card-dark:  0 4px 24px rgba(0,0,0,0.35), var(--inset-top);
  --s-card-lift:  0 20px 60px rgba(0,0,0,0.5),  var(--inset-top-strong);

  /* Colour glows */
  --s-glow-blue-soft:   0 0 48px rgba(0,102,255,0.18);
  --s-glow-violet-soft: 0 0 48px rgba(124,58,237,0.18);
}

/* ── 2. DISPLAY FONT — headings & titles ──────────────── */
.corp-hero__h1,
.corp-h2,
.corp-cta__h2,
.corp-service-card__title,
.corp-case-card__title,
.corp-testi-card__name,
.corp-metric-card__num,
.corp-stats__num,
.corp-pricing-card__head h4 {
  font-family: var(--font-display) !important;
}

/* ── 3. HERO IMPROVEMENTS ───────────────────────────── */
/* Dot grid — focus toward globe (right side), fade left */
.corp-hero::before {
  background-image: radial-gradient(rgba(0,102,255,0.2) 1px, transparent 1px);
  background-size: 30px 30px;
  opacity: 0.55;
  mask-image: radial-gradient(ellipse 75% 70% at 68% 48%, black 20%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 75% 70% at 68% 48%, black 20%, transparent 75%);
}

/* Stronger orbs — more chromatic */
.corp-hero__orb-1 {
  background: radial-gradient(ellipse, rgba(124,58,237,0.32) 0%, rgba(0,102,255,0.16) 38%, transparent 66%);
}
.corp-hero__orb-2 {
  background: radial-gradient(ellipse, rgba(6,182,212,0.26) 0%, rgba(0,102,255,0.12) 42%, transparent 66%);
}

/* Badge — glass refinement */
.corp-hero__badge {
  background: linear-gradient(135deg, rgba(0,102,255,0.13), rgba(124,58,237,0.07));
  border-color: rgba(99,102,241,0.38);
  box-shadow: 0 0 24px rgba(0,102,255,0.1), var(--inset-top);
  padding: 7px 20px;
  letter-spacing: 0.07em;
}

/* Richer hero headline gradient */
.corp-hero__h1 .grad-text {
  background: linear-gradient(135deg, #7dd3fc 0%, #c4b5fd 45%, #22d3ee 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Better hero description text */
.corp-hero__p {
  font-size: 1.07rem !important;
  color: rgba(148,163,184,0.92) !important;
}

/* ── 4. SECTION HEADING UPGRADE ─────────────────────── */
.corp-h2 {
  font-size: clamp(1.95rem, 4vw, 3.1rem) !important;
  letter-spacing: -0.028em !important;
}
.corp-h2 .grad {
  background: linear-gradient(135deg, #7dd3fc 0%, #c4b5fd 50%, #34d399 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.corp-h2 .grad-b {
  background: linear-gradient(135deg, #60a5fa 0%, #a78bfa 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── 5. EYEBROW UPGRADE ──────────────────────────────── */
.corp-eyebrow {
  font-size: 0.72rem;
  letter-spacing: 0.13em;
  background: linear-gradient(135deg, #60a5fa, #a78bfa);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 14px;
}
.corp-eyebrow::before {
  content: '';
  width: 20px; height: 2px;
  background: linear-gradient(90deg, #60a5fa, #a78bfa);
  border-radius: var(--r-full);
  opacity: 1;
}

/* ── 6. SHIMMER BUTTON ───────────────────────────────── */
@keyframes btnShimmer {
  from { transform: translateX(-120%) skewX(-15deg); }
  to   { transform: translateX(300%)  skewX(-15deg); }
}
.corp-btn-primary::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 45%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.22), transparent);
  transform: translateX(-120%) skewX(-15deg);
  pointer-events: none;
  border-radius: inherit;
}
.corp-btn-primary:hover::before {
  animation: btnShimmer 0.65s ease forwards;
}
.corp-btn-primary:active {
  transform: translateY(0px) scale(0.98) !important;
  box-shadow: 0 4px 16px rgba(0,102,255,0.3) !important;
}

/* Outline button upgrade */
.corp-btn-outline:hover {
  border-color: rgba(99,102,241,0.45) !important;
  background: rgba(99,102,241,0.07) !important;
  color: #c4b5fd !important;
}

/* ── 7. STATS BAR UPGRADE ────────────────────────────── */
.corp-stats {
  background: linear-gradient(180deg, var(--c-bg-2) 0%, rgba(3,15,38,0.97) 100%);
  box-shadow: var(--inset-top);
}
.corp-stats__num {
  font-size: 2.7rem;
  background: linear-gradient(135deg, #7dd3fc 0%, #a78bfa 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.corp-stats__label {
  font-size: 0.74rem;
  letter-spacing: 0.1em;
}

/* ── 8. SERVICE CARDS ────────────────────────────────── */
.corp-service-card {
  box-shadow: 0 2px 10px rgba(0,0,0,0.06);
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1),
              box-shadow 0.3s cubic-bezier(0.4,0,0.2,1),
              border-color 0.3s ease !important;
}
.corp-service-card:hover {
  transform: translateY(-7px) !important;
  box-shadow: 0 14px 44px rgba(0,0,0,0.13),
              0 0 0 1px var(--sc-tint, rgba(0,102,255,0.15)) !important;
}

/* Service card title font size */
.corp-service-card__title {
  font-size: 0.97rem !important;
  letter-spacing: -0.01em;
}

/* ── 9. DARK CARDS DEPTH ─────────────────────────────── */
.corp-case-card {
  box-shadow: var(--s-card-dark);
}
.corp-case-card:hover {
  box-shadow: var(--s-card-lift),
              0 0 0 1px var(--cc-border) !important;
}

/* Metric cards */
.corp-about .corp-metric-card {
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1),
              box-shadow 0.3s ease,
              border-color 0.3s ease;
}
.corp-about .corp-metric-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 36px rgba(0,102,255,0.13),
              0 0 0 1px rgba(0,102,255,0.14);
}

/* ── 10. TESTIMONIALS ────────────────────────────────── */
.corp-testi-card {
  box-shadow: 0 2px 16px rgba(0,0,0,0.07);
}
.corp-testi-card:hover {
  box-shadow: 0 16px 52px rgba(0,102,255,0.11),
              0 0 0 1px rgba(0,102,255,0.09) !important;
}
.corp-testi-card__quote {
  font-size: 3.5rem;
  opacity: 0.18;
}

/* ── 11. PRICING CARDS ───────────────────────────────── */
.corp-pricing-card:hover {
  box-shadow: 0 18px 52px rgba(0,102,255,0.13),
              0 0 0 1px rgba(0,102,255,0.11) !important;
}

/* ── 12. FAQ ACCORDION ───────────────────────────────── */
.corp-accordion .accordion-item:hover {
  box-shadow: 0 4px 20px rgba(0,102,255,0.08),
              0 0 0 1px rgba(0,102,255,0.06);
}
.corp-accordion .accordion-button:not(.collapsed) {
  color: var(--c-blue) !important;
  background: linear-gradient(135deg, rgba(0,102,255,0.05), rgba(124,58,237,0.03)) !important;
}

/* ── 13. CTA SECTION ─────────────────────────────────── */
.corp-cta::before {
  background: radial-gradient(ellipse 70% 80% at 50% 50%,
    rgba(0,102,255,0.14) 0%,
    rgba(124,58,237,0.06) 50%,
    transparent 70%);
}
.corp-cta__inner {
  background: rgba(255,255,255,0.025) !important;
  box-shadow: 0 0 120px rgba(0,102,255,0.08),
              var(--inset-rim),
              var(--inset-top) !important;
}

/* ── 14. TECH GRID ITEM ──────────────────────────────── */
.corp-tech__item:hover {
  background: rgba(255,255,255,0.08) !important;
  box-shadow: 0 8px 28px rgba(0,0,0,0.3),
              var(--inset-top) !important;
  transform: translateY(-5px) scale(1.04) !important;
}

/* ── 15. TABS CONTAINER ──────────────────────────────── */
.corp-tabs {
  box-shadow: 0 2px 16px rgba(0,0,0,0.07), var(--inset-top) !important;
}

/* ── 16. FOOTER GRADIENT BAR ─────────────────────────── */
.corp-footer::before {
  height: 3px;
  background: linear-gradient(90deg, #0066ff 0%, #7c3aed 50%, #06b6d4 100%);
  opacity: 0.9;
}

/* Nicer social icon hover */
.corp-footer__social a:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 4px 12px rgba(0,102,255,0.25);
}

/* ── 17. PROCESS SECTION ─────────────────────────────── */
.corp-process__step-num {
  font-family: var(--font-display);
}

/* ── 18. PROJECT CARDS ───────────────────────────────── */
.corp-project-card:hover {
  box-shadow: 0 18px 48px rgba(0,0,0,0.16),
              0 0 0 1px rgba(0,102,255,0.08) !important;
}

/* ── 19. SCROLLBAR REFINEMENT ────────────────────────── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--c-bg-0); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #0066ff 0%, #7c3aed 100%);
  border-radius: var(--r-full);
}

/* ── 20. FOCUS RINGS ─────────────────────────────────── */
:focus-visible {
  outline: 2px solid rgba(0,102,255,0.65);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ── 21. TEXT SELECTION ──────────────────────────────── */
::selection {
  background: rgba(99,102,241,0.28);
  color: #fff;
}

/* ── 22. SCROLL REVEAL — smoother easing ─────────────── */
.corp-reveal {
  transform: translateY(20px);
  transition: opacity 0.55s ease, transform 0.6s cubic-bezier(0.22,1,0.36,1);
}

/* ── 23. NAVBAR CTA — stronger glow ──────────────────── */
.corp-nav .btn-nav-cta:hover {
  box-shadow: 0 12px 36px rgba(0,102,255,0.5) !important;
  transform: translateY(-2px) scale(1.02) !important;
}

/* ── 24. HERO TRUST ITEMS ────────────────────────────── */
.corp-hero__trust-item i {
  font-size: 1.05rem;
  filter: drop-shadow(0 0 6px rgba(16,185,129,0.5));
}

/* ── 25. ABOUT PANEL REFINEMENT ──────────────────────── */
.corp-about__panel {
  box-shadow: 0 4px 24px rgba(0,0,0,0.07),
              0 0 0 1px rgba(0,102,255,0.06);
}

/* ── 26. SECTION SURFACE — subtle top gradient ────────── */
.corp-section--surface {
  background: linear-gradient(180deg, #eef2f9 0%, var(--c-bg-light) 100%);
}

/* ── 27. TRUSTED SECTION — refined edges ─────────────── */
.corp-trusted__track-wrap {
  mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}

/* ── 28. RESPONSIVE FONT TIGHTENING ──────────────────── */
@media (max-width: 575.98px) {
  .corp-hero__h1 { font-size: 2.1rem !important; letter-spacing: -0.025em !important; }
  .corp-h2 { font-size: 1.75rem !important; }
  .corp-btn-primary, .corp-btn-outline { font-size: 0.85rem !important; padding: 11px 22px !important; }
}
@media (max-width: 991.98px) {
  :root { --section-py: 80px; }
  .corp-h2 { font-size: clamp(1.7rem, 4.5vw, 2.4rem) !important; }
}

/* ═══════════════════════════════════════════════════════
   GLOBAL FIXES & ENHANCEMENTS  v4.1
   ═══════════════════════════════════════════════════════ */

/* ── Testimonials: BI star icons + company badge ────── */
.corp-testi-card__stars i {
  color: #f59e0b;
  font-size: 0.82rem;
}
.corp-testi-card__company {
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: 5px;
  font-size: 0.7rem; font-weight: 600;
  color: var(--c-blue);
  background: rgba(0,102,255,0.06);
  border: 1px solid rgba(0,102,255,0.14);
  border-radius: var(--r-full);
  padding: 2px 9px;
  letter-spacing: 0.03em;
}
.corp-testi-card__company i { font-size: 0.65rem; }

/* ── CTA trust row + availability ───────────────────── */
.corp-cta__trust {
  display: flex; gap: 24px;
  justify-content: center; flex-wrap: wrap;
  margin-top: 28px; padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 0.8rem; color: var(--c-text-2);
}
.corp-cta__trust span { display: inline-flex; align-items: center; gap: 6px; }
.corp-cta__trust i { color: var(--c-green); }
.corp-cta__avail {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 16px;
  font-size: 0.8rem; color: var(--c-text-2);
}
.corp-cta__avail-dot {
  width: 8px; height: 8px; flex-shrink: 0;
  background: var(--c-green); border-radius: 50%;
  animation: availPulse 2s ease-in-out infinite;
}
@keyframes availPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(16,185,129,0.55); }
  60%     { box-shadow: 0 0 0 5px rgba(16,185,129,0); }
}

/* ── FAQ accordion icons ─────────────────────────────── */
.corp-accordion .accordion-button i.faq-icon {
  color: var(--c-blue);
  margin-right: 10px;
  font-size: 1rem;
  flex-shrink: 0;
  transition: color 0.2s;
}
.corp-accordion .accordion-button:not(.collapsed) i.faq-icon { color: #fff; }

/* ── Floating WhatsApp button ───────────────────────── */
#wa-float {
  position: fixed;
  bottom: 28px; right: 28px;
  z-index: 9900;
  width: 56px; height: 56px;
  background: #25d366;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 1.55rem;
  text-decoration: none;
  box-shadow: 0 4px 24px rgba(37,211,102,0.45);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
#wa-float:hover {
  transform: scale(1.1) translateY(-2px);
  box-shadow: 0 8px 32px rgba(37,211,102,0.62);
  color: #fff;
}
#wa-float::before {
  content: '';
  position: absolute; inset: -1px;
  border-radius: 50%;
  border: 2px solid rgba(37,211,102,0.55);
  animation: waPulse 2.5s ease-in-out infinite;
}
@keyframes waPulse {
  0%   { transform: scale(1);    opacity: 0.7; }
  70%  { transform: scale(1.55); opacity: 0; }
  100% { transform: scale(1.55); opacity: 0; }
}

/* ── Scroll progress bar ────────────────────────────── */
#scrollProgress {
  position: fixed;
  top: 0; left: 0;
  height: 3px; width: 0%;
  background: linear-gradient(90deg, var(--c-blue) 0%, var(--c-violet) 50%, var(--c-cyan) 100%);
  z-index: 99999;
  pointer-events: none;
  transition: width 0.08s linear;
}

/* ── Back-to-top button ─────────────────────────────── */
#backToTop {
  position: fixed;
  bottom: 96px; right: 28px;
  z-index: 9800;
  width: 42px; height: 42px;
  background: rgba(8,21,40,0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(0,102,255,0.25);
  border-radius: var(--r-md);
  color: var(--c-text-2);
  font-size: 1.3rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transform: translateY(12px);
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}
#backToTop.visible {
  opacity: 1; visibility: visible;
  transform: translateY(0);
}
#backToTop:hover {
  background: var(--c-blue); border-color: var(--c-blue);
  color: #fff; transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,102,255,0.4);
}

/* ═══════════════════════════════════════════════════════
   BRAND IDENTITY ENHANCEMENTS  — Dev-Binary-X v4.2
   Colors from official logo: Navy #1B3068 · Blue #2E7DC5 · Orange #F5A421
   ═══════════════════════════════════════════════════════ */

/* ── Brand "X" orange accent (mirrors logo) ─────────── */
.brand-x { color: var(--brand-orange) !important; }

/* ── Official tagline badge ─────────────────────────── */
.corp-brand-tagline {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font);
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--brand-orange);
  background: rgba(245,164,33,0.1);
  border: 1px solid rgba(245,164,33,0.28);
  border-radius: var(--r-full);
  padding: 5px 14px;
  margin-bottom: 16px;
}
.corp-brand-tagline code {
  font-family: 'Courier New', monospace;
  font-size: 0.78rem; font-weight: 900;
  color: var(--brand-orange);
  background: none; padding: 0;
}

/* ── Hero badge — orange brand ring ────────────────── */
.corp-hero__badge span {
  background: var(--brand-orange) !important;
  box-shadow: 0 0 6px rgba(245,164,33,0.6) !important;
}

/* ── Eyebrow — orange underline ─────────────────────── */
.corp-eyebrow::after {
  background: linear-gradient(90deg, var(--brand-orange), var(--brand-blue)) !important;
}

/* ── Brand orange gradient text ──────────────────────── */
.grad-brand {
  background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-orange) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Stats bar — orange accent on hover ─────────────── */
.corp-stats__item:hover .corp-stats__num {
  color: var(--brand-orange);
}

/* ── Section divider — brand gradient bar ───────────── */
.corp-brand-divider {
  width: 100%; height: 3px;
  background: var(--g-brand-full);
  border: none; margin: 0;
  opacity: 0.7;
}

/* ── CTA button — orange variant ────────────────────── */
.corp-btn-brand {
  background: linear-gradient(135deg, var(--brand-orange-dark), var(--brand-orange)) !important;
  color: #fff !important;
  border: none;
  border-radius: var(--r-full);
  padding: 12px 30px;
  font-size: 0.92rem; font-weight: 700;
  letter-spacing: 0.02em;
  position: relative; overflow: hidden;
  transition: var(--t-base);
  box-shadow: 0 4px 20px rgba(245,164,33,0.4);
}
.corp-btn-brand:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(245,164,33,0.55);
  color: #fff !important;
}

/* ── Software & Data dual-identity pill tags ─────────── */
.corp-identity-pills {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 20px;
}
.corp-identity-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 4px 12px; border-radius: var(--r-full);
}
.corp-identity-pill--software {
  background: rgba(46,125,197,0.12);
  border: 1px solid rgba(46,125,197,0.3);
  color: #60b4ff;
}
.corp-identity-pill--data {
  background: rgba(245,164,33,0.1);
  border: 1px solid rgba(245,164,33,0.3);
  color: var(--brand-orange);
}
.corp-identity-pill--it {
  background: rgba(16,185,129,0.1);
  border: 1px solid rgba(16,185,129,0.28);
  color: var(--c-green);
}
