:root {
  --warm-white: #faf8f5;
  --beige: #e8dfd2;
  --charcoal: #2b2a28;
  --gold: #c6a15b;
  --glass: rgba(255, 255, 255, 0.12);
  --shadow: 0 20px 50px rgba(43, 42, 40, 0.12);
}

[data-theme="dark"] {
  --warm-white: #141312;
  --beige: #2a2724;
  --charcoal: #f4efe7;
  --gold: #d4b06a;
  --glass: rgba(0, 0, 0, 0.35);
  --shadow: 0 20px 50px rgba(0, 0, 0, 0.35);
}

body {
  font-family: "Inter", system-ui, sans-serif;
  background: var(--warm-white);
  color: var(--charcoal);
  scroll-behavior: smooth;
}

h1, h2, h3, .display-font {
  font-family: "Playfair Display", Georgia, serif;
}

.marathi-quote {
  font-family: "Inter", system-ui, sans-serif;
  font-style: italic;
  color: var(--gold);
  letter-spacing: 0.02em;
}

.marathi-banner {
  background: color-mix(in srgb, var(--gold) 12%, var(--beige));
  border-left: 3px solid var(--gold);
  padding: 0.65rem 1rem;
  border-radius: 0 0.5rem 0.5rem 0;
  font-size: 0.95rem;
}

.navbar-glass {
  backdrop-filter: blur(14px);
  background: color-mix(in srgb, var(--warm-white) 82%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--beige) 70%, transparent);
}

.navbar-glass .navbar-brand,
.navbar-glass .nav-link {
  color: var(--charcoal);
}

.navbar-glass .nav-link:hover {
  color: var(--gold);
}

[data-theme="dark"] .navbar-glass {
  background: color-mix(in srgb, #1a1816 92%, transparent);
  border-bottom-color: color-mix(in srgb, #3d3832 80%, transparent);
}

[data-theme="dark"] .navbar-glass .navbar-brand,
[data-theme="dark"] .navbar-glass .nav-link {
  color: #f4efe7 !important;
}

[data-theme="dark"] .navbar-toggler {
  border-color: color-mix(in srgb, var(--gold) 50%, transparent);
}

[data-theme="dark"] .navbar-toggler-icon {
  filter: invert(1) brightness(1.2);
}

[data-theme="dark"] .marathi-banner {
  background: color-mix(in srgb, var(--gold) 18%, #1a1816);
  color: #f4efe7;
}

.theme-toggle-btn {
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 50%;
  border: 1px solid var(--gold);
  background: color-mix(in srgb, var(--gold) 8%, transparent);
  color: var(--charcoal);
  display: inline-grid;
  place-items: center;
  padding: 0;
  line-height: 1;
  transition: background 0.2s ease, transform 0.2s ease;
}

.theme-toggle-btn:hover {
  background: color-mix(in srgb, var(--gold) 22%, transparent);
  transform: scale(1.05);
}

.theme-icon-dark { display: none; }
[data-theme="dark"] .theme-icon-light { display: none; }
[data-theme="dark"] .theme-icon-dark { display: inline; }
[data-theme="dark"] .theme-toggle-btn { color: #f4efe7; }

.seo-boost {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  user-select: none;
  -webkit-user-select: none;
  pointer-events: none;
}

.hero {
  min-height: 92vh;
  position: relative;
  overflow: hidden;
}

.hero video,
.hero .hero-fallback {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(20, 18, 16, 0.72), rgba(20, 18, 16, 0.25));
}

.hero-content {
  position: relative;
  z-index: 2;
  padding-top: 8rem;
  padding-bottom: 4rem;
}

.gold-text { color: var(--gold); }

.btn-gold {
  background: linear-gradient(135deg, #c6a15b, #a8843f);
  color: #fff;
  border: none;
  padding: 0.85rem 1.6rem;
  border-radius: 999px;
}

.btn-outline-gold {
  border: 1px solid var(--gold);
  color: var(--charcoal);
  border-radius: 999px;
  padding: 0.85rem 1.6rem;
  background: transparent;
}

.section-pad { padding: 5rem 0; }

.glass-card {
  background: color-mix(in srgb, var(--warm-white) 88%, transparent);
  backdrop-filter: blur(12px);
  border: 1px solid color-mix(in srgb, var(--beige) 60%, transparent);
  border-radius: 1.25rem;
  box-shadow: var(--shadow);
}

/* Project grid — no masonry crop, stable aspect ratio */
.projects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
}

.project-card {
  border-radius: 1rem;
  overflow: hidden;
  transition: box-shadow 0.3s ease, transform 0.3s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.project-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}

.project-card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--beige);
}

.project-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: opacity 0.35s ease;
}

.project-card:hover .project-card__media img {
  opacity: 0.92;
}

.project-card__body {
  padding: 1.1rem 1.25rem 1.25rem;
  flex: 1;
}

.filter-bar {
  background: color-mix(in srgb, var(--beige) 35%, transparent);
  border-radius: 1rem;
  padding: 1.25rem;
}

.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.counter-value {
  font-size: 2.4rem;
  font-family: "Playfair Display", serif;
  color: var(--gold);
}

.process-step {
  border-left: 2px solid var(--gold);
  padding-left: 1rem;
}

.whatsapp-float,
.mobile-cta {
  position: fixed;
  z-index: 1050;
  border-radius: 999px;
  box-shadow: var(--shadow);
}

.whatsapp-float {
  right: 1.25rem;
  bottom: 5.5rem;
  width: 3.4rem;
  height: 3.4rem;
  display: grid;
  place-items: center;
  background: #25d366;
  color: #fff;
}

.mobile-cta {
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  display: none;
}

.footer-premium {
  background: linear-gradient(180deg, color-mix(in srgb, var(--beige) 40%, transparent), var(--warm-white));
  padding-top: 4rem;
}

.autocomplete-wrap {
  position: relative;
}

.autocomplete-list {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 4px);
  z-index: 20;
  background: var(--warm-white);
  border: 1px solid var(--beige);
  border-radius: 0.5rem;
  box-shadow: var(--shadow);
  max-height: 220px;
  overflow-y: auto;
  display: none;
}

.autocomplete-list.open {
  display: block;
}

.autocomplete-item {
  display: block;
  width: 100%;
  text-align: left;
  border: 0;
  background: transparent;
  padding: 0.55rem 0.85rem;
  color: var(--charcoal);
}

.autocomplete-item:hover {
  background: color-mix(in srgb, var(--gold) 15%, transparent);
}

.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.88);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 2000;
}

.lightbox.open { display: flex; }

.lightbox img {
  max-width: 92vw;
  max-height: 88vh;
  border-radius: 0.5rem;
  object-fit: contain;
}

.map-dark iframe {
  filter: grayscale(0.2) contrast(1.05) brightness(0.85);
  border-radius: 1rem;
  width: 100%;
  min-height: 360px;
  border: 0;
}

.media-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 0.5rem;
}

.media-preview-grid img,
.media-preview-grid video {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 0.35rem;
}

@media (max-width: 992px) {
  .mobile-cta { display: block; }
  .projects-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
}
