:root {
  --primary: #e86b7a;
  --primary-dark: #d45166;
  --primary-soft: #f4d4d8;
  --deep: #2f2a3a;
  --deep-2: #3a3147;
  --muted-bg: #f7f4f5;
  --text: #5b5566;
  --white: #ffffff;
  --border: rgba(47, 42, 58, 0.08);
  --shadow: 0 18px 40px rgba(47, 42, 58, 0.12);
  --radius-xl: 1.75rem;
  --radius-lg: 1.2rem;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background: var(--muted-bg);
  line-height: 1.65;
  text-rendering: optimizeLegibility;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--deep);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.02em;
}

a {
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

.section-space {
  padding: 5rem 0;
}

.topbar h1{
  font-size: 45px;
}

.topbar1 {
  background-image: url(../img/topbar.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.repair {
  background-image: url(../img/topbar-repair.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.maintenance {
  background-image: url(../img/topbar-main.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.res {
  background-image: url(../img/topbar-res.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.comm {
  background-image: url(../img/topbar-comm.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.ins {
  background-image: url(../img/topbar-ins.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.emergency {
  background-image: url(../img/topbar-emergency.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.parts {
  background-image: url(../img/topbar-parts.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.opener {
  background-image: url(../img/topbar-opener.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.cont {
  background-image: url(../img/topbar-contact.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}

.loc {
  background-image: url(../img/topbar-location.webp);
  background-position: 60% center;
  background-repeat: no-repeat;
  color: var(--white);
  padding: 1.9rem 0 2rem;
  position: relative;
  overflow: hidden;
}



.topbar::before,
.topbar::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  /* background: rgba(255, 255, 255, 0.08); */
  pointer-events: none;
}

/* .topbar::before {
  width: 22rem;
  height: 22rem;
  top: -8rem;
  left: -6rem;
} */

/* .topbar::after {
  width: 18rem;
  height: 18rem;
  bottom: -7rem;
  right: -5rem;
} */

.brand-title {
  font-size: clamp(2.4rem, 5vw, 4.4rem);
  color: var(--white);
  margin-bottom: 0.75rem;
}

.brand-subtitle {
  color: rgba(255, 255, 255, 0.88);
  font-size: 1.05rem;
  max-width: 42rem;
  margin: 0 auto;
}

.nav-shell {
  background: var(--deep);
  border-radius: 999px;
  box-shadow: var(--shadow);
  margin-top: 2rem;
  padding: 0.7rem 1rem;
}

.navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.9);
  font-weight: 600;
  padding: 0.85rem 1rem;
  border-radius: 999px;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus,
.navbar-nav .nav-link.active {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.intro-card {
  background: var(--white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  padding: clamp(2rem, 4vw, 4rem);
  margin-top: -1.8rem;
  position: relative;
  z-index: 2;
}

.eyebrow {
  display: inline-block;
  font-size: 0.85rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--primary-dark);
  font-weight: 800;
  margin-bottom: 1rem;
}

.footer-eyebrow {
  color: rgba(255, 255, 255, 0.75) !important;
}



.lead-strong {
  font-size: clamp(1.15rem, 2vw, 1.35rem);
  color: var(--deep-2);
}

.btn-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.3rem;
  padding: 0.9rem 1.55rem;
  border-radius: 999px;
  font-weight: 800;
  border: 0;
  transition: transform 0.2s ease, opacity 0.2s ease, box-shadow 0.2s ease;
}

.btn-pill:hover {
  transform: translateY(-2px);
}

.btn-phone {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.3rem;
  padding: 0.9rem 1.55rem;
  border-radius: 999px;
  font-size: 35px;
  font-weight: 800;
  border: 0;
  background-color: #fff;
  color: #0e0e0e;
  transition: transform 0.2s ease, opacity 0.2s ease, box-shadow 0.2s ease;
}

.btn-phone:hover {
  transform: translateY(-2px);
}

.btn-primary-soft {
  background: var(--primary);
  color: #fff;
  box-shadow: 0 12px 24px rgba(232, 107, 122, 0.22);
}

.btn-dark-soft {
  background: var(--deep);
  color: #fff;
}

.btn-outline-soft {
  background: transparent;
  color: var(--deep);
  border: 2px solid rgba(47, 42, 58, 0.14);
}

.content-panel {
  background: var(--white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  padding: clamp(2rem, 3vw, 3rem);
}

.feature-box {
  text-align: center;
  padding: 1rem;
}

.feature-icon {
  width: 4.25rem;
  height: 4.25rem;
  margin: 0 auto 1.2rem;
  border-radius: 50%;
  background: linear-gradient(180deg, var(--primary-soft), #fff);
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  color: var(--primary-dark);
  box-shadow: inset 0 0 0 1px rgba(212, 81, 102, 0.12);
}

.mini-card,
.stat-box,
.price-card,
.quote-card,
.faq-item {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  border: 1px solid var(--border);
  box-shadow: 0 10px 25px rgba(47, 42, 58, 0.08);
}

.stat-box h3,
.price-card .price {
  font-size: 2rem;
  margin-bottom: 0.5rem;
  color: var(--primary-dark);
}

.price-card {
  text-align: center;
}

.price-card.featured {
  border-color: rgba(212, 81, 102, 0.25);
  transform: translateY(-6px);
}

.showcase-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 10px 25px rgba(47, 42, 58, 0.08);
  height: 100%;
}

.showcase-media1 {
  aspect-ratio: 16 / 10;
  background-image: url(../img/sm-coupon1.webp);
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  /* background: linear-gradient(135deg, #d85f74, #3a3147); */
  position: relative;
}

.showcase-media2 {
  aspect-ratio: 16 / 10;
  background-image: url(../img/sm-coupon2.webp);
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  /* background: linear-gradient(135deg, #d85f74, #3a3147); */
  position: relative;
}

.showcase-media3 {
  aspect-ratio: 16 / 10;
  background-image: url(../img/sm-coupon3.webp);
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  /* background: linear-gradient(135deg, #d85f74, #3a3147); */
  position: relative;
}

/* .showcase-media::before {
  content: "";
  position: absolute;
  inset: 8%;
  border-radius: 1.2rem;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.18);
} */

.showcase-body {
  padding: 1.5rem;
}

.accent-section {
  background: linear-gradient(180deg, #fff 0%, #f8f1f2 100%);
}

.contact-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.contact-list li {
  padding: 0.85rem 0;
  border-bottom: 1px solid var(--border);
}

.contact-list li:last-child {
  border-bottom: 0;
}

.footer-wrap {
  background: var(--deep);
  color: rgba(255, 255, 255, 0.75);
  padding: 4rem 0 2rem;
}

.footer-wrap h3,
.footer-wrap h4,
.footer-wrap h5 {
  color: #fff;
}

.footer-wrap a{
  color: #fff;
}

.footer-card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-xl);
  padding: 2rem;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  margin-top: 2rem;
  padding-top: 1.2rem;
  font-size: 0.95rem;
}


/* section 3 */
.custom-card {
  background: #fff;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 10px 25px rgba(0,0,0,0.08);
  transition: 0.3s;
}

.custom-card:hover {
  transform: translateY(-5px);
}

.custom-card img {
  width: 100%;
  height: 400px;
  object-fit: cover;
}

.card-content {
  padding: 40px;
  text-align: center;
}





@media (max-width: 991.98px) {
  .nav-shell {
    border-radius: 1.25rem;
  }

  .navbar-collapse {
    padding-top: 0.75rem;
  }

  .navbar-nav .nav-link {
    border-radius: 0.9rem;
  }

  .nav-shell {
    position: relative;
    border-radius: 1.25rem;
  }

  .navbar-collapse {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--deep);
    padding: 0.75rem 1rem;
    border-radius: 1rem;
    z-index: 9999;
  }

  .navbar-nav {
    align-items: stretch !important;
  }
.topbar {
  overflow: visible;
  z-index: 10;
}
}

@media (max-width: 767.98px) {

  .section-space {
    padding: 3.8rem 0;
  }


  .intro-card,
  .content-panel,
  .footer-card,
  .mini-card,
  .stat-box,
  .price-card,
  .quote-card,
  .faq-item {
    border-radius: 1.4rem;
  }

  .price-card.featured {
    transform: none;
  }

  .custom-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.card-content {
  padding: 0;
  text-align: center;
}
}

.navbar-toggler-icon{
  background-color: #f8f1f2;
}

 /* form */
.CUS{
  
  padding: 0;
  border-radius: 30px;
}

.CUS p{
  padding: 0;
 }

form.CUS input.subject {
    display: none;
}

.CUS .form-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

.CUS .form-row p {
    flex: 1;
    margin: 0;
}

.CUS textarea {
    width: 100%;
    font-size: 15px;
    border: 1px solid #020202;
    box-sizing: border-box;
    border: 1px solid #d4d4d4;
    background-color: #f0f0f0;
}

.CUS .submit {
    width: 100%;
    font-size: 15px;
    box-sizing: border-box;
    border: 1px solid #d4d4d4;
    background-color: #f0f0f0;
    color: #161515;
}

.CUS input,
.CUS select {
    width: 100%;
    font-size: 15px;
     border: 1px solid #d4d4d4;
    box-sizing: border-box;
    font-weight: normal;
    padding: 10px;
    margin: 5px 0;
    background-color: #f0f0f0;

}

.CUS label {
    font-size: 15px;
    display: block;
    margin-top: 10px;
    font-weight: bold;
    text-align: left;
    color: #3b3b3b;
}

.CUS legend {
    font-size: 20px;
    text-align: left;
    color: #ffffff;
}

form.CUS,
.CUS fieldset {
    border: none;
}


@media only screen and (max-width:500px){
    .CUS .form-row {
        flex-direction: column;  
        align-items: stretch;    
    }

    .CUS .form-row p {
        flex: 1 0 100%;
        width: 100%;
    }
 } 

 .img-main{
  border-radius: var(--bs-border-radius-xl) !important;
  box-shadow: var(--bs-box-shadow) !important;
 }


 /* locations */
 .locations-wrapper {
  width: 70%;
  margin: 0 auto;
  padding: 50px 0;
}

.locations-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 15px;
}

.location-item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 55px;
  padding: 12px 15px;
  text-align: center;
  text-decoration: none;
  color: #222;
  background: #f8f8f8;
  border: 1px solid #e5e5e5;
  border-radius: 12px;
  font-weight: 600;
  transition: all 0.3s ease;
}

.location-item:hover {
  background: #d45166;
  color: #ffffff;
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
}

.location-item:active {
  transform: scale(0.98);
}