.hero {
  background: linear-gradient(rgba(0,0,0,0.82), rgba(0,0,0,0.62));
  color: white;
  padding: 72px 0 56px;
}

.topbar {
  background: #f3f5f7;
  color: #243547;
}

.navbar {
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
}

.site-logo {
  height: 52px;
  width: auto;
}

.hero-logo {
  max-width: 420px;
  width: 100%;
  height: auto;
  background: rgba(255,255,255,0.96);
  padding: 1rem;
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.18);
}

.about-logo,
.footer-logo {
  max-width: 360px;
  width: 100%;
  height: auto;
}

.hero-trust {
  font-size: 1rem;
  font-weight: 500;
  color: rgba(255,255,255,0.92);
}

.hero-trust-sep {
  margin: 0 0.5rem;
  opacity: 0.7;
}

.hero-phone a {
  font-size: 1.15rem;
}

.service-icon {
  font-size: 40px;
}

footer {
  background: linear-gradient(rgba(0,0,0,0.7), rgba(0,0,0,0.9));
  color: #bcd;
}

.contact-card,
form.card {
  border-radius: 14px;
}

form.card .form-control,
form.card .form-select {
  padding: 0.8rem 0.9rem;
}

@media (max-width: 991.98px) {
  .site-logo {
    height: 44px;
  }

  .brand-text {
    display: none !important;
  }

  .hero {
    padding: 64px 0 50px;
  }

  .hero-logo {
    max-width: 360px;
  }
}

@media (max-width: 767.98px) {
  .hero {
    padding: 56px 0 44px;
  }

  .hero-logo {
    max-width: 300px;
    padding: 0.75rem;
  }

  .hero-trust {
    font-size: 0.95rem;
    line-height: 1.7;
  }

  .hero-trust-sep {
    display: none;
  }

  .hero-trust span {
    display: block;
  }

  .hero-phone a {
    font-size: 1.05rem;
  }
}

.hero-title {
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: 1.1;
}

.hero-subtitle {
  font-size: 1.1rem;
  line-height: 1.4;
  color: rgba(255,255,255,0.92);
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}