.contact-page-wrap {
  --contact-navy: #0a2c63;
  --contact-navy-deep: #051c42;
  --contact-gold: #dca83a;
  --contact-line: #d8e2f0;
  background:
    radial-gradient(circle at 8% 8%, rgba(220, 168, 58, 0.18), transparent 34%),
    radial-gradient(circle at 92% 28%, rgba(10, 44, 99, 0.12), transparent 42%),
    linear-gradient(to bottom, #f8fbff 0%, #eef3f9 100%);
}

.contact-main-section {
  padding: 3rem 0 5.3rem;
}

.contact-hero-card,
.contact-stats-card,
.contact-channel-card,
.contact-form-card,
.contact-side-card,
.contact-map-card {
  border: 1px solid var(--contact-line);
  border-radius: 20px;
  box-shadow: 0 14px 36px rgba(7, 33, 78, 0.09);
}

.contact-hero-card {
  position: relative;
  overflow: hidden;
  padding: 1.55rem 1.55rem 1.4rem;
  background:
    radial-gradient(circle at 94% 8%, rgba(220, 168, 58, 0.2), transparent 36%),
    linear-gradient(145deg, #fff 0%, #f7fbff 100%);
}

.contact-kicker {
  margin: 0;
  color: #8b6416;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.82rem;
  font-weight: 800;
}

.contact-hero-card h2 {
  margin: 0.45rem 0 0;
  color: var(--contact-navy);
  line-height: 1.07;
  font-size: clamp(1.64rem, 2.5vw, 2.28rem);
}

.contact-hero-lead {
  margin: 0.82rem 0 0;
  color: #4a5f81;
  line-height: 1.6;
  max-width: 58ch;
}

.contact-badges {
  margin-top: 1rem;
  display: flex;
  gap: 0.56rem;
  flex-wrap: wrap;
}

.contact-badges span {
  border: 1px solid #dce7f5;
  border-radius: 999px;
  background: #fff;
  color: #2e4d7e;
  font-size: 0.82rem;
  font-weight: 600;
  padding: 0.38rem 0.72rem;
}

.contact-badges i {
  color: var(--contact-gold);
  margin-right: 0.22rem;
}

.contact-main-actions {
  margin-top: 1.08rem;
  display: flex;
  gap: 0.64rem;
  flex-wrap: wrap;
}

.contact-equal-row {
  align-items: stretch;
}

.contact-equal-row > [class*='col-'] {
  display: flex;
}

.contact-equal-row > [class*='col-'] > article {
  width: 100%;
}

.btn-outline-navy {
  border: 1px solid rgba(10, 44, 99, 0.25);
  color: var(--contact-navy);
  background: #fff;
}

.btn-outline-navy:hover,
.btn-outline-navy:focus-visible {
  color: #fff;
  background: var(--contact-navy);
  border-color: var(--contact-navy);
}

.contact-stats-card {
  height: 100%;
  padding: 1.22rem 1.12rem 1.08rem;
  color: #dce6f7;
  border-color: rgba(220, 168, 58, 0.42);
  background:
    radial-gradient(circle at 100% 0%, rgba(220, 168, 58, 0.2), transparent 44%),
    linear-gradient(180deg, var(--contact-navy) 0%, var(--contact-navy-deep) 100%);
}

.contact-stats-card h3 {
  margin: 0;
  color: #fff;
  font-size: 1.16rem;
}

.contact-stat-grid {
  margin-top: 0.88rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.56rem;
}

.stat-item {
  border: 1px solid rgba(255, 255, 255, 0.17);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.06);
  padding: 0.62rem;
}

.stat-item strong {
  display: block;
  color: #fff;
  line-height: 1;
  font-size: 1.2rem;
}

.stat-item span {
  margin-top: 0.32rem;
  display: block;
  color: #d4e1f5;
  font-size: 0.76rem;
  line-height: 1.35;
}

.contact-hours {
  margin-top: 0.82rem;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  padding-top: 0.66rem;
}

.contact-hours p {
  margin: 0;
  color: #e3ecfb;
  font-size: 0.87rem;
}

.contact-hours p + p {
  margin-top: 0.4rem;
}

.contact-hours i {
  color: #f4cd77;
  margin-right: 0.36rem;
}

.contact-channel-card {
  height: 100%;
  padding: 0.9rem 1rem 0.98rem;
  background: #fff;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.contact-channel-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 36px rgba(10, 44, 99, 0.14);
}

.contact-channel-card::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: linear-gradient(90deg, rgba(220, 168, 58, 0.2) 0%, var(--contact-gold) 45%, rgba(10, 44, 99, 0.16) 100%);
}

.channel-tag {
  margin: 0 0 0.62rem;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #6c82a7;
  font-weight: 700;
}

.channel-head {
  display: flex;
  align-items: center;
  gap: 0.62rem;
}

.channel-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #f7df9f 0%, var(--contact-gold) 100%);
  color: var(--contact-navy);
  font-size: 1.12rem;
}

.contact-channel-card h3 {
  margin: 0;
  color: var(--contact-navy);
  font-size: 1.05rem;
}

.channel-link {
  margin-top: 0.62rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  width: 100%;
  color: #113f81;
  font-weight: 600;
  text-decoration: none;
  background: rgba(10, 44, 99, 0.04);
  border: 1px solid #d8e3f3;
  border-radius: 11px;
  min-height: 42px;
  padding: 0.52rem 0.72rem;
}

.channel-link span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.channel-link i {
  color: #1d4f96;
  flex-shrink: 0;
  font-size: 0.86rem;
}

.channel-link:hover,
.channel-link:focus-visible {
  color: #07295b;
  border-color: #b7cae4;
  background: rgba(10, 44, 99, 0.07);
}

.contact-channel-mail .channel-icon {
  background: linear-gradient(180deg, #f6e5b7 0%, #e3bc63 100%);
}

.contact-channel-phone .channel-icon {
  background: linear-gradient(180deg, #e4edff 0%, #b4c9f3 100%);
}

.contact-channel-map .channel-icon {
  background: linear-gradient(180deg, #fce4c4 0%, #efbc77 100%);
}

.contact-form-card {
  background: #fff;
  padding: 1.22rem 1.12rem;
  height: 100%;
}

.contact-hero-card {
  height: 100%;
}

.card-head h3 {
  margin: 0;
  color: var(--contact-navy);
  font-size: 1.3rem;
}

.card-head p {
  margin: 0.46rem 0 0;
  color: #5f7291;
}

.contact-pro-form {
  margin-top: 0.9rem;
}

.contact-hp-input {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.contact-pro-form .form-label {
  color: #284a7f;
  font-size: 0.87rem;
  font-weight: 700;
}

.contact-pro-form .form-control,
.contact-pro-form .form-select {
  border: 1px solid #d5e1f0;
  border-radius: 12px;
  min-height: 44px;
  color: #173969;
  background: #fdfefe;
}

.contact-pro-form .form-control:focus,
.contact-pro-form .form-select:focus {
  border-color: rgba(10, 44, 99, 0.4);
  box-shadow: 0 0 0 0.2rem rgba(10, 44, 99, 0.13);
}

.form-actions {
  margin-top: 0.9rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.72rem;
  flex-wrap: wrap;
}

.form-actions small {
  color: #5d6f8b;
}

.contact-side-card {
  background: #fff;
  padding: 1.08rem 1.04rem;
}

.contact-side-card + .contact-side-card {
  margin-top: 1rem;
}

.contact-side-card h3 {
  margin: 0;
  color: var(--contact-navy);
  font-size: 1.08rem;
}

.contact-steps {
  margin: 0.85rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.54rem;
}

.contact-steps li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 0.54rem;
  align-items: start;
  color: #536888;
  line-height: 1.45;
}

.contact-steps li span {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1b3d75;
  font-weight: 700;
  background: linear-gradient(180deg, #f6e0a2 0%, #dfb85e 100%);
}

.faq-card details {
  margin-top: 0.68rem;
  border: 1px solid #dde8f6;
  border-radius: 12px;
  background: #f8fbff;
  padding: 0.68rem 0.78rem;
}

.faq-card summary {
  cursor: pointer;
  color: #173e7b;
  font-weight: 700;
}

.faq-card p {
  margin: 0.52rem 0 0;
  color: #5a6d8b;
  line-height: 1.48;
}

.contact-map-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 1.18rem 1.1rem;
  background:
    radial-gradient(circle at 95% 50%, rgba(220, 168, 58, 0.18), transparent 40%),
    linear-gradient(130deg, #ffffff 0%, #f4f9ff 100%);
}

.contact-map-card h3 {
  margin: 0.4rem 0 0;
  color: var(--contact-navy);
  font-size: 1.36rem;
}

.contact-map-card p {
  margin: 0.5rem 0 0;
  color: #556a89;
  max-width: 62ch;
}

.contact-map-fullwidth {
  margin-top: 1rem;
}

.contact-map-frame-wrap {
  width: 100%;
  height: clamp(360px, 52vw, 540px);
  border-top: 1px solid #cfdaea;
  border-bottom: 1px solid #cfdaea;
  overflow: hidden;
}

.contact-map-frame {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

@media (max-width: 1199.98px) {
  .contact-main-actions .btn {
    flex: 1 1 calc(50% - 0.64rem);
  }

  .contact-map-card {
    align-items: flex-start;
  }
}

@media (max-width: 767.98px) {
  .contact-main-actions .btn {
    flex: 1 1 100%;
  }

  .contact-stat-grid {
    grid-template-columns: 1fr;
  }

  .form-actions {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 575.98px) {
  .contact-main-section {
    padding: 2rem 0 3.4rem;
  }

  .contact-hero-card,
  .contact-form-card,
  .contact-side-card,
  .contact-channel-card,
  .contact-map-card {
    border-radius: 16px;
  }

  .contact-hero-card {
    padding: 1.05rem 1rem 1rem;
  }

  .contact-form-card {
    padding: 1rem 0.9rem;
  }

  .contact-channel-card {
    padding: 0.82rem 0.9rem 0.9rem;
  }

  .contact-channel-card h3 {
    font-size: 0.98rem;
  }

  .channel-link {
    min-height: 40px;
    padding: 0.48rem 0.62rem;
  }

  .channel-link span {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

  .contact-map-frame-wrap {
    height: 320px;
  }
}
