/* PJ INFRA — Premium Clean Real Estate */

:root {
  --navy: #050505;
  --navy-light: #0b0b0b;
  --royal: #d4af37;
  --royal-glow: #ffd700;
  --royal-border: rgba(212, 175, 55, 0.28);
  --gold: #d4af37;
  --gold-light: #ffd700;
  --gold-soft: rgba(212, 175, 55, 0.15);
  --emerald: #d4af37;
  --bg: #0b0b0b;
  --bg-white: #111111;
  --bg-soft: #0b0b0b;
  --text: #f8f8f8;
  --text-muted: #b8b8b8;
  --text-light: #949494;
  --card-shadow: 0 4px 24px rgba(15, 23, 42, 0.06);
  --card-shadow-hover: 0 12px 32px rgba(15, 23, 42, 0.1);
  --z-hero-bg: 0;
  --z-flare: 1;
  --z-hero-overlay: 2;
  --z-hero-content: 10;
  --z-header: 100;
  --z-popup: 200;
  --card-img-h: 280px;
  --card-img-h-m: 220px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  font-family: 'Roboto', Calibri, 'Segoe UI', sans-serif;
  background: var(--bg);
  color: var(--text);
  margin: 0;
  overflow-x: hidden;
}

/* ——— Dark luxury sections ——— */
.section-light {
  background: var(--navy-light) !important;
}

.section-muted {
  background: var(--navy) !important;
}

.section-alt {
  background: var(--bg-white) !important;
}

.section-dark:not(.hero-slider):not(.site-footer),
.section-darker {
  background: var(--navy-light) !important;
}

/* ——— Typography on dark sections ——— */
.section-light .text-white,
.section-muted .text-white,
.section-alt .text-white,
.section-dark .text-white:not(.hero-slider *),
.section-darker .text-white {
  color: var(--text) !important;
}

.section-light .text-slate-600,
.section-muted .text-slate-600,
.section-alt .text-slate-600,
.section-dark .text-slate-600,
.section-darker .text-slate-600 {
  color: var(--text-muted) !important;
}

.section-light .text-slate-500,
.section-muted .text-slate-500 {
  color: var(--text-light) !important;
}

.text-emerald-brand:not(.tag-rera):not(.badge-rera) {
  color: var(--royal) !important;
}

.text-gold-brand,
.gold-text {
  color: var(--gold) !important;
}

.text-royal-glow {
  color: var(--royal-glow) !important;
}

/* ——— Page hero (inner pages) ——— */
.page-hero {
  background: linear-gradient(180deg, var(--navy) 0%, var(--navy-light) 100%) !important;
  padding-top: 7rem;
  padding-bottom: 3rem;
  position: relative;
  overflow: hidden;
}

.page-hero .text-white,
.page-hero h1 {
  color: #fff !important;
}

.page-hero .text-slate-600,
.page-hero .text-slate-500 {
  color: #cbd5e1 !important;
}

/* ——— Keyframes (minimal) ——— */
@keyframes shineSweep {
  0% { transform: translateX(-120%); }
  100% { transform: translateX(220%); }
}

@keyframes heroKenBurns {
  0% { transform: scale(1.03); }
  100% { transform: scale(1.07); }
}

@keyframes heroFadeIn {
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes popupZoom {
  from { opacity: 0; transform: scale(0.96); }
  to { opacity: 1; transform: scale(1); }
}

@keyframes flarePulse {
  0%, 100% { opacity: 0.14; }
  50% { opacity: 0.22; }
}

@keyframes borderRotate {
  to { transform: rotate(360deg); }
}

@keyframes reviewsMarquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Border flare — header, cards, popup only */
.border-flare {
  position: relative;
  padding: 2px;
  border-radius: 1rem;
  overflow: hidden;
  isolation: isolate;
}

.border-flare::before {
  content: '';
  position: absolute;
  inset: -60%;
  background: conic-gradient(
    from 0deg,
    var(--royal-glow),
    var(--gold),
    transparent 35%,
    var(--royal-glow) 70%,
    var(--gold)
  );
  animation: borderRotate 14s linear infinite;
  z-index: 0;
  opacity: 0.85;
}

.border-flare:hover::before {
  opacity: 1;
}

.border-flare-inner {
  position: relative;
  z-index: 1;
  background: var(--bg-white);
  border-radius: calc(1rem - 2px);
}

/* Header: static gold border + half flare line (no rotating sides) */
.site-header .header-bar.border-flare,
.header-bar.border-flare {
  position: relative;
  border-radius: 999px;
  padding: 0;
  overflow: visible;
  isolation: auto;
  background: rgba(5, 5, 5, 0.92);
  border: 1px solid rgba(212, 175, 55, 0.35);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.5);
}

.site-header .header-bar.border-flare::before,
.header-bar.border-flare::before {
  display: none !important;
  animation: none !important;
  content: none !important;
}

.site-header .header-bar.border-flare::after,
.header-bar.border-flare::after {
  content: '';
  position: absolute;
  left: 22%;
  width: 56%;
  bottom: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(184, 134, 11, 0.5) 12%,
    #d4af37 30%,
    #ff8c00 50%,
    #ffd700 70%,
    rgba(184, 134, 11, 0.5) 88%,
    transparent
  );
  border-radius: 0 0 4px 4px;
  pointer-events: none;
  z-index: 2;
}

.header-bar.border-flare .border-flare-inner,
.header-bar > .max-w-7xl,
.header-bar.border-flare > div {
  border-radius: 999px;
}

.header-bar.border-flare .border-flare-inner {
  border-radius: 999px;
  background: transparent !important;
  border: none;
}

.border-flare-popup {
  border-radius: 1.25rem;
  padding: 2px;
}

.border-flare-popup .enquiry-popup-inner {
  border-radius: calc(1.25rem - 2px);
  border: none;
}

.border-flare-card {
  border-radius: 1rem;
  height: 100%;
  display: block;
}

.border-flare-card > .border-flare-inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: calc(1rem - 2px);
}

/* ——— Sticky header ——— */
.site-header {
  z-index: var(--z-header);
  transition: padding 0.3s ease;
}

.site-header.scrolled {
  padding-top: 0.5rem;
}

.site-header .header-bar > div,
.site-header .header-bar .max-w-7xl {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  padding: 0.5rem 1rem;
  background: rgba(10, 15, 28, 0.55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: background 0.35s ease, box-shadow 0.35s ease;
}

.site-header.scrolled .header-bar > div,
.site-header.scrolled .header-bar .max-w-7xl {
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 8px 32px rgba(15, 23, 42, 0.1);
}

.site-header.scrolled .brand-lockup .header-brand-title {
  color: #111827 !important;
}

.site-header.scrolled .brand-lockup .header-brand-sub {
  color: #4b5563 !important;
}

.site-header.scrolled .island-link {
  color: #374151;
}

.site-header.scrolled .island-link:hover,
.site-header.scrolled .island-link.active {
  color: var(--royal);
}

.site-header.scrolled .dynamic-island {
  background: var(--bg-soft);
  border-color: var(--royal-border);
}

.brand-logo {
  background: linear-gradient(135deg, var(--royal), #1d4ed8);
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}

.brand-lockup .header-brand-title {
  color: var(--gold-light) !important;
  transition: color 0.35s ease;
}

.brand-lockup .header-brand-sub {
  color: #94a3b8 !important;
  transition: color 0.35s ease;
}

/* Dynamic Island — clean glass, no spinning border */
.dynamic-island-wrap {
  flex: 1;
  max-width: 420px;
  margin: 0 auto;
  padding: 0;
  border: none;
  background: none;
}

.dynamic-island-wrap::before,
.dynamic-island-wrap.border-animate::before {
  display: none !important;
}

.dynamic-island {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  padding: 0.35rem 0.55rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  position: relative;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.island-indicator {
  position: absolute;
  bottom: 5px;
  height: 2px;
  width: 0;
  background: linear-gradient(90deg, var(--gold), var(--royal-glow));
  border-radius: 2px;
  transition: left 0.3s ease, width 0.3s ease;
}

.island-link {
  position: relative;
  padding: 0.5rem 0.9rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.75);
  border-radius: 999px;
  transition: color 0.25s ease;
  white-space: nowrap;
}

.island-link::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 4px;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), var(--royal-glow));
  transition: width 0.25s ease;
  transform: translateX(-50%);
}

.island-link:hover {
  color: #fff;
}

.island-link:hover::after,
.island-link.active::after {
  width: 55%;
}

.island-link.active {
  color: var(--gold-light);
}

.glass-dark {
  background: rgba(10, 15, 28, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.mobile-overlay {
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(2px);
  z-index: calc(var(--z-header) + 10);
}

.mobile-menu {
  transform: translateX(100%);
  transition: transform 0.3s ease;
  background: var(--bg-white) !important;
  border-left: 1px solid var(--royal-border);
  z-index: calc(var(--z-header) + 20);
  color: var(--text);
}

.mobile-menu.open {
  transform: translateX(0);
}

.mobile-nav-link {
  padding: 0.75rem 1rem;
  border-radius: 0.75rem;
  color: var(--text-muted);
  transition: background 0.2s ease, color 0.2s ease;
}

.mobile-nav-link:hover,
.mobile-nav-link.active {
  background: var(--bg-soft);
  color: var(--royal);
}

.mobile-menu .text-gold-brand {
  color: var(--royal) !important;
}

/* ——— Buttons ——— */
.btn-premium,
.btn-primary,
.btn-gold {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.7rem 1.35rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.875rem;
  color: #fff;
  background: linear-gradient(135deg, var(--royal) 0%, #1d4ed8 55%, var(--gold) 120%);
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  box-shadow: 0 4px 14px rgba(37, 99, 235, 0.25);
}

.btn-premium::before,
.btn-primary::before,
.btn-gold::before {
  content: '';
  position: absolute;
  inset: 0;
  width: 45%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent);
  transform: translateX(-120%);
  pointer-events: none;
}

.btn-premium:hover::before,
.btn-primary:hover::before,
.btn-gold:hover::before {
  animation: shineSweep 0.55s ease;
}

.btn-premium:hover,
.btn-primary:hover,
.btn-gold:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.28);
}

.btn-premium.btn-sm {
  padding: 0.45rem 0.9rem;
  font-size: 0.8125rem;
}

.btn-outline-gold,
.btn-outline {
  background: transparent !important;
  border: 1px solid var(--royal-border) !important;
  color: var(--royal) !important;
  box-shadow: none !important;
}

.section-light .btn-outline,
.page-hero ~ * .btn-outline {
  border-color: var(--royal-border) !important;
  color: var(--royal) !important;
}

.btn-outline-gold:hover,
.btn-outline:hover {
  background: var(--bg-soft) !important;
  border-color: var(--gold) !important;
  color: var(--gold) !important;
  transform: translateY(-2px);
}

/* ——— Hero (dark only here) ——— */
.hero-slider {
  position: relative;
  min-height: min(100vh, 900px);
  max-height: 900px;
  overflow: hidden;
  padding-top: 5.5rem;
  isolation: isolate;
  background: var(--navy);
}

.hero-flare {
  position: absolute;
  width: min(280px, 50vw);
  height: min(280px, 50vw);
  border-radius: 50%;
  pointer-events: none;
  z-index: var(--z-flare);
  filter: blur(70px);
  animation: flarePulse 8s ease-in-out infinite;
}

.hero-flare.flare-gold {
  background: radial-gradient(circle, rgba(212, 175, 55, 0.35), transparent 70%);
  top: 15%;
  right: 8%;
}

.hero-flare.flare-blue {
  background: radial-gradient(circle, rgba(201, 164, 92, 0.25), transparent 70%);
  bottom: 20%;
  left: 6%;
  animation-delay: 2s;
}

.hero-float-icons {
  display: none !important;
}

.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease;
  overflow: hidden;
  z-index: var(--z-hero-bg);
}

.hero-slide.active {
  opacity: 1;
  z-index: calc(var(--z-hero-bg) + 1);
}

.hero-bg-zoom {
  position: absolute;
  inset: 0;
  z-index: var(--z-hero-bg);
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
}

.hero-slide.active .hero-bg-zoom {
  animation: heroKenBurns 26s ease-in-out infinite alternate;
}

.hero-slide::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: var(--z-hero-overlay);
  background: linear-gradient(
    135deg,
    rgba(10, 15, 28, 0.82) 0%,
    rgba(10, 15, 28, 0.65) 50%,
    rgba(37, 99, 235, 0.15) 100%
  );
}

.hero-content {
  position: relative;
  z-index: var(--z-hero-content);
  animation: heroFadeIn 0.75s ease-out both;
}

.hero-content h1,
.hero-content .gold-text {
  color: #fff !important;
}

.hero-content .text-slate-300 {
  color: #cbd5e1 !important;
}

.hero-dots {
  z-index: var(--z-hero-content);
}

.hero-dots button {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.35);
  border: none;
  cursor: pointer;
  transition: width 0.25s ease, background 0.25s ease;
}

.hero-dots button.active {
  width: 24px;
  background: linear-gradient(90deg, var(--gold), var(--royal-glow));
}

.tag-rera {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  background: rgba(5, 150, 105, 0.15);
  color: var(--emerald) !important;
  border: 1px solid rgba(5, 150, 105, 0.3);
}

/* ——— Premium project cards (white, no flare) ——— */
.border-flare-card.project-card-premium {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 2px;
}

.project-card-premium,
.project-card {
  background: var(--bg-white);
  border: 1px solid var(--royal-border);
  border-radius: 1rem;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  box-shadow: var(--card-shadow);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.project-card-premium::before,
.project-card.border-animate-card::before,
.border-animate-card.project-card::before {
  display: none !important;
}

.project-card-premium:hover,
.project-card:hover {
  transform: translateY(-6px);
  border-color: var(--gold-soft);
  box-shadow: var(--card-shadow-hover);
}

.project-card-premium .card-inner,
.project-card > .card-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--bg-white);
  border-radius: 1rem;
  overflow: hidden;
}

.card-media,
.project-card .img-zoom-wrap:not(.rounded-2xl) {
  position: relative;
  width: 100%;
  height: var(--card-img-h);
  min-height: var(--card-img-h);
  max-height: var(--card-img-h);
  overflow: hidden;
  flex-shrink: 0;
  border-radius: 0;
}

.card-image,
.project-card .card-image,
.project-card img.card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.5s ease;
}

.project-card-premium:hover .card-image,
.project-card:hover .card-image {
  transform: scale(1.05);
}

.card-body,
.project-card .p-6,
.project-card .p-8 {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 1.5rem;
  background: var(--bg-white);
}

.project-badges {
  position: absolute;
  top: 0.85rem;
  left: 0.85rem;
  right: 0.85rem;
  z-index: 5;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  pointer-events: none;
}

.project-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.28rem 0.6rem;
  border-radius: 999px;
  font-size: 0.65rem;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid var(--royal-border);
  color: var(--text);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.project-badge.badge-rera {
  color: var(--emerald) !important;
  border-color: rgba(5, 150, 105, 0.3);
}

.project-badge.badge-ready {
  color: var(--gold) !important;
  border-color: var(--gold-soft);
}

/* ——— Light glass cards ——— */
.glass-card {
  background: var(--bg-white) !important;
  border: 1px solid var(--royal-border) !important;
  box-shadow: var(--card-shadow) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.glass-card:hover {
  transform: translateY(-4px);
  border-color: rgba(201, 162, 39, 0.35) !important;
  box-shadow: var(--card-shadow-hover) !important;
}

/* Project cards use .border-flare-card — not generic disable */
.form-enquiry-wrap {
  border: 1px solid var(--royal-border);
}

.form-enquiry-wrap {
  background: var(--bg-white) !important;
  border: 1px solid var(--royal-border) !important;
  border-radius: 1rem !important;
  box-shadow: var(--card-shadow) !important;
}

.border-animate::before {
  display: none !important;
}

.border-animate {
  padding: 0;
  background: none;
}

/* Stats */
.stat-box {
  transition: transform 0.25s ease;
}

.stat-box:hover {
  transform: translateY(-3px);
}

.counter-value {
  color: var(--royal-glow) !important;
  font-variant-numeric: tabular-nums;
}

.bg-emerald-50,
.bg-amber-50,
.bg-navy-card {
  background: var(--bg-soft) !important;
}

.bg-navy-card {
  border: 1px solid var(--royal-border);
}

.bg-soft-tag {
  background: var(--bg-soft) !important;
  color: var(--text) !important;
  border: 1px solid var(--royal-border);
}

/* Amenities */
.amenity-box {
  transition: transform 0.25s ease, border-color 0.25s ease;
}

.amenity-box:hover {
  transform: translateY(-3px);
  border-color: rgba(201, 162, 39, 0.35) !important;
}

.amenity-box:hover i {
  color: var(--royal-glow) !important;
}

.float-card,
.floating-icon {
  animation: none !important;
}

/* Reviews */
.review-card,
.testimonial-card {
  background: var(--bg-white) !important;
  border: 1px solid var(--royal-border) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.review-card:hover,
.testimonial-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--card-shadow-hover);
  border-color: rgba(201, 162, 39, 0.3) !important;
}

.review-card .stars i,
.testimonial-card .stars i,
.testimonial-card .text-gold-brand i {
  color: var(--gold) !important;
}

.highlight-item {
  color: var(--text-muted);
}

.highlight-item:hover {
  color: var(--royal);
}

.highlight-item i {
  color: var(--gold);
}

.highlight-item strong {
  color: var(--text);
}

/* Search */
.search-wrap {
  position: relative;
  max-width: 640px;
  margin: 0 auto 2rem;
}

.search-wrap i {
  position: absolute;
  left: 1.15rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--royal);
  pointer-events: none;
}

.project-search {
  width: 100%;
  padding: 0.9rem 1.15rem 0.9rem 2.85rem;
  border-radius: 999px;
  background: var(--bg-white);
  border: 1px solid var(--royal-border);
  color: var(--text);
  font-size: 0.9375rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.project-search:focus {
  outline: none;
  border-color: var(--royal);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

.project-card-hidden {
  display: none !important;
}

.section-title::after {
  content: '';
  display: block;
  width: 72px;
  height: 3px;
  background: linear-gradient(90deg, var(--royal), var(--gold));
  margin: 10px auto 0;
  border-radius: 2px;
}

.section-title.text-left::after {
  margin-left: 0;
}

/* Forms (light) */
.form-input {
  background: var(--bg-white) !important;
  border: 1px solid #e5e7eb !important;
  color: var(--text) !important;
  border-radius: 0.75rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-input:focus {
  border-color: var(--royal) !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12) !important;
  outline: none;
}

.form-input::placeholder {
  color: #9ca3af;
}

.form-success {
  background: #ecfdf5 !important;
  color: var(--emerald) !important;
  border: 1px solid rgba(5, 150, 105, 0.2);
}

/* WhatsApp button (popup) */
.btn-whatsapp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.85rem 1rem;
  border-radius: 0.75rem;
  font-weight: 600;
  font-size: 0.875rem;
  color: #fff !important;
  background: linear-gradient(135deg, #25d366, #128c7e) !important;
  border: none !important;
  box-shadow: 0 6px 18px rgba(37, 211, 102, 0.35);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  text-decoration: none;
  margin-top: 0.75rem;
}

.btn-whatsapp:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(37, 211, 102, 0.45);
  color: #fff !important;
}

/* Google reviews marquee */
.google-reviews-section {
  overflow: hidden;
}

.google-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 1rem;
  background: var(--bg-white);
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text);
  box-shadow: var(--card-shadow);
  margin-bottom: 1rem;
}

.google-badge .google-g {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: conic-gradient(from -45deg, #ea4335, #fbbc05, #34a853, #4285f4, #ea4335);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12px;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.reviews-marquee-wrap {
  overflow: hidden;
  width: 100%;
  mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}

.reviews-marquee-track {
  display: flex;
  gap: 1.25rem;
  width: max-content;
  animation: reviewsMarquee 45s linear infinite;
  padding: 0.5rem 0 1rem;
}

.reviews-marquee-track:hover {
  animation-play-state: paused;
}

.google-review-card {
  flex: 0 0 320px;
  max-width: 320px;
  background: var(--bg-white);
  border: 1px solid #e5e7eb;
  border-radius: 1rem;
  padding: 1.25rem;
  box-shadow: var(--card-shadow);
}

.google-review-card .review-top {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.google-review-card .review-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--royal), var(--gold));
  color: #fff;
  font-weight: 700;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.google-review-card .review-meta h4 {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
}

.google-review-card .review-meta .google-stars {
  color: #fbbc04;
  font-size: 0.75rem;
  letter-spacing: 1px;
}

.google-review-card .review-meta .posted {
  font-size: 0.7rem;
  color: #9ca3af;
}

.google-review-card .review-text {
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--text-muted);
  margin: 0;
}

.google-review-card .review-google-icon {
  margin-top: 0.75rem;
  font-size: 0.7rem;
  color: #9ca3af;
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

/* Popup — white + border flare */
.enquiry-popup-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-popup);
  background: rgba(10, 15, 28, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.enquiry-popup-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.enquiry-popup {
  width: 100%;
  max-width: 440px;
  position: relative;
  animation: popupZoom 0.35s ease;
}

.enquiry-popup.border-flare::before {
  opacity: 1;
  animation-duration: 10s;
}

.enquiry-popup-inner {
  background: var(--bg-white);
  border-radius: calc(1.25rem - 2px);
  padding: 1.75rem;
  border: none;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.12);
  position: relative;
}

.enquiry-popup-inner h2 {
  color: var(--text) !important;
}

.enquiry-popup-inner .text-slate-400 {
  color: var(--text-muted) !important;
}

.popup-close {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--bg-soft);
  color: var(--gold);
  border: 1px solid var(--gold-soft);
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
  z-index: 2;
}

.popup-close:hover {
  background: var(--gold);
  color: #fff;
  transform: scale(1.05);
}

/* Footer (dark) */
.site-footer {
  background: linear-gradient(180deg, var(--navy-light), var(--navy)) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  color: #e2e8f0;
}

.site-footer .text-white,
.site-footer h4 {
  color: #f8fafc !important;
}

.site-footer .text-slate-600,
.site-footer .text-slate-500,
.site-footer p,
.site-footer li,
.site-footer a:not(:hover) {
  color: #94a3b8 !important;
}

.site-footer a:hover {
  color: var(--gold-light) !important;
}

.footer-credit {
  margin-top: 0.5rem;
  font-size: 0.8rem;
  color: #94a3b8 !important;
}

.footer-credit a {
  color: var(--gold) !important;
  font-weight: 600;
}

.border-slate-200 {
  border-color: rgba(255, 255, 255, 0.1) !important;
}

footer a.w-10,
.social-btn {
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  color: var(--gold-light) !important;
}

footer a.w-10:hover {
  transform: scale(1.06);
  border-color: var(--gold) !important;
}

/* WhatsApp */
.whatsapp-float {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 99;
  width: 54px;
  height: 54px;
  background: linear-gradient(135deg, #25d366, #128c7e);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 1.5rem;
  box-shadow: 0 6px 20px rgba(37, 211, 102, 0.35);
  transition: transform 0.25s ease;
}

.whatsapp-float:hover {
  transform: scale(1.06);
}

/* Scroll reveal */
.reveal,
.reveal-left,
.reveal-right,
.reveal-zoom {
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal { transform: translateY(24px); }
.reveal-left { transform: translateX(-20px); }
.reveal-right { transform: translateX(20px); }
.reveal-zoom { transform: scale(0.98); }

.reveal.revealed,
.reveal-left.revealed,
.reveal-right.revealed,
.reveal-zoom.revealed {
  opacity: 1;
  transform: none;
}

.delay-100 { transition-delay: 0.08s; }
.delay-200 { transition-delay: 0.16s; }
.delay-300 { transition-delay: 0.24s; }

/* Project detail hero */
.project-hero-img {
  transition: transform 10s ease-out;
}

.project-hero:hover .project-hero-img {
  transform: scale(1.03);
}

.map-placeholder {
  background: var(--bg-soft) !important;
  border: 2px dashed var(--royal-border) !important;
  color: var(--text-muted);
}

.legal-content {
  background: var(--bg-white);
  border: 1px solid var(--royal-border);
  border-radius: 1rem;
}

.legal-content h2 {
  color: var(--text) !important;
}

.legal-content p,
.legal-content li {
  color: var(--text-muted) !important;
}

main,
.hero-slider,
.page-hero {
  scroll-margin-top: 6rem;
}

/* Tailwind gradient overrides on light sections */
[class*="from-emerald-50"],
.bg-gradient-to-r.from-emerald-50 {
  background: var(--bg-soft) !important;
}

@media (max-width: 768px) {
  :root {
    --card-img-h: var(--card-img-h-m);
  }

  .hero-flare {
    opacity: 0.1;
    width: 200px;
    height: 200px;
  }

  .hero-slider:not(.hero-video-slider) {
    min-height: 85vh;
    padding-top: 5rem;
  }

  .project-card-premium:hover,
  .project-card:hover {
    transform: translateY(-4px);
  }
}

/* ——— Projects tabs & status badges ——— */
.projects-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem;
  margin-bottom: 2.5rem;
  padding: 0.35rem;
  background: var(--bg-white);
  border: 1px solid var(--royal-border);
  border-radius: 999px;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
  box-shadow: var(--card-shadow);
}

.projects-tab {
  flex: 1;
  min-width: 10rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.85rem 1.25rem;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-muted);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}

.projects-tab:hover {
  color: var(--navy);
}

.projects-tab.active {
  color: var(--navy);
  background: linear-gradient(135deg, rgba(212, 175, 55, 0.2), rgba(37, 99, 235, 0.12));
  box-shadow: 0 2px 12px rgba(10, 15, 28, 0.08);
}

.projects-tab .tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  height: 1.5rem;
  padding: 0 0.4rem;
  border-radius: 999px;
  font-size: 0.7rem;
  background: rgba(10, 15, 28, 0.08);
  color: var(--navy);
}

.projects-tab.active .tab-count {
  background: var(--navy);
  color: #fff;
}

.projects-panel.panel-empty {
  display: none;
}

.project-badge.badge-completed {
  color: #050505 !important;
  border-color: rgba(184, 134, 11, 0.5);
  background: linear-gradient(135deg, #b8860b, #d4af37);
}

.project-badge.badge-ongoing {
  color: #050505 !important;
  border-color: rgba(212, 175, 55, 0.5);
  background: linear-gradient(135deg, #d4af37, #ffd700);
}

.project-badge.badge-featured {
  color: var(--gold) !important;
  border-color: var(--gold-soft);
  background: rgba(255, 251, 235, 0.95);
}

.card-image-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-placeholder-icon {
  width: 4rem;
  height: 4rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  color: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(4px);
}

.project-card-highlight {
  box-shadow: 0 12px 40px rgba(212, 175, 55, 0.15), var(--card-shadow);
}

.project-card-highlight:hover {
  box-shadow: 0 16px 48px rgba(212, 175, 55, 0.22), var(--card-shadow-hover);
}

.featured-more-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0.75rem;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--gold-soft) transparent;
}

.featured-more-track {
  display: flex;
  gap: 1.5rem;
  width: max-content;
  padding: 0.25rem 0.25rem 0.5rem;
}

.featured-more-track .project-card {
  width: min(320px, 85vw);
  flex-shrink: 0;
}

.featured-more-track .card-media {
  height: 200px;
  min-height: 200px;
  max-height: 200px;
}

.projects-grid .project-card .card-body .flex.flex-wrap.gap-2 {
  margin-top: auto;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .hero-flare {
    display: none;
  }
}
