:root {
  --primary: #c8860a;
  --dark: #1a1a2e;
  --light-bg: #f9f6f1;
}

body {
  font-family: 'Segoe UI', sans-serif;
  color: #333;
}

/* Navbar */
.navbar {
  background: var(--dark) !important;
}
.navbar-brand span {
  color: var(--primary);
}
.nav-link {
  color: #ccc !important;
  font-weight: 500;
}
.nav-link:hover, .nav-link.active {
  color: var(--primary) !important;
}
.topbar-phone {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  white-space: nowrap;
}
.topbar-phone:hover { color: #fff; }
.topbar-divider {
  width: 1px;
  height: 16px;
  background: #555;
}
.topbar-social {
  color: #aaa;
  font-size: 1.1rem;
  text-decoration: none;
  transition: color .2s;
}
.topbar-social:hover { color: var(--primary); }

/* Hero */
#hero {
  background: linear-gradient(rgba(26,26,46,0.72), rgba(26,26,46,0.72)),
    url('images/saikruparenovation31.jpg') center/cover no-repeat;
  min-height: 92vh;
  display: flex;
  align-items: center;
  padding-top: 120px;
}
#hero h1 { font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 700; }
#hero p  { font-size: 1.15rem; max-width: 560px; }
.btn-primary {
  background: var(--primary);
  border-color: var(--primary);
}
.btn-primary:hover {
  background: #a86e08;
  border-color: #a86e08;
}
.btn-outline-light:hover { background: var(--primary); border-color: var(--primary); }

/* Section titles */
.section-title { font-weight: 700; position: relative; display: inline-block; }
.section-title::after {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: var(--primary);
  margin: 8px auto 0;
}

/* Services */
#services { background: var(--light-bg); }
.service-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.service-list li {
  padding: 5px 0;
  padding-left: 20px;
  position: relative;
  color: #555;
  font-size: 0.88rem;
}
.service-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 12px;
  width: 7px;
  height: 7px;
  background: var(--primary);
  border-radius: 50%;
}
.service-card {
  border: none;
  border-radius: 12px;
  transition: transform .25s, box-shadow .25s;
}
.service-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 28px rgba(0,0,0,.12);
}
.service-icon {
  font-size: 2.4rem;
  color: var(--primary);
}

/* About */
.callout-card {
  background: #fff;
  border-left: 4px solid var(--primary);
  box-shadow: 0 4px 16px rgba(0,0,0,.07);
}
.callout-icon {
  font-size: 2rem;
  color: var(--primary);
  flex-shrink: 0;
}

/* Stats */
#stats { background: var(--dark); }
.stat-number { font-size: 2.6rem; font-weight: 700; color: var(--primary); }

/* Gallery */
.gallery-img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 10px;
  transition: transform .3s;
}
.gallery-img:hover { transform: scale(1.04); }

/* Testimonials */
#testimonials { background: var(--light-bg); }
.testimonial-card {
  border: none;
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0,0,0,.07);
}
.stars { color: var(--primary); }

/* Contact */
#contact { background: var(--dark); }
#contact .form-control, #contact .form-select {
  background: #2a2a40;
  border: 1px solid #444;
  color: #eee;
}
#contact .form-control::placeholder { color: #888; }
#contact .form-control:focus, #contact .form-select:focus {
  background: #2a2a40;
  border-color: var(--primary);
  color: #eee;
  box-shadow: none;
}
.contact-info i { color: var(--primary); font-size: 1.3rem; }

/* Inquiry form checkboxes */
#contact .form-check-input {
  background-color: #2a2a40;
  border-color: #555;
}
#contact .form-check-input:checked {
  background-color: var(--primary);
  border-color: var(--primary);
}
#contact .form-label { margin-bottom: 6px; }

/* Footer */
footer { background: #111; }
footer a { color: #aaa; text-decoration: none; }
footer a:hover { color: var(--primary); }

/* Social icons */
.nav-phone {
  color: var(--primary);
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
}
.nav-phone:hover { color: #fff; }

/* Social icons */
.social-nav-icon {
  color: #aaa;
  font-size: 1.2rem;
  transition: color .2s;
}
.social-nav-icon:hover { color: var(--primary); }

.social-footer-icon {
  color: #aaa;
  font-size: 1.4rem;
  transition: color .2s;
}
.social-footer-icon:hover { color: var(--primary); }

/* Page header (gallery & quote pages) */
.page-header {
  background: linear-gradient(rgba(26,26,46,0.82), rgba(26,26,46,0.82)),
    url('images/saikruparenovation1.jpg') center/cover no-repeat;
  padding: 140px 0 60px;
}

/* Gallery filter buttons */
.btn-filter {
  border: 2px solid #ddd;
  background: #fff;
  color: #555;
  border-radius: 50px;
  padding: 6px 20px;
  font-size: 0.9rem;
  transition: all .2s;
}
.btn-filter:hover, .btn-filter.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

/* Gallery wrap with overlay */
.gallery-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
}
.gallery-wrap .gallery-img {
  border-radius: 0;
  transition: transform .35s;
}
.gallery-wrap:hover .gallery-img { transform: scale(1.07); }
.gallery-overlay {
  position: absolute;
  inset: 0;
  background: rgba(26,26,46,0.45);
  display: flex;
  align-items: flex-end;
  padding: 12px;
  opacity: 0;
  transition: opacity .3s;
}
.gallery-wrap:hover .gallery-overlay { opacity: 1; }
.gallery-overlay span {
  background: var(--primary);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 50px;
  text-transform: uppercase;
}

/* Scroll-to-top */
#scrollTop {
  position: fixed;
  bottom: 28px;
  right: 28px;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 44px;
  height: 44px;
  font-size: 1.2rem;
  display: none;
  z-index: 999;
  cursor: pointer;
}
