/* ============================================================
   SRI GARUDA DECORATORS — COMMON CSS
   WhatsApp float CTA, scroll-to-top button, shared utilities
   ============================================================ */


   /* ============================================================
   SITE LOADER
============================================================ */

#site-loader {
  position: fixed;
  inset: 0;
  background: #FBE9ED;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999999;
  transition:
    opacity 0.5s ease,
    visibility 0.5s ease;
}

#site-loader.hide {
  opacity: 0;
  visibility: hidden;
}

.loader-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
}

.loader-content img {
  width: 90px;
  height: auto;
  object-fit: contain;
  animation: loaderFloat 2s ease-in-out infinite;
}

.loader-ring {
  width: 46px;
  height: 46px;
  border: 3px solid rgba(181, 82, 103, 0.18);
  border-top-color: #B55267;
  border-radius: 50%;
  animation: loaderSpin 1s linear infinite;
}

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

@keyframes loaderFloat {
  0%,100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-8px);
  }
}

/* ── WhatsApp Floating Button ── */
.wa-float {
  position: fixed;
  bottom: 28px;
  right: 24px;
  z-index: var(--z-float);
  display: flex;
  flex-direction: row;   /* changed */
  align-items: center;
  gap: 10px;
}

.wa-tooltip {
  background: var(--deep-wine);
  color: var(--champagne-beige);
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 6px 12px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border-dark);
  white-space: nowrap;
  opacity: 0;
 transform: translateX(10px);
  transition: opacity var(--transition-fast), transform var(--transition-fast);
  pointer-events: none;
}

.wa-float:hover .wa-tooltip {
  opacity: 1;
  transform: translateX(0);
}

.wa-btn {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
  transition: transform var(--transition-fast),
              box-shadow var(--transition-fast);
  text-decoration: none;
  animation: wa-pulse 3s ease-in-out infinite;
}

.wa-btn:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 28px rgba(37, 211, 102, 0.55);
  animation: none;
}

.wa-btn svg {
  width: 28px;
  height: 28px;
  fill: #ffffff;
}

@keyframes wa-pulse {
  0%, 100% { box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4); }
  50%       { box-shadow: 0 4px 28px rgba(37, 211, 102, 0.65), 0 0 0 8px rgba(37, 211, 102, 0.1); }
}

/* ── Scroll To Top Button ── */
.scroll-top-btn {
  position: fixed;
  bottom: 96px;
  right: 24px;
  z-index: var(--z-float);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--dark-maroon);
  border: 1px solid var(--color-border-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity var(--transition-base),
              transform var(--transition-base),
              background var(--transition-fast);
  pointer-events: none;
}

.scroll-top-btn.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}

.scroll-top-btn:hover {
  background: var(--burgundy);
}

.scroll-top-btn svg {
  width: 16px;
  height: 16px;
  fill: var(--champagne-beige);
}

/* ── Utility: Section Padding ── */
.section-pad {
  padding: var(--space-3xl) 0;
}

.section-pad-sm {
  padding: var(--space-2xl) 0;
}

.container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

/* ── Utility: Section Heading ── */
.section-label {
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--burgundy);
  display: block;
  margin-bottom: var(--space-sm);
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 600;
  line-height: 1.15;
  color: var(--text-dark);
}

.section-title.on-dark {
  color: var(--champagne-beige);
}

.section-subtitle {
  font-size: 0.9rem;
  color: var(--text-muted);
  line-height: 1.8;
  max-width: 560px;
  margin-top: var(--space-md);
}

.section-subtitle.on-dark {
  color: var(--champagne-beige);
  opacity: 0.65;
}

/* ── Utility: Gold Divider ── */
.gold-divider {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin: var(--space-md) 0;
}

.gold-divider::before,
.gold-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--sand-gold));
}

.gold-divider::after {
  background: linear-gradient(to left, transparent, var(--sand-gold));
}

.gold-divider-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--sand-gold);
  flex-shrink: 0;
}

/* ── Scroll Reveal Base ── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* ── Page Top Offset (for fixed header) ── */
.page-content {
  padding-top: 80px;
}

/* ── Responsive Floating Buttons ── */
@media (max-width: 480px) {
  .wa-float {
    bottom: 20px;
    right: 16px;
  }

  .wa-btn {
    width: 50px;
    height: 50px;
  }

  .scroll-top-btn {
    bottom: 82px;
    right: 16px;
    width: 36px;
    height: 36px;
  }

  .container {
    padding: 0 var(--space-md);
  }
}

#site-loader.hide {
  pointer-events: none !important;
}
#site-loader {
  pointer-events: none;
}
.nav-mobile-overlay:not(.active) {
  display: none !important;
  pointer-events: none !important;
}
