/* Override font-display for Font Awesome (loaded from CDN) */
@font-face {
  font-family: 'Font Awesome 6 Free';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/webfonts/fa-solid-900.woff2') format('woff2');
}
@font-face {
  font-family: 'Font Awesome 6 Free';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/webfonts/fa-regular-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Font Awesome 6 Brands';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/webfonts/fa-brands-400.woff2') format('woff2');
}

.hero-bg {
  background-color: #000;
  background-image:
    radial-gradient(ellipse 80% 60% at 60% 40%, rgba(7,71,166,0.35) 0%, transparent 70%),
    radial-gradient(ellipse 50% 80% at 10% 80%, rgba(7,71,166,0.15) 0%, transparent 60%);
}

.nav-link::after {
  content: '';
  display: block;
  height: 2px;
  width: 0;
  background: #0747A6;
  transition: width 0.25s ease;
  margin-top: 2px;
}
.nav-link:hover::after { width: 100%; }

.service-card {
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(7,71,166,0.15);
}

label:has(~ input[required])::after,
label:has(~ textarea[required])::after {
  content: ' *';
  color: #ef4444;
}

input:focus, textarea:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(7,71,166,0.25);
}

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.lang-btn { transition: color 0.15s, background 0.15s; }
.lang-btn[aria-current="true"] {
  color: #fff;
  background: #0747A6;
}
