/* Custom styles to reproduce the red organic hero background */
.bg-hero {
  /* Layered black/charcoal gradients for a cinematic dark hero */
  background:
    radial-gradient(900px 520px at 80% -10%, rgba(160, 160, 160, 0.18) 0%, rgba(0, 0, 0, 0) 60%),
    radial-gradient(680px 420px at 20% 55%, rgba(0, 0, 0, 0.65) 0%, rgba(0, 0, 0, 0) 62%),
    radial-gradient(700px 480px at 10% 10%, rgba(90, 90, 90, 0.25) 0%, rgba(0, 0, 0, 0) 65%),
    linear-gradient(180deg, #0f0f12 0%, #000000 100%);
}

/* Soft film grain / vignette edges for cinematic feel */
.bg-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(1200px 600px at 50% 30%, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.0) 60%),
    radial-gradient(1200px 600px at 50% 120%, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.0) 60%);
}

/* Make sure the ::after layer can sit on positioned parent */
.bg-hero { position: absolute; }

/* Premium card styling for partners section */
.premium-frame {
  position: relative;
  padding: 1.5px; /* gradient border */
  background: linear-gradient(135deg, rgba(255,255,255,0.9), rgba(0,0,0,0.08));
  border-radius: 1rem; /* match rounded-2xl */
  box-shadow: 0 14px 34px rgba(0,0,0,0.08);
}

.premium-card {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,255,255,1));
  border: 1px solid rgba(0,0,0,0.04);
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 -1px 0 rgba(0,0,0,0.02) inset, 0 8px 20px rgba(0,0,0,0.05);
}

.premium-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(900px 360px at -10% -20%, rgba(255,255,255,0.5), rgba(255,255,255,0) 60%);
}

/* Smooth image rendering on slider */
.slide { will-change: opacity, transform; }

/* Red wave background used in CTA card */
.bg-hero-red {
  background:
    radial-gradient(900px 520px at 80% -10%, rgba(232, 64, 64, 0.95) 0%, rgba(232, 64, 64, 0) 60%),
    radial-gradient(680px 420px at 20% 55%, rgba(123, 12, 12, 0.95) 0%, rgba(123, 12, 12, 0) 62%),
    radial-gradient(700px 480px at 10% 10%, rgba(225, 38, 38, 0.7) 0%, rgba(225, 38, 38, 0) 65%),
    linear-gradient(180deg, #b71414 0%, #6d0e0e 100%);
  position: relative;
  overflow: hidden;
}

.bg-hero-navy {
  position: relative;
  overflow: hidden;
  background-color: #04060b;
  background-image:
    radial-gradient(120% 140% at 10% 10%, rgba(48, 75, 129, 0.4), rgba(48, 75, 129, 0) 70%),
    radial-gradient(90% 120% at 85% 30%, rgba(16, 35, 65, 0.9), rgba(16, 35, 65, 0) 72%),
    linear-gradient(180deg, rgba(13, 26, 47, 0.95), rgba(4, 6, 11, 0.92)),
    linear-gradient(90deg, rgba(4, 6, 11, 0.45), rgba(4, 6, 11, 0)),
    url("../img/icons/globe.svg");
  background-repeat: no-repeat;
  background-blend-mode: normal, normal, overlay, multiply, screen;
  background-size:
    130% 130%,
    120% 120%,
    100% 100%,
    80% 130%,
    clamp(260px, 40vw, 420px) clamp(260px, 40vw, 420px);
  background-position:
    15% 25%,
    75% 15%,
    center,
    5% center,
    calc(50% + 140px) center;
}

@media (max-width: 768px) {
  .bg-hero-navy {
    background-size:
      160% 160%,
      140% 140%,
      100% 100%,
      110% 150%,
      clamp(220px, 70vw, 340px) clamp(220px, 70vw, 340px);
    background-position:
      20% 18%,
      70% 10%,
      center,
      12% center,
      center 68%;
  }
}

/* Glassy pill used on cards */
.glass-pill {
  background: radial-gradient(100% 100% at 50% 0%, rgba(255,255,255,0.14), rgba(255,255,255,0.06)) , rgba(0,0,0,0.35);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.2), 0 2px 10px rgba(0,0,0,0.25);
}

.cta-arrow {
  background: radial-gradient(120% 120% at 30% 20%, #ffffff, #f3f3f3);
  box-shadow: 0 10px 30px rgba(0,0,0,0.20), inset 0 1px 0 rgba(255,255,255,0.7);
}

/* Animated sheen/highlights over the red hero for subtle motion */
.bg-hero-red::after {
  content: "";
  position: absolute;
  inset: -15%;
  pointer-events: none;
  background:
    radial-gradient(50% 40% at 20% 0%, rgba(255,255,255,0.12), rgba(255,255,255,0) 60%),
    radial-gradient(45% 35% at 80% 10%, rgba(255,255,255,0.10), rgba(255,255,255,0) 60%);
  mix-blend-mode: overlay;
  animation: heroRedDrift 12s ease-in-out infinite alternate;
  will-change: transform, opacity;
}

@keyframes heroRedDrift {
  0%   { transform: translate3d(-6%, -3%, 0) scale(0.985); opacity: 0.9; }
  50%  { transform: translate3d(6%, 3%, 0) scale(1.05);  opacity: 1; }
  100% { transform: translate3d(3%, -6%, 0) scale(1.02); opacity: 0.95; }
}

/* Second drifting layer for stronger parallax motion */
.bg-hero-red::before {
  content: "";
  position: absolute;
  inset: -20%;
  pointer-events: none;
  background:
    radial-gradient(70% 60% at 10% 30%, rgba(255,255,255,0.08), rgba(255,255,255,0) 65%),
    radial-gradient(60% 50% at 90% 60%, rgba(255,255,255,0.06), rgba(255,255,255,0) 65%);
  mix-blend-mode: overlay;
  animation: heroRedDriftParallax 16s ease-in-out infinite alternate-reverse;
  will-change: transform, opacity;
}

@keyframes heroRedDriftParallax {
  0%   { transform: translate3d(5%, 2%, 0) scale(1.02) rotate(0.2deg); opacity: 0.75; }
  50%  { transform: translate3d(-7%, -4%, 0) scale(1.07) rotate(-0.2deg); opacity: 0.9; }
  100% { transform: translate3d(-3%, 6%, 0) scale(1.03) rotate(0.15deg); opacity: 0.8; }
}

/* Panels for capabilities grid */
.panel-red { @apply bg-white; }
.panel-red {
  background:
    radial-gradient(900px 520px at 80% -10%, rgba(232, 64, 64, 0.95) 0%, rgba(232, 64, 64, 0) 60%),
    radial-gradient(680px 420px at 20% 55%, rgba(123, 12, 12, 0.95) 0%, rgba(123, 12, 12, 0) 62%),
    radial-gradient(700px 480px at 10% 10%, rgba(225, 38, 38, 0.7) 0%, rgba(225, 38, 38, 0) 65%),
    linear-gradient(180deg, #c41f1f 0%, #5d0d0d 100%);
}

.panel-navy {
  background: linear-gradient(180deg, #13223D 0%, #0F1B33 100%);
}

/* Keep red and blue capability panels equal height across viewports */
.panel-equal {
  /* Scales with viewport but stays within sensible bounds */
  min-height: clamp(260px, 32vw, 380px);
}

/* Prevent document scroll when modals are open */
body.modal-open {
  overflow: hidden;
}

.modal-backdrop {
  opacity: 0;
  transition: opacity 120ms cubic-bezier(0.4, 0, 0.2, 1);
  background-color: rgba(22, 24, 28, 0.55);
  backdrop-filter: blur(18px);
}

.modal-backdrop.is-open {
  opacity: 1;
}

[data-modal-panel] {
  opacity: 0;
  transform: translate3d(0, -12px, 0) scale(0.96);
  transition:
    opacity 140ms cubic-bezier(0.33, 1, 0.68, 1),
    transform 160ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform, opacity;
  outline: none;
  max-height: min(90vh, 760px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  width: min(92vw, 56rem);
  position: relative;
  background-color: #ffffff;
  box-shadow: 0 28px 60px -35px rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(0, 0, 0, 0.08);
}

[data-modal-panel].is-open {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

[data-modal-panel] .modal-body {
  overflow-y: auto;
  margin-top: clamp(1.5rem, 3vw, 2rem);
  padding-inline-end: 0.75rem;
  margin-inline-end: -0.75rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(148, 163, 184, 0.3) transparent;
}

[data-modal-panel] .modal-body::-webkit-scrollbar {
  width: 6px;
}

[data-modal-panel] .modal-body::-webkit-scrollbar-track {
  background: transparent;
}

[data-modal-panel] .modal-body::-webkit-scrollbar-thumb {
  background: rgba(148, 163, 184, 0.35);
  border-radius: 9999px;
}

@media (max-width: 640px) {
  [data-modal-panel] {
    border-radius: 1.5rem;
    padding: 2.5rem 1.75rem;
  }

  [data-modal-panel] .modal-body {
    margin-top: 1.5rem;
    padding-inline-end: 0.5rem;
    margin-inline-end: -0.5rem;
  }

  [data-modal-panel] h2 {
    font-size: clamp(1.4rem, 6vw, 1.9rem);
  }

  [data-modal-panel] section {
    padding: 1.25rem 1.5rem;
  }

  [data-modal-panel] .modal-body ul {
    margin-top: 1.1rem;
  }

  [data-modal-panel] .modal-body li {
    gap: 0.875rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .modal-backdrop,
  [data-modal-panel] {
    transition-duration: 0ms !important;
    transition-delay: 0ms !important;
  }
  [data-modal-panel] {
    transform: none !important;
  }
}
