/* Global & Fonts */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=Open+Sans:wght@300;400;600&display=swap');

:root{
  /* Bright theme colors */
  --darkblue:#1B254B; /* restored dark navy for headings/text */
  --accent:#C49B66; /* restored gold accent */
  --accent-rgb:196,155,102; /* rgb for gold */
  --gold:var(--accent); /* legacy alias kept */
  --cream:#FFFFFF; /* white page background */
  --muted:#6b6b6b;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'Open Sans',sans-serif;background:var(--cream);color:#222}
.container{max-width:1180px;margin:0 auto;padding:0 18px}

/* NAV */
.nav-wrap{position:fixed;left:0;right:0;top:0;z-index:60;backdrop-filter:saturate(1) blur(4px)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.logo{display:flex;gap:12px;align-items:center}
.pi{background:var(--gold);color:var(--darkblue);width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-family:'Playfair Display',serif}
.brand{font-weight:700}
.tag{font-size:12px;color:var(--darkblue);margin-top:2px}

/* ensure logo anchor doesn't get default link styling */
.logo{display:flex;gap:12px;align-items:center}
.logo a{color:inherit;text-decoration:none;display:flex;align-items:center;gap:12px}
.nav-links{display:flex;gap:18px;align-items:center}
/* default nav link color: dark (black-ish) */
.nav-links a{color:var(--darkblue);text-decoration:none;padding:8px 10px;border-radius:4px;font-weight:600}
.nav-links a.active,.nav-links a:hover{background:rgba(0,0,0,0.04);color:var(--gold)}

/* when mobile menu is opened we toggle .open on .nav-links so links become readable on dark overlay */
.nav-links.open{display:flex}
.nav-links.open a{color:#fff}
.nav-cta{display:flex;align-items:center;gap:12px}
.btn-accent{background:var(--accent);color:var(--darkblue);padding:10px 14px;border-radius:6px;text-decoration:none;font-weight:700}
/* keep legacy class for compatibility */
.btn-gold{background:var(--gold);color:var(--darkblue);padding:10px 14px;border-radius:6px;text-decoration:none;font-weight:700}
.hamburger{display:none;background:transparent;border:0;color:var(--gold);font-size:20px;padding:6px;border-radius:6px}
.hamburger:hover,.hamburger:focus{background:rgba(27,37,75,0.06);outline:none}

/* HERO SLIDER */
.hero-slider{margin-top:78px}
.slides{position:relative;overflow:hidden;height:560px}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;display:flex;align-items:center}
.slide .overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(27,37,75,0.55), rgba(27,37,75,0.65))}
.hero-content{position:relative;color:#fff;max-width:640px;padding:40px}
.hero-content h1{font-family:'Playfair Display',serif;font-size:40px;margin:0 0 12px}
.hero-content p{margin:0 0 18px;color:#f1f1f1}
.hero-actions{display:flex;gap:12px}
.btn-outline{background:transparent;border:2px solid var(--gold);color:var(--gold);padding:10px 14px;border-radius:6px;text-decoration:none;font-weight:700}

.slider-controls{margin-top:24px;pointer-events:none}
.info-cards{display:flex;gap:14px;justify-content:space-between;pointer-events:auto;flex-wrap:wrap}
.info-card{background:#fff;padding:18px;border-radius:10px;flex:1;min-width:140px;text-align:center;box-shadow:0 8px 30px rgba(27,37,75,0.08)}
.info-card strong{display:block;font-size:24px;color:var(--darkblue);margin-bottom:6px}
.info-card span{color:var(--muted)}

/* Gold-heavy hover effect for cards */
.info-card,
.service-card,
.testi-card{
  transition:transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s ease, border-color .28s ease;
  will-change:transform, box-shadow;
  border:1px solid transparent;
}
.info-card:hover,
.service-card:hover,
.testi-card:hover{
  transform:translateY(-10px);
  box-shadow:0 22px 50px rgba(var(--accent-rgb),0.18), 0 8px 30px rgba(27,37,75,0.08);
  border-color:rgba(var(--accent-rgb),0.22);
  /* make the whole card take on the bright accent tone with readable text */
  background:var(--gold);
  color:#072136; /* darker contrast for text on bright backgrounds */
}

/* Gallery images: add gold glow + slight lift on hover */
.gallery-img{transition:transform .28s ease, box-shadow .28s ease}
.gallery-img:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 18px 40px rgba(var(--accent-rgb),0.12);border:3px solid rgba(var(--accent-rgb),0.18)}

/* Emphasize heading when card hovered */
.info-card:hover strong,
.service-card:hover h4,
.testi-card:hover strong{
  color:var(--darkblue);
}

/* ABOUT PREVIEW */
.about-preview{padding:60px 0}
.about-grid{display:flex;gap:30px;align-items:center;flex-wrap:wrap}
.about-img img{width:100%;height:300px;object-fit:cover;border-radius:8px;box-shadow:0 10px 30px rgba(0,0,0,0.08)}
.about-text{max-width:580px}
.section-title{color:var(--darkblue);font-family:'Playfair Display',serif;margin-bottom:18px}

/* SERVICES */
.services-preview{padding:40px 0}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.service-card{background:#fff;border-radius:8px;padding:12px;box-shadow:0 8px 20px rgba(0,0,0,0.06);text-align:center}
.service-card img{width:100%;height:140px;object-fit:cover;border-radius:6px}

/* GALLERY */
.gallery-preview{padding:40px 0}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.gallery-img{width:100%;height:140px;object-fit:cover;border-radius:6px;cursor:pointer;transition:transform .25s}
  .gallery-img{
    transition:transform .32s cubic-bezier(.2,.8,.2,1), box-shadow .32s ease, border-color .28s ease, filter .28s ease;
    will-change:transform, box-shadow;
    position:relative;
    z-index:0;
  }
  .gallery-img:hover{
    transform:translateY(-12px) scale(1.06);
    box-shadow:0 30px 60px rgba(var(--accent-rgb),0.22), 0 12px 30px rgba(27,37,75,0.08);
    border:4px solid rgba(var(--accent-rgb),0.18);
    filter:brightness(1.03);
    z-index:10;
  }

/* TESTIMONIALS */
.testimonials{padding:36px 0}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.testi-card{background:#fff;padding:18px;border-radius:8px;box-shadow:0 8px 20px rgba(0,0,0,0.06)}
.testi-card p{color:#444;font-size:15px}

/* CONTACT PREVIEW */
.contact-preview{padding:40px 0}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:center}
.contact-info a{color:var(--darkblue);font-weight:700}
.center{text-align:center;margin-top:14px}

/* FOOTER */
.footer{background:var(--darkblue);color:#fff;padding:24px 0;margin-top:40px}
.footer-grid{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}

/* LIGHTBOX */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.9);align-items:center;justify-content:center;z-index:1200}
.lightbox .lb-img{max-width:92%;max-height:92%;border-radius:6px}
.lb-close{position:absolute;top:22px;right:28px;color:#fff;font-size:40px;cursor:pointer}

/* Whatsapp float */
.whatsapp-float{position:fixed;right:18px;bottom:18px;background:var(--accent);color:var(--darkblue);padding:14px;border-radius:50%;text-decoration:none;font-size:20px;box-shadow:0 6px 20px rgba(0,0,0,0.15)}
/* Floating WhatsApp button */
.whatsapp-float {
  position: fixed;
  bottom: 20px;
  right: 20px;
  background-color: var(--accent);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
  z-index: 1000;
  transition: transform 0.2s ease;
}
.whatsapp-float:hover {
  transform: scale(1.1);
}
.whatsapp-float img {
  width: 28px;
  height: 28px;
}
.video-text-section {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin: 40px auto;
}

/* LEFT SMALL VIDEO BOX */
.video-box-left {
  width: 280px;
  border-radius: 10px;
  overflow: hidden;
  border: 2px solid #d4a047;
}

.video-box-left video {
  width: 100%;
  display: block;
  border-radius: 10px;
}

/* RIGHT SIDE TEXT */
.video-info-right {
  flex: 1;
}

.video-info-right h3 {
  margin-bottom: 10px;
}

.video-info-right p {
  margin-bottom: 15px;
  line-height: 1.4;
}

/* Responsive (Mobile View) */
@media (max-width: 768px) {
  .video-text-section {
    flex-direction: column;
    text-align: center;
  }

  .video-box-left {
    width: 80%;
    margin: 0 auto;
  }

  .video-info-right {
    width: 100%;
  }
}

.map-buttons {
  text-align: center;
  margin-top: 10px;
}
.map-buttons .btn-accent {
  display: inline-block;
  background: var(--accent);
  color: var(--darkblue);
  font-weight: 600;
  padding: 10px 18px;
  border-radius: 8px;
  text-decoration: none;
  transition: transform 0.25s;
}
.map-buttons .btn-accent:hover {
  transform: scale(1.05);
}
/* keep legacy selector for compatibility */
.map-buttons .btn-gold{display:inline-block;background:var(--gold);color:var(--darkblue);font-weight:600;padding:10px 18px;border-radius:8px;text-decoration:none;transition:transform .25s}
.map-buttons .btn-gold:hover{transform:scale(1.05)}

/* Modern contact form styles */
.contact-form{background:#fff;padding:18px;border-radius:10px;box-shadow:0 12px 30px rgba(27,37,75,0.06);max-width:860px;margin-top:18px}
.contact-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-form .form-field{display:flex;flex-direction:column}
.contact-form .form-field.full{grid-column:1 / -1}
.contact-form label{font-size:13px;color:var(--darkblue);margin-bottom:6px;font-weight:600}
.contact-form input[type="text"],
.contact-form input[type="tel"],
.contact-form input[type="email"],
.contact-form textarea{
  padding:12px 14px;border-radius:8px;border:1px solid rgba(27,37,75,0.08);font-size:15px;transition:box-shadow .18s ease, border-color .18s ease;resize:vertical;background:#fff;color:#111
}
.contact-form textarea{min-height:140px}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:rgba(var(--accent-rgb),0.9);box-shadow:0 8px 24px rgba(var(--accent-rgb),0.12)}
.contact-form .form-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.contact-form .form-actions .hint{color:var(--muted);font-size:13px}
.contact-form .btn-accent{padding:10px 18px;border-radius:8px}
/* legacy */
.contact-form .btn-gold{padding:10px 18px;border-radius:8px}

@media(max-width:720px){
  .contact-form .form-grid{grid-template-columns:1fr}
  .contact-form .form-actions{flex-direction:column;align-items:stretch}
  .contact-form .form-actions .hint{text-align:left}
}
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
}

.logo-img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  border-radius: 50%;
  background: #fff;
  padding: 3px;
  box-shadow: 0 0 10px rgba(0,0,0,0.1);
}

/* Responsive */
@media(max-width:900px){
  .hero-content h1{font-size:30px}
  .slides{height:460px}
  .nav-links{display:none}
  .hamburger{display:inline-block}
  .info-cards{gap:10px}
  .about-grid{flex-direction:column}
  .contact-grid{grid-template-columns:1fr}
}
/* Small video box */
.video-box {
  margin: 40px auto;
  text-align: center;
}

.video-wrapper {
  position: relative;
  width: 300px;
  margin: 0 auto;
  border-radius: 10px;
  overflow: hidden;
  border: 2px solid #d4a047;
}
.video-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 20px;
  margin-bottom: 40px;
}

.video-card {
  background: #fff;
  border-radius: 12px;
  padding: 15px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  text-align: center;
}

.video-thumb {
  width: 100%;
  height: 150px;
  border-radius: 12px;
  object-fit: cover;
  background: #000;
}

.video-actions {
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
}

.play-btn {
  background: #222;
  color: #fff;
  border: none;
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 16px;
}

.extend-btn {
  background: #0077ff;
  color: white;
  border: none;
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
}

.play-btn:hover,
.extend-btn:hover {
  opacity: 0.8;
}

.video-wrapper video {
  width: 100%;
  height: auto;
  display: block;
}
.testi-card {
  background: #fff;
  padding: 20px;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  text-align: center;
}
.gallery-video {
  width: 100%;
  height: auto;
  border-radius: 10px;
  cursor: pointer;
  transition: transform 0.3s;
}

.gallery-video:hover {
  transform: scale(1.05);
}

.lightbox-video {
  width: 90%;
  max-width: 800px;
  display: none;
  border-radius: 10px;
}

.testi-img {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  object-fit: cover;
  margin-bottom: 12px;
  border: 3px solid #d4a047;
}

.expand-btn {
  position: absolute;
  bottom: 8px;
  right: 8px;
  background: rgba(0,0,0,0.6);
  color: white;
  border: none;
  padding: 6px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
}

/* Fullscreen popup modal */
.video-modal {
  display: none; 
  position: fixed;
  z-index: 2000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
}

.video-modal-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 700px;
}

.video-modal video {
  width: 100%;
  border-radius: 10px;
}

.close-modal {
  position: absolute;
  top: -35px;
  right: -5px;
  font-size: 35px;
  color: #fff;
  cursor: pointer;
}
