/* ================================================================
   Renovation Gallery — Premium Dark Theme Grid & Hover Animations
   Triple R Partners
   ================================================================ */

:root {
  --renovation-bg:            #09090b;
  --renovation-surface:       rgba(24, 24, 28, 0.75);
  --renovation-border:        rgba(212, 175, 55, 0.18);
  --renovation-gold:          #d4af37;
  --renovation-gold-light:    #e8cc6a;
  --renovation-text:          #f5f5f7;
  --renovation-text-muted:    #9e9ea8;
  --renovation-glow:          0 10px 30px rgba(212, 175, 55, 0.2);
  --renovation-transition:    all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.rr-renovation-gallery {
  width: 100%;
  margin: 3rem 0;
}

/* Dynamic CSS Grid Columns link with JS */
.rr-renovation-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  padding: 1rem;
}

.rr-renovation-gallery[data-columns="2"] .rr-renovation-grid {
  grid-template-columns: repeat(2, 1fr);
}
.rr-renovation-gallery[data-columns="3"] .rr-renovation-grid {
  grid-template-columns: repeat(3, 1fr);
}
.rr-renovation-gallery[data-columns="4"] .rr-renovation-grid {
  grid-template-columns: repeat(4, 1fr);
}

/* Individual Premium Dark renovation card */
.rr-renovation-item {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  background: var(--renovation-surface) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--renovation-border) !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5) !important;
  transition: var(--renovation-transition) !important;
}

.rr-renovation-item:hover,
.rr-renovation-item.force-hover,
.rr-renovation-item.focused {
  transform: translateY(-8px) !important;
  border-color: var(--renovation-gold) !important;
  box-shadow: var(--renovation-glow), 0 15px 40px rgba(0, 0, 0, 0.6) !important;
}

/* Touch active state */
.rr-renovation-item.touch-active {
  transform: scale(0.98);
  transition: transform 0.1s ease;
}

/* Main image container */
.rr-renovation-main-image {
  position: relative;
  width: 100%;
  height: 380px; /* Golden-ratio scale */
  overflow: hidden;
  border-bottom: 1px solid var(--renovation-border);
}

/* Title below the card */
.rr-renovation-title-below {
  padding: 2rem 1.5rem;
  text-align: center;
  background: transparent !important;
}

.rr-renovation-title-below h3 {
  margin: 0;
  font-size: 15px !important;
  font-weight: 700 !important;
  line-height: 1.4;
  color: var(--renovation-text) !important;
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  transition: var(--renovation-transition) !important;
}

.rr-renovation-item:hover .rr-renovation-title-below h3,
.rr-renovation-item.force-hover .rr-renovation-title-below h3 {
  color: var(--renovation-gold) !important;
}

.rr-renovation-link {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: inherit;
}

.rr-main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--renovation-transition) !important;
}

.rr-renovation-item:hover .rr-main-img,
.rr-renovation-item.force-hover .rr-main-img {
  transform: scale(1.04);
}

/* No image fallback */
.rr-no-image {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #111114 0%, #1a1a20 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--renovation-gold);
  border: 1px solid var(--renovation-border);
  font-weight: 600;
  text-align: center;
  padding: 1rem;
}

/* Hover grid container - Premium Dark Glassmorphism */
.rr-renovation-hover-grid {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(9, 9, 11, 0.88) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  visibility: hidden;
  transition: var(--renovation-transition) !important;
  z-index: 10;
  pointer-events: none;
}

/* Desktop hover effects */
@media (hover: hover) and (pointer: fine) {
  .rr-renovation-item:hover .rr-renovation-hover-grid,
  .rr-renovation-item.force-hover .rr-renovation-hover-grid {
    opacity: 1;
    visibility: visible;
  }

  .rr-renovation-item:hover .rr-hover-grid-item,
  .rr-renovation-item.force-hover .rr-hover-grid-item {
    transform: translateY(0) scale(1) !important;
    opacity: 1 !important;
  }

  /* Staggered animations for grid items */
  .rr-renovation-item:hover .rr-hover-grid-item:nth-child(1),
  .rr-renovation-item.force-hover .rr-hover-grid-item:nth-child(1) { transition-delay: 0.05s; }
  
  .rr-renovation-item:hover .rr-hover-grid-item:nth-child(2),
  .rr-renovation-item.force-hover .rr-hover-grid-item:nth-child(2) { transition-delay: 0.1s; }
  
  .rr-renovation-item:hover .rr-hover-grid-item:nth-child(3),
  .rr-renovation-item.force-hover .rr-hover-grid-item:nth-child(3) { transition-delay: 0.15s; }
  
  .rr-renovation-item:hover .rr-hover-grid-item:nth-child(4),
  .rr-renovation-item.force-hover .rr-hover-grid-item:nth-child(4) { transition-delay: 0.2s; }
  
  .rr-renovation-item:hover .rr-hover-grid-item:nth-child(5),
  .rr-renovation-item.force-hover .rr-hover-grid-item:nth-child(5) { transition-delay: 0.25s; }
}

/* Mobile: disable hover effects */
@media (hover: none) and (pointer: coarse) {
  .rr-renovation-hover-grid {
    display: none !important;
  }
  .rr-renovation-item {
    transform: none !important;
  }
  .rr-main-img {
    transform: none !important;
  }
}

/* Additional mobile safeguard */
@media (max-width: 768px) {
  .rr-renovation-hover-grid {
    display: none !important;
  }
}

/* Dynamic grid containers based on image count */
.rr-hover-grid-container {
  display: grid;
  gap: 8px;
  padding: 12px;
  height: 100%;
  width: 100%;
  box-sizing: border-box;
}

.rr-hover-grid-container[data-count="1"] { grid-template-columns: 1fr; grid-template-rows: 1fr; }
.rr-hover-grid-container[data-count="2"] { grid-template-columns: repeat(2, 1fr); grid-template-rows: 1fr; }
.rr-hover-grid-container[data-count="3"] { grid-template-columns: repeat(3, 1fr); grid-template-rows: 1fr; }
.rr-hover-grid-container[data-count="4"] { grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(2, 1fr); }
.rr-hover-grid-container[data-count="5"] { grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(2, 1fr); }

/* Individual grid items */
.rr-hover-grid-item {
  overflow: hidden;
  border-radius: 8px;
  background: #111114;
  border: 1px solid rgba(255, 255, 255, 0.05);
  transform: translateY(15px) scale(0.95);
  opacity: 0;
  transition: var(--renovation-transition) !important;
  position: relative;
}

.rr-hover-grid-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--renovation-transition) !important;
}

.rr-hover-grid-item:hover {
  border-color: var(--renovation-gold) !important;
  box-shadow: 0 0 15px rgba(212, 175, 55, 0.4) !important;
  z-index: 5;
}

.rr-hover-grid-item:hover img {
  transform: scale(1.08) !important;
}

/* Loading state for grid items */
.rr-hover-grid-item.loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  margin: -10px 0 0 -10px;
  border: 2px solid #222;
  border-top: 2px solid var(--renovation-gold);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.rr-hover-grid-item.error {
  background: #2a1111;
  border-color: #8a2a2a !important;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ff6b6b;
}

.rr-hover-grid-item.error::after {
  content: "✕";
  font-size: 1.2rem;
}

/* Responsive adjustments */
@media (max-width: 1024px) {
  .rr-renovation-main-image {
    height: 320px;
  }
}

@media (max-width: 768px) {
  .rr-renovation-grid {
    gap: 2rem;
    padding: 0.5rem;
  }

  .rr-renovation-main-image {
    height: 280px;
  }

  .rr-renovation-title-below {
    padding: 1.5rem 1rem;
  }

  .rr-renovation-title-below h3 {
    font-size: 13px !important;
  }

  .rr-hover-grid-container {
    gap: 4px;
    padding: 6px;
  }
}

@media (max-width: 480px) {
  .rr-renovation-main-image {
    height: 240px;
  }
}

/* Loading animation spinner */
.rr-renovation-item.loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 30px;
  height: 30px;
  margin: -15px 0 0 -15px;
  border: 3px solid #222;
  border-top: 3px solid var(--renovation-gold);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  z-index: 20;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Accessibility / Focus States */
.rr-renovation-link:focus {
  outline: 2px solid var(--renovation-gold);
  outline-offset: 2px;
}

.rr-renovation-item:focus-within {
  transform: translateY(-8px) !important;
  border-color: var(--renovation-gold) !important;
  box-shadow: var(--renovation-glow), 0 15px 40px rgba(0, 0, 0, 0.6) !important;
}

/* JavaScript enabled hover logic link */
.rr-renovation-gallery.js-enabled .rr-renovation-item {
  cursor: pointer;
}

/* ================================================================
   Renovation Pages Global Secondary Color & Font Overrides
   Forces all text elements utilizing Elementor's secondary global color
   to render in white, and shifts headings from "Calligraffitti" to
   "Montserrat" premium sans-serif styling across all languages.
   ================================================================ */
body.rrr-renovation-page .elementor-heading-title,
body.rrr-renovation-page .elementor-heading-title *,
body.rrr-renovation-page .elementor-widget-text-editor,
body.rrr-renovation-page .elementor-widget-text-editor *,
body.rrr-renovation-page .elementor-icon-list-text,
body.rrr-renovation-page .elementor-icon-list-text *,
body.rrr-renovation-page p,
body.rrr-renovation-page span,
body.rrr-renovation-page a,
body.rrr-renovation-page li,
body.rrr-renovation-page h1,
body.rrr-renovation-page h2,
body.rrr-renovation-page h3,
body.rrr-renovation-page h4,
body.rrr-renovation-page h5,
body.rrr-renovation-page h6 {
  --e-global-color-secondary: #ffffff !important;
}

body.rrr-renovation-page .elementor,
body.rrr-renovation-page .elementor *:not(i):not([class^="fa-"]):not([class*=" fa-"]):not([class^="eicon-"]):not([class*=" eicon-"]):not(.elementor-social-icon):not(.elementor-icon) {
  font-family: "Montserrat", sans-serif !important;
}

/* Safety restore for FontAwesome and Elementor Icons if targeted by general rules */
body.rrr-renovation-page .fab,
body.rrr-renovation-page .fab * {
  font-family: "Font Awesome 5 Brands" !important;
}
body.rrr-renovation-page .fas,
body.rrr-renovation-page .fas * {
  font-family: "Font Awesome 5 Free" !important;
  font-weight: 900 !important;
}
body.rrr-renovation-page .far,
body.rrr-renovation-page .far * {
  font-family: "Font Awesome 5 Free" !important;
  font-weight: 400 !important;
}
body.rrr-renovation-page [class^="eicon-"],
body.rrr-renovation-page [class*=" eicon-"] {
  font-family: "elementor-icons" !important;
}
