/* ================================================================
   LocdByPhilly — Luxury Salon Stylesheet
   A lavish dark-gold aesthetic with cinematic animations
   ================================================================ */

/* ------------------------------------------------
   1. CUSTOM PROPERTIES
   ------------------------------------------------ */
:root {
  /* ---- Palette ---- */
  --dark:            #060606;
  --dark-2:          #111111;
  --dark-3:          #1a1a1a;
  --dark-4:          #222222;
  --gold:            #c9a84c;
  --gold-light:      #e2ca7b;
  --gold-pale:       #f0e2b5;
  --cream:           #f2ece0;
  --cream-dim:       rgba(242,236,224,.7);
  --rose:            #c27685;
  --rose-deep:       #a0525f;
  --white:           #ffffff;

  /* ---- Fonts ---- */
  --ff-display:  'Playfair Display', Georgia, serif;
  --ff-body:     'Poppins', 'Segoe UI', sans-serif;
  --ff-accent:   'Cormorant Garamond', 'Times New Roman', serif;

  /* ---- Misc ---- */
  --radius:      4px;
  --ease:        cubic-bezier(.25,.46,.45,.94);
  --ease-bounce: cubic-bezier(.34,1.56,.64,1);
  --shadow-gold: 0 8px 32px rgba(201,168,76,.18);
  --shadow-lg:   0 24px 64px rgba(0,0,0,.45);
}

/* ------------------------------------------------
   2. RESET & BASE
   ------------------------------------------------ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

html{
  scroll-behavior:smooth;
  font-size:16px;
  scrollbar-width:thin;
  scrollbar-color:var(--gold) var(--dark);
}

body{
  font-family:var(--ff-body);
  font-weight:400;
  font-size:1rem;
  line-height:1.75;
  color:var(--cream);
  background:var(--dark);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

::-webkit-scrollbar{width:7px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:10px}

::selection{background:rgba(201,168,76,.35);color:var(--gold-light)}

img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color .3s var(--ease)}
ul{list-style:none}

h1,h2,h3,h4,h5,h6{
  font-family:var(--ff-display);
  font-weight:700;
  line-height:1.25;
  color:var(--cream);
}

section{
  padding:110px 0;
  position:relative;
}

.container{
  max-width:1240px;
  margin:0 auto;
  padding:0 24px;
  width:100%;
}

.section-dark{background:var(--dark)}
.section-light{background:var(--dark-2)}

/* ------------------------------------------------
   3. PRELOADER
   ------------------------------------------------ */
#preloader{
  position:fixed;inset:0;
  background:var(--dark);
  display:flex;align-items:center;justify-content:center;
  z-index:99999;
  transition:opacity .8s ease,visibility .8s ease;
}
#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}

.preloader-inner{text-align:center}

.preloader-circle{
  width:56px;height:56px;
  border:3px solid rgba(201,168,76,.12);
  border-top-color:var(--gold);
  border-radius:50%;
  animation:spin 1s linear infinite;
  margin:0 auto 24px;
}

.preloader-text{
  font-family:var(--ff-display);
  color:var(--gold);
  letter-spacing:6px;
  font-size:1rem;
  text-transform:uppercase;
  opacity:.85;
}

/* ------------------------------------------------
   4. NAVIGATION
   ------------------------------------------------ */
.navbar{
  position:fixed;top:0;left:0;width:100%;
  z-index:1000;
  padding:22px 5%;
  display:flex;align-items:center;justify-content:space-between;
  background:transparent;
  transition:all .45s var(--ease);
}

.navbar.nav-scrolled{
  background:rgba(6,6,6,.92);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  padding:14px 5%;
  box-shadow:0 4px 30px rgba(0,0,0,.5);
}

.nav-container{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:1400px;margin:0 auto;
}

/* Logo */
.nav-logo{display:flex;align-items:center;gap:10px}

.logo-text{
  font-family:var(--ff-display);
  font-size:1.55rem;font-weight:700;
  letter-spacing:5px;
  color:var(--gold);
  text-transform:uppercase;
  position:relative;
}
.logo-text::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:100%;height:1px;
  background:linear-gradient(90deg,var(--gold),transparent);
}

/* Menu */
.nav-menu{
  display:flex;align-items:center;gap:2.2rem;
}
.nav-item{}

.nav-link{
  font-family:var(--ff-body);
  text-transform:uppercase;
  font-size:.82rem;font-weight:500;
  letter-spacing:2.5px;
  color:var(--cream-dim);
  position:relative;
  padding:4px 0;
  transition:color .3s var(--ease);
}
.nav-link::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:2px;
  background:var(--gold);
  transition:width .35s var(--ease);
}
.nav-link:hover,
.nav-link.active{color:var(--gold)}
.nav-link:hover::after,
.nav-link.active::after{width:100%}

/* Book Now btn in nav */
.nav-btn{
  border:1.5px solid var(--gold) !important;
  padding:9px 28px !important;
  letter-spacing:2px !important;
  transition:all .35s var(--ease) !important;
}
.nav-btn::after{display:none !important}
.nav-btn:hover{
  background:var(--gold) !important;
  color:var(--dark) !important;
}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  cursor:pointer;padding:4px;z-index:1001;
}
.hamburger .bar{
  width:28px;height:2px;
  background:var(--gold);
  transition:all .35s var(--ease);
  border-radius:2px;
}
.hamburger.active .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active .bar:nth-child(2){opacity:0;transform:translateX(-10px)}
.hamburger.active .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ------------------------------------------------
   5. HERO
   ------------------------------------------------ */
.hero{
  height:100vh;min-height:650px;
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}

.hero-video-bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;z-index:0;
}
.hero-fallback{
  background:
    radial-gradient(ellipse at 30% 60%,rgba(201,168,76,.08) 0%,transparent 60%),
    radial-gradient(ellipse at 70% 30%,rgba(194,118,133,.06) 0%,transparent 50%),
    linear-gradient(160deg,#0a0a0a 0%,#111 40%,#0a0807 100%);
}

.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    180deg,
    rgba(6,6,6,.55) 0%,
    rgba(6,6,6,.35) 40%,
    rgba(6,6,6,.65) 100%
  );
}

.hero-content{
  position:relative;z-index:2;
  text-align:center;
  max-width:920px;padding:0 24px;
}

.hero-tag{
  font-family:var(--ff-accent);
  font-size:1.15rem;
  letter-spacing:6px;
  color:var(--gold-light);
  margin-bottom:16px;
  opacity:.9;
  text-transform:uppercase;
}

.hero-title{
  font-family:var(--ff-display);
  font-size:clamp(3rem,7vw,5.5rem);
  font-weight:800;
  color:var(--gold);
  letter-spacing:4px;
  line-height:1.1;
  margin-bottom:20px;
  text-shadow:0 4px 30px rgba(201,168,76,.2);
  animation:heroTitleIn 1.2s var(--ease) both;
}

.hero-subtitle{
  font-family:var(--ff-accent);
  font-size:clamp(1.15rem,2.5vw,1.65rem);
  color:var(--cream);
  letter-spacing:4px;
  font-weight:300;
  margin-bottom:40px;
  opacity:.85;
  animation:fadeInUp 1s .4s var(--ease) both;
}

/* Hero buttons */
.hero-cta{
  display:flex;align-items:center;justify-content:center;
  gap:18px;flex-wrap:wrap;
  animation:fadeInUp 1s .7s var(--ease) both;
}

/* Scroll indicator */
.hero-scroll-indicator{
  position:absolute;bottom:36px;left:50%;
  transform:translateX(-50%);z-index:3;
  text-align:center;
  animation:fadeInUp 1s 1.2s var(--ease) both;
}
.hero-scroll-indicator span{
  font-size:.72rem;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold-light);opacity:.6;display:block;margin-bottom:8px;
}
.scroll-arrow{
  animation:bounceDown 2s infinite;
  color:var(--gold);font-size:1rem;
}

/* ------------------------------------------------
   6. BUTTONS
   ------------------------------------------------ */
.btn-primary{
  display:inline-block;
  padding:15px 42px;
  background:var(--gold);
  color:var(--dark);
  font-family:var(--ff-body);
  font-size:.88rem;font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  border:2px solid var(--gold);
  border-radius:var(--radius);
  cursor:pointer;
  transition:all .4s var(--ease);
  position:relative;overflow:hidden;
}
.btn-primary:hover{
  background:var(--gold-light);
  border-color:var(--gold-light);
  transform:translateY(-3px);
  box-shadow:var(--shadow-gold);
}

.btn-outline{
  display:inline-block;
  padding:15px 42px;
  background:transparent;
  color:var(--gold);
  font-family:var(--ff-body);
  font-size:.88rem;font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  border:2px solid var(--gold);
  border-radius:var(--radius);
  cursor:pointer;
  transition:all .4s var(--ease);
}
.btn-outline:hover{
  background:var(--gold);
  color:var(--dark);
  transform:translateY(-3px);
  box-shadow:var(--shadow-gold);
}

/* Shimmer effect */
.shimmer-btn{position:relative;overflow:hidden}
.shimmer-btn::before{
  content:'';position:absolute;top:0;left:-100%;
  width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transition:none;
  animation:shimmer 3s infinite;
}

/* ------------------------------------------------
   7. SECTION HEADERS
   ------------------------------------------------ */
.section-header{
  text-align:center;
  margin-bottom:70px;
}

.section-tag{
  font-family:var(--ff-accent);
  font-size:1.05rem;
  letter-spacing:5px;
  color:var(--gold);
  text-transform:uppercase;
  display:block;
  margin-bottom:12px;
  font-weight:400;
}

.section-title{
  font-family:var(--ff-display);
  font-size:clamp(2.2rem,4vw,3.2rem);
  color:var(--gold);
  position:relative;
  display:inline-block;
  margin-bottom:14px;
}
.section-title::after{
  content:'';display:block;
  width:60px;height:2px;
  background:linear-gradient(90deg,var(--gold),var(--rose));
  margin:14px auto 0;
}

.section-subtitle{
  font-family:var(--ff-accent);
  font-size:1.2rem;
  color:var(--cream-dim);
  letter-spacing:2px;
}

/* ------------------------------------------------
   8. ABOUT INTRO
   ------------------------------------------------ */
.about-intro{padding:120px 0}

.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:70px;
  align-items:center;
}

.about-img-frame{position:relative}

.about-img-frame img{
  width:100%;border-radius:var(--radius);
  position:relative;z-index:1;
}

.frame-decoration{
  position:absolute;
  top:24px;left:24px;right:-24px;bottom:-24px;
  border:2px solid var(--gold);
  border-radius:var(--radius);
  opacity:.45;z-index:0;
  transition:all .5s var(--ease);
}
.about-img-frame:hover .frame-decoration{
  top:16px;left:16px;right:-16px;bottom:-16px;
  opacity:.7;
}

.about-placeholder{
  width:100%;height:420px;
  background:linear-gradient(135deg,var(--dark-3),var(--dark-2));
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius);
  font-size:5rem;color:var(--gold);opacity:.18;
}

.about-text .section-tag{text-align:left;margin-bottom:10px}

.about-text h2{
  font-size:clamp(1.8rem,3vw,2.5rem);
  margin-bottom:22px;
}

.about-text p{
  font-size:1.05rem;
  line-height:1.9;
  color:var(--cream-dim);
  margin-bottom:10px;
}

/* Stats */
.about-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;margin-top:40px;
}

.stat-item{
  text-align:center;
  padding:18px 8px;
  background:var(--dark-3);
  border-radius:var(--radius);
  border:1px solid rgba(201,168,76,.08);
  transition:all .4s var(--ease);
}
.stat-item:hover{
  border-color:rgba(201,168,76,.25);
  transform:translateY(-4px);
}

.stat-number{
  font-size:2.6rem;
  font-family:var(--ff-display);
  color:var(--gold);
  display:block;
  line-height:1.1;
}

.stat-label{
  text-transform:uppercase;
  letter-spacing:2px;
  font-size:.72rem;
  color:var(--cream);opacity:.55;
  margin-top:6px;display:block;
}

/* ------------------------------------------------
   9. SERVICES
   ------------------------------------------------ */
.services-section{padding:110px 0}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}

.service-card{
  background:var(--dark-3);
  border-radius:var(--radius);
  overflow:hidden;
  transition:all .45s var(--ease);
  border:1px solid rgba(201,168,76,.06);
}
.service-card:hover{
  transform:translateY(-10px);
  box-shadow:0 20px 50px rgba(201,168,76,.12);
  border-color:rgba(201,168,76,.2);
}
.service-card.featured{
  border-top:3px solid var(--gold);
}

.service-card-image{
  height:260px;overflow:hidden;position:relative;
}
.service-card-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease);
}
.service-card:hover .service-card-image img{transform:scale(1.08)}

.service-placeholder{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--dark-3) 0%,var(--dark-4) 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:2.8rem;color:var(--gold);opacity:.15;
}

.service-card-content{padding:28px}

.service-card-category{
  text-transform:uppercase;letter-spacing:2.5px;
  color:var(--gold);font-size:.72rem;font-weight:600;
}

.service-card-title{
  font-family:var(--ff-display);
  font-size:1.35rem;color:var(--cream);
  margin:10px 0 8px;
}

.service-card-desc{
  font-size:.92rem;color:var(--cream-dim);
  line-height:1.7;
}

.service-card-footer{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:22px;padding-top:16px;
  border-top:1px solid rgba(201,168,76,.1);
}

.service-card-price{
  color:var(--gold);
  font-size:1.55rem;font-weight:700;
  font-family:var(--ff-display);
}

.service-card-duration{
  font-size:.85rem;color:var(--cream);opacity:.55;
}
.service-card-duration i{margin-right:5px;color:var(--gold);opacity:.7}

/* Services page filter */
.services-filter-bar{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:10px;margin-bottom:50px;
}

.services-category-section{margin-bottom:70px}

.services-category-title{
  font-family:var(--ff-display);
  font-size:1.8rem;color:var(--gold);
  margin-bottom:30px;padding-bottom:14px;
  border-bottom:1px solid rgba(201,168,76,.15);
  text-transform:capitalize;
}

/* ------------------------------------------------
   10. GALLERY
   ------------------------------------------------ */
.gallery-preview{padding:110px 0}

.gallery-masonry{
  columns:4 280px;
  column-gap:16px;
}

.gallery-item{
  break-inside:avoid;
  margin-bottom:16px;
  position:relative;overflow:hidden;
  border-radius:var(--radius);
  cursor:pointer;
}

.gallery-item img{
  width:100%;display:block;
  transition:transform .65s var(--ease);
}
.gallery-item:hover img{transform:scale(1.06)}

.gallery-item-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,6,6,.85) 0%,rgba(6,6,6,.1) 50%,transparent 100%);
  opacity:0;
  transition:opacity .4s var(--ease);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;
}
.gallery-item:hover .gallery-item-overlay{opacity:1}

.gallery-item-title{
  font-family:var(--ff-display);
  color:var(--cream);font-size:1.1rem;
  margin-top:6px;
  transform:translateY(12px);
  transition:transform .4s var(--ease);
}
.gallery-item:hover .gallery-item-title{transform:translateY(0)}

.gallery-item-category{
  color:var(--gold);text-transform:uppercase;
  font-size:.72rem;letter-spacing:2.5px;font-weight:600;
  transform:translateY(12px);
  transition:transform .4s .05s var(--ease);
}
.gallery-item:hover .gallery-item-category{transform:translateY(0)}

/* Filter bar */
.gallery-filter-bar{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:10px;margin-bottom:40px;
}

.filter-btn{
  padding:11px 26px;
  border:1px solid rgba(201,168,76,.25);
  background:transparent;
  color:var(--cream);
  cursor:pointer;
  font-family:var(--ff-body);
  font-size:.82rem;letter-spacing:1.5px;
  text-transform:uppercase;
  transition:all .35s var(--ease);
  border-radius:var(--radius);
}
.filter-btn:hover,
.filter-btn.active{
  background:var(--gold);color:var(--dark);
  border-color:var(--gold);
}

.gallery-count{
  text-align:center;margin-bottom:40px;
  font-size:.95rem;opacity:.6;
}

.gallery-page-grid{columns:4 280px;column-gap:16px}

.gallery-item-zoom{
  width:42px;height:42px;
  border:1px solid var(--gold);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-top:12px;font-size:.9rem;color:var(--gold);
  transition:all .3s var(--ease);
}
.gallery-item:hover .gallery-item-zoom{
  background:var(--gold);color:var(--dark);
}

.gallery-item-caption{font-size:.85rem;opacity:.65;margin-top:5px}

.gallery-placeholder-bg{
  background:linear-gradient(135deg,var(--dark-3),var(--dark-2));
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  color:var(--gold);opacity:.22;border-radius:var(--radius);
}
.gallery-placeholder-bg i{font-size:2.2rem;margin-bottom:10px}
.gallery-placeholder-bg p{font-size:.8rem}

.gallery-empty{
  text-align:center;padding:100px 20px;
  grid-column:1/-1;
}

/* ------------------------------------------------
   11. VIDEOS
   ------------------------------------------------ */
.video-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}

.video-card{
  background:var(--dark-3);
  border-radius:var(--radius);
  overflow:hidden;cursor:pointer;
  transition:all .45s var(--ease);
  border:1px solid rgba(201,168,76,.06);
}
.video-card:hover{
  transform:translateY(-8px);
  box-shadow:0 18px 40px rgba(201,168,76,.1);
  border-color:rgba(201,168,76,.2);
}

.video-thumbnail{
  position:relative;overflow:hidden;
  aspect-ratio:16/9;
}
.video-thumbnail img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .65s var(--ease);
}
.video-card:hover .video-thumbnail img{transform:scale(1.06)}

.video-play-btn{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:72px;height:72px;border-radius:50%;
  background:rgba(201,168,76,.88);
  display:flex;align-items:center;justify-content:center;
  color:var(--dark);font-size:1.3rem;
  transition:all .35s var(--ease);
  box-shadow:0 8px 28px rgba(201,168,76,.3);
}
.video-play-btn i{margin-left:4px}
.video-card:hover .video-play-btn{transform:translate(-50%,-50%) scale(1.12)}

.video-thumb-placeholder{
  width:100%;aspect-ratio:16/9;
  background:var(--dark-3);
  display:flex;align-items:center;justify-content:center;
  font-size:3.5rem;color:var(--gold);opacity:.18;
}

.video-duration-badge{
  position:absolute;top:12px;right:12px;
  background:rgba(6,6,6,.7);
  color:var(--gold);padding:4px 12px;
  border-radius:3px;font-size:.78rem;
}

.video-info{padding:22px}

.video-title{
  font-family:var(--ff-display);
  color:var(--cream);font-size:1.1rem;
  margin-top:8px;
}

.video-category{
  color:var(--gold);text-transform:uppercase;
  font-size:.72rem;letter-spacing:2.5px;font-weight:600;
}

.video-desc{
  font-size:.85rem;opacity:.55;margin-top:8px;line-height:1.6;
}

/* Video Modal */
.video-modal{
  position:fixed;inset:0;
  background:rgba(0,0,0,.96);
  z-index:10000;
  display:none;align-items:center;justify-content:center;
}
.video-modal.active{display:flex}

.video-modal video{
  max-width:90vw;max-height:85vh;
  border-radius:var(--radius);
}

.video-modal-close{
  position:absolute;top:24px;right:32px;
  background:none;border:none;
  color:var(--cream);font-size:2.2rem;
  cursor:pointer;transition:color .3s var(--ease);
  z-index:10001;
}
.video-modal-close:hover{color:var(--gold)}

/* ------------------------------------------------
   12. TESTIMONIALS
   ------------------------------------------------ */
.testimonials-section{padding:110px 0;overflow:hidden}

.testimonials-wrapper{
  max-width:820px;margin:0 auto;
  overflow:hidden;position:relative;
}

.testimonials-slider{
  display:flex;
  transition:transform .55s var(--ease);
}

.testimonial-card{
  min-width:100%;
  padding:48px 24px;
  text-align:center;
}

.testimonial-quote{
  font-size:5rem;
  color:var(--gold);
  font-family:var(--ff-display);
  line-height:.6;opacity:.25;
  margin-bottom:10px;
}

.testimonial-stars{
  color:var(--gold);font-size:1.05rem;
  margin-bottom:24px;letter-spacing:4px;
}

.testimonial-text{
  font-family:var(--ff-accent);
  font-size:1.45rem;font-style:italic;
  line-height:1.85;color:var(--cream);
  max-width:620px;margin:0 auto;
}

.testimonial-author{
  margin-top:28px;
  font-family:var(--ff-display);
  color:var(--gold);font-size:1.1rem;
  letter-spacing:1px;
}

.testimonial-dots{
  display:flex;justify-content:center;
  gap:10px;margin-top:32px;
}

.testimonial-dot{
  width:10px;height:10px;border-radius:50%;
  background:rgba(201,168,76,.25);
  cursor:pointer;border:none;
  transition:all .3s var(--ease);
}
.testimonial-dot.active{
  background:var(--gold);
  transform:scale(1.35);
}

/* ------------------------------------------------
   13. CTA SECTION
   ------------------------------------------------ */
.cta-section{
  padding:110px 0;
  background:linear-gradient(135deg,var(--gold) 0%,var(--rose) 100%);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 20% 80%,rgba(255,255,255,.08) 0%,transparent 50%);
}

.cta-section h2{
  font-family:var(--ff-display);
  font-size:clamp(2rem,4vw,3rem);
  color:var(--dark);
  margin-bottom:14px;
  position:relative;
}

.cta-section p{
  color:rgba(6,6,6,.6);
  font-size:1.1rem;
  margin-bottom:32px;
  position:relative;
}

.cta-section .btn-primary{
  background:var(--dark);color:var(--gold);
  border-color:var(--dark);
  padding:17px 48px;font-size:.95rem;
  position:relative;
}
.cta-section .btn-primary:hover{
  background:var(--dark-2);
  box-shadow:0 12px 32px rgba(0,0,0,.35);
}

/* ------------------------------------------------
   14. FOOTER
   ------------------------------------------------ */
.footer{
  background:var(--dark);
  padding:90px 0 0;
  position:relative;
}
.footer-gold-line,
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg,transparent 0%,var(--gold) 50%,transparent 100%);
}

.footer-container{
  max-width:1240px;margin:0 auto;padding:0 24px;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:48px;
}

.footer-logo{
  font-family:var(--ff-display);
  font-size:1.4rem;font-weight:700;
  letter-spacing:5px;color:var(--gold);
  text-transform:uppercase;
  margin-bottom:14px;display:block;
}

.footer-tagline{
  font-family:var(--ff-accent);
  font-size:1.1rem;color:var(--gold-light);
  font-style:italic;margin-bottom:12px;
  opacity:.8;
}

.footer-about{
  font-size:.9rem;opacity:.6;line-height:1.8;
}

.footer-heading{
  font-family:var(--ff-display);
  color:var(--gold);font-size:1.15rem;
  margin-bottom:24px;position:relative;
  padding-bottom:12px;
}
.footer-heading::after{
  content:'';position:absolute;bottom:0;left:0;
  width:28px;height:2px;background:var(--gold);
}

.footer-links li{margin-bottom:11px}
.footer-links li a{
  color:var(--cream);opacity:.6;
  font-size:.9rem;
  display:flex;align-items:center;gap:8px;
  transition:all .3s var(--ease);
}
.footer-links li a i{
  font-size:.6rem;color:var(--gold);
  transition:transform .3s var(--ease);
}
.footer-links li a:hover{
  opacity:1;color:var(--gold);
  padding-left:6px;
}
.footer-links li a:hover i{transform:translateX(3px)}

.footer-contact{list-style:none}
.footer-contact li{
  display:flex;gap:14px;
  margin-bottom:16px;opacity:.65;
  font-size:.9rem;align-items:flex-start;
}
.footer-contact li i{
  color:var(--gold);margin-top:5px;
  width:16px;text-align:center;
  font-size:.85rem;
}
.footer-contact li a{color:var(--cream)}
.footer-contact li a:hover{color:var(--gold)}

.footer-socials{
  display:flex;gap:12px;margin-bottom:28px;
}
.footer-socials a{
  width:42px;height:42px;
  border:1px solid rgba(201,168,76,.25);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--cream);font-size:.9rem;
  transition:all .35s var(--ease);
}
.footer-socials a:hover{
  background:var(--gold);color:var(--dark);
  border-color:var(--gold);
  transform:translateY(-4px);
  box-shadow:0 6px 18px rgba(201,168,76,.25);
}

.footer-heading-newsletter{margin-top:6px}

.footer-newsletter-text{
  font-size:.85rem;opacity:.55;margin-bottom:12px;
}

.footer-newsletter .newsletter-input-group{
  display:flex;
}
.footer-newsletter input{
  flex:1;
  background:var(--dark-3);
  border:1px solid rgba(201,168,76,.15);
  border-right:none;
  padding:12px 16px;color:var(--cream);
  font-family:var(--ff-body);font-size:.88rem;
  outline:none;
  border-radius:var(--radius) 0 0 var(--radius);
  transition:border-color .3s;
}
.footer-newsletter input:focus{border-color:var(--gold)}
.footer-newsletter input::placeholder{color:rgba(242,236,224,.3)}

.footer-newsletter button{
  background:var(--gold);color:var(--dark);
  padding:12px 18px;border:none;
  cursor:pointer;font-size:.9rem;
  border-radius:0 var(--radius) var(--radius) 0;
  transition:background .3s;
}
.footer-newsletter button:hover{background:var(--gold-light)}

.newsletter-msg{
  display:block;margin-top:8px;
  font-size:.82rem;color:var(--gold);
}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.04);
  padding:22px 0;margin-top:60px;
  text-align:center;
  font-size:.82rem;opacity:.4;color:var(--cream);
}

/* ------------------------------------------------
   15. PAGE BANNER (Gallery, Videos, Services, About, Booking)
   ------------------------------------------------ */
.page-banner{
  height:50vh;min-height:360px;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 50% 50%,rgba(201,168,76,.04) 0%,transparent 70%),
    linear-gradient(160deg,var(--dark) 0%,var(--dark-2) 50%,var(--dark) 100%);
  overflow:hidden;
}

.page-banner-overlay{
  position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse at center,rgba(201,168,76,.03) 0%,transparent 70%);
}

.page-banner-content{
  position:relative;z-index:2;text-align:center;
}

.page-banner-title{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem,5vw,4rem);
  color:var(--gold);letter-spacing:4px;
  margin-bottom:14px;
}

.page-banner-subtitle{
  font-family:var(--ff-accent);
  font-size:1.3rem;color:var(--cream);
  opacity:.75;letter-spacing:3px;
}

.page-breadcrumb{
  margin-top:20px;font-size:.88rem;
  color:var(--cream);opacity:.5;
}
.page-breadcrumb a{color:var(--gold);transition:opacity .3s}
.page-breadcrumb a:hover{opacity:.8}
.page-breadcrumb span{margin:0 8px}

.gallery-page,.videos-page{padding:70px 0 110px}

/* ------------------------------------------------
   16. BOOKING FORM
   ------------------------------------------------ */
.booking-section{
  padding:60px 0 110px;
}

.booking-form-container{
  max-width:720px;margin:0 auto;
  background:var(--dark-2);
  padding:52px;border-radius:var(--radius);
  border:1px solid rgba(201,168,76,.08);
}

.form-group{margin-bottom:26px}

.form-group label{
  display:block;margin-bottom:9px;
  color:var(--gold);text-transform:uppercase;
  letter-spacing:1.5px;font-size:.82rem;font-weight:500;
}

.form-group input,
.form-group select,
.form-group textarea{
  width:100%;padding:15px 18px;
  background:var(--dark);
  border:1px solid rgba(201,168,76,.15);
  color:var(--cream);
  font-family:var(--ff-body);font-size:1rem;
  border-radius:var(--radius);
  outline:none;
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,76,.1);
}

.form-group input::placeholder,
.form-group textarea::placeholder{color:rgba(242,236,224,.25)}

.form-group textarea{min-height:130px;resize:vertical}

.form-group select{
  appearance:none;
  background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c9a84c' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:18px;
  padding-right:42px;
}

.form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
}

.form-submit-btn{
  width:100%;padding:17px;
  background:var(--gold);color:var(--dark);
  border:none;
  font-family:var(--ff-body);font-weight:700;
  font-size:1rem;letter-spacing:2.5px;
  text-transform:uppercase;cursor:pointer;
  border-radius:var(--radius);
  transition:all .4s var(--ease);
}
.form-submit-btn:hover{
  background:var(--gold-light);
  transform:translateY(-3px);
  box-shadow:var(--shadow-gold);
}
.form-submit-btn:disabled{
  opacity:.5;cursor:not-allowed;transform:none;
}

.form-success{
  padding:16px;
  background:rgba(39,174,96,.08);
  border:1px solid rgba(39,174,96,.25);
  color:#2ecc71;border-radius:var(--radius);
  margin-bottom:20px;text-align:center;
}

.form-error{
  padding:16px;
  background:rgba(231,76,60,.08);
  border:1px solid rgba(231,76,60,.25);
  color:#e74c3c;border-radius:var(--radius);
  margin-bottom:20px;text-align:center;
}

/* ------------------------------------------------
   17. TEAM
   ------------------------------------------------ */
.team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:42px;margin-top:50px;
}

.team-card{
  text-align:center;
  transition:transform .4s var(--ease);
}
.team-card:hover{transform:translateY(-8px)}

.team-card-image{
  width:200px;height:200px;
  border-radius:50%;overflow:hidden;
  margin:0 auto 22px;
  border:3px solid var(--gold);
  transition:all .45s var(--ease);
}
.team-card:hover .team-card-image{
  box-shadow:0 12px 36px rgba(201,168,76,.2);
  transform:scale(1.05);
}
.team-card-image img{width:100%;height:100%;object-fit:cover}

.team-placeholder{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--dark-3),var(--dark-2));
  display:flex;align-items:center;justify-content:center;
  font-size:3rem;color:var(--gold);opacity:.2;
}

.team-card-name{
  font-family:var(--ff-display);
  color:var(--gold);font-size:1.2rem;
  margin-bottom:4px;
}

.team-card-role{
  font-size:.82rem;color:var(--cream);
  opacity:.6;text-transform:uppercase;
  letter-spacing:1.5px;
}

.team-card-bio{
  font-size:.9rem;opacity:.6;
  margin-top:10px;line-height:1.6;
}

/* ------------------------------------------------
   18. LIGHTBOX
   ------------------------------------------------ */
.lightbox{
  position:fixed;inset:0;
  background:rgba(0,0,0,.96);
  z-index:10000;
  display:none;align-items:center;justify-content:center;
  flex-direction:column;
}
.lightbox.active{display:flex}

.lightbox img{
  max-width:90vw;max-height:85vh;
  object-fit:contain;border-radius:var(--radius);
}

.lightbox-close{
  position:absolute;top:22px;right:32px;
  color:var(--cream);font-size:2.5rem;
  cursor:pointer;background:none;border:none;
  transition:color .3s var(--ease);
  z-index:10001;line-height:1;
}
.lightbox-close:hover{color:var(--gold)}

.lightbox-prev,.lightbox-next{
  position:absolute;top:50%;transform:translateY(-50%);
  font-size:1.4rem;color:var(--cream);
  background:rgba(6,6,6,.5);
  border:1px solid rgba(201,168,76,.15);
  padding:16px 22px;cursor:pointer;
  transition:all .3s var(--ease);
}
.lightbox-prev:hover,.lightbox-next:hover{
  background:var(--gold);color:var(--dark);
  border-color:var(--gold);
}
.lightbox-prev{left:22px}
.lightbox-next{right:22px}

.lightbox-caption{
  position:absolute;bottom:32px;left:50%;
  transform:translateX(-50%);text-align:center;
  color:var(--cream);
  font-family:var(--ff-accent);font-size:1.2rem;
}

.lightbox-counter{
  position:absolute;top:28px;left:32px;
  color:var(--cream);opacity:.6;font-size:.9rem;
}

/* ------------------------------------------------
   19. BACK TO TOP
   ------------------------------------------------ */
.back-to-top{
  position:fixed;bottom:32px;right:32px;
  width:48px;height:48px;
  background:var(--gold);color:var(--dark);
  border:none;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;cursor:pointer;
  opacity:0;pointer-events:none;
  transition:all .4s var(--ease);
  z-index:999;
  box-shadow:0 6px 20px rgba(201,168,76,.3);
}
.back-to-top.visible{opacity:1;pointer-events:auto}
.back-to-top:hover{
  transform:translateY(-4px);
  box-shadow:0 10px 28px rgba(201,168,76,.4);
}

/* ------------------------------------------------
   20. CUSTOM CURSOR
   ------------------------------------------------ */
.cursor-follower{
  position:fixed;
  width:22px;height:22px;
  border:1.5px solid var(--gold);
  border-radius:50%;
  pointer-events:none;z-index:99999;
  transition:width .2s,height .2s,background .2s;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
}
.cursor-follower.active{
  width:48px;height:48px;
  background:rgba(201,168,76,.08);
}

/* ------------------------------------------------
   21. UTILITIES
   ------------------------------------------------ */
.text-center{text-align:center}
.gold-text{color:var(--gold)}
.text-cream{color:var(--cream)}

.text-gradient{
  background:linear-gradient(135deg,var(--gold),var(--gold-light),var(--rose));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.divider-gold{
  width:60px;height:2px;
  background:var(--gold);margin:20px auto;
}

.glass-effect{
  backdrop-filter:blur(12px);
  background:rgba(6,6,6,.5);
}

.gold-border-glow{animation:pulseGold 2s infinite}

/* ------------------------------------------------
   22. KEYFRAME ANIMATIONS
   ------------------------------------------------ */
@keyframes heroTitleIn{
  0%{opacity:0;transform:translateY(40px) scale(.96);letter-spacing:12px}
  100%{opacity:1;transform:translateY(0) scale(1);letter-spacing:4px}
}

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

@keyframes fadeInDown{
  from{opacity:0;transform:translateY(-36px)}
  to{opacity:1;transform:translateY(0)}
}

@keyframes fadeInLeft{
  from{opacity:0;transform:translateX(-36px)}
  to{opacity:1;transform:translateX(0)}
}

@keyframes fadeInRight{
  from{opacity:0;transform:translateX(36px)}
  to{opacity:1;transform:translateX(0)}
}

@keyframes shimmer{
  0%{left:-100%}
  100%{left:200%}
}

@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-18px)}
}

@keyframes pulseGold{
  0%,100%{box-shadow:0 0 0 0 rgba(201,168,76,.4)}
  70%{box-shadow:0 0 0 16px rgba(201,168,76,0)}
}

@keyframes scaleIn{
  from{opacity:0;transform:scale(.85)}
  to{opacity:1;transform:scale(1)}
}

@keyframes spin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}

@keyframes bounceDown{
  0%,20%,50%,80%,100%{transform:translateY(0)}
  40%{transform:translateY(10px)}
  60%{transform:translateY(5px)}
}

@keyframes glowPulse{
  0%,100%{text-shadow:0 0 8px rgba(201,168,76,.3)}
  50%{text-shadow:0 0 20px rgba(201,168,76,.6)}
}

@keyframes blink{
  50%{opacity:0}
}

@keyframes borderDraw{
  0%{clip-path:inset(0 100% 100% 0)}
  25%{clip-path:inset(0 0 100% 0)}
  50%{clip-path:inset(0 0 0 0)}
  100%{clip-path:inset(0 0 0 0)}
}

.typing-cursor{
  display:inline-block;width:2px;height:1em;
  background:var(--gold);margin-left:4px;
  animation:blink .8s step-end infinite;
  vertical-align:text-bottom;
}

/* ------------------------------------------------
   23. RESPONSIVE — TABLET
   ------------------------------------------------ */
@media(max-width:1024px){
  .gallery-masonry,.gallery-page-grid{columns:3}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .video-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{gap:45px}
  .footer-grid{grid-template-columns:repeat(2,1fr);gap:40px}
}

/* ------------------------------------------------
   24. RESPONSIVE — MOBILE
   ------------------------------------------------ */
@media(max-width:768px){
  .nav-menu{
    position:fixed;top:0;right:-100%;
    width:100%;height:100vh;
    background:rgba(6,6,6,.98);
    flex-direction:column;
    align-items:center;justify-content:center;
    gap:2.2rem;
    transition:right .45s var(--ease);
    z-index:998;
  }
  .nav-menu.active{right:0}

  .nav-link{font-size:1.15rem;letter-spacing:3px}

  .hamburger{display:flex;z-index:999}

  section{padding:70px 0}

  .hero{min-height:580px}
  .hero-title{font-size:clamp(2.2rem,8vw,3.8rem)}
  .hero-subtitle{font-size:1.1rem;letter-spacing:2px}

  .about-grid{grid-template-columns:1fr;gap:40px}
  .frame-decoration{display:none}

  .services-grid{grid-template-columns:1fr}
  .gallery-masonry,.gallery-page-grid{columns:2}
  .video-grid{grid-template-columns:1fr}

  .about-stats{grid-template-columns:repeat(3,1fr);gap:12px}

  .footer-grid{grid-template-columns:1fr;gap:32px;text-align:center}
  .footer-heading::after{left:50%;transform:translateX(-50%)}
  .footer-contact li{justify-content:center}
  .footer-socials{justify-content:center}
  .footer-links li a{justify-content:center}

  .section-title{font-size:2rem}
  .page-banner{height:42vh;min-height:280px}
  .page-banner-title{font-size:2.4rem}

  .booking-form-container{padding:32px 20px}
  .form-row{grid-template-columns:1fr}

  .lightbox-prev,.lightbox-next{padding:10px 15px;font-size:1.2rem}

  .testimonial-text{font-size:1.2rem}
}

/* ------------------------------------------------
   25. RESPONSIVE — SMALL MOBILE
   ------------------------------------------------ */
@media(max-width:480px){
  .gallery-masonry,.gallery-page-grid{columns:1}
  .hero-title{font-size:2rem}
  .hero-subtitle{font-size:.95rem;letter-spacing:1px}
  .hero-tag{font-size:.95rem;letter-spacing:3px}

  .logo-text{font-size:1.15rem;letter-spacing:3px}

  section{padding:50px 0}
  .section-header{margin-bottom:36px}
  .container{padding:0 16px}

  .about-stats{grid-template-columns:1fr}
  .stat-item{padding:14px}

  .cursor-follower{display:none}

  .hero-cta{flex-direction:column;gap:12px}
  .hero-cta .btn-primary,
  .hero-cta .btn-outline{width:100%;text-align:center;padding:14px 20px}

  .cta-section h2{font-size:1.7rem}
  .cta-section{padding:70px 0}

  .filter-btn{padding:8px 16px;font-size:.75rem}

  .service-card-image{height:200px}
  .service-card-price{font-size:1.3rem}
}

/* ------------------------------------------------
   26. FLOATING WHATSAPP BUTTON
   ------------------------------------------------ */
.whatsapp-float{
  position:fixed;
  bottom:100px;right:28px;
  z-index:998;
  display:flex;align-items:center;gap:12px;
  text-decoration:none;
  animation:waFloatIn 1s 1.5s var(--ease) both;
}

.whatsapp-float-icon{
  width:62px;height:62px;
  background:#25D366;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.8rem;
  box-shadow:0 6px 24px rgba(37,211,102,.4);
  transition:all .35s var(--ease);
  position:relative;z-index:2;
}

.whatsapp-float:hover .whatsapp-float-icon{
  transform:scale(1.1) rotate(-8deg);
  box-shadow:0 10px 36px rgba(37,211,102,.5);
}

.whatsapp-float-pulse{
  position:absolute;right:28px;bottom:100px;
  width:62px;height:62px;
  border-radius:50%;
  background:rgba(37,211,102,.35);
  animation:waPulse 2s infinite;
  z-index:1;
}

.whatsapp-float-label{
  background:var(--dark-2);
  color:var(--cream);
  padding:8px 16px;
  border-radius:6px;
  font-size:.82rem;
  font-weight:500;
  letter-spacing:.5px;
  white-space:nowrap;
  box-shadow:0 4px 16px rgba(0,0,0,.4);
  opacity:0;
  transform:translateX(10px);
  transition:all .3s var(--ease);
  pointer-events:none;
}

.whatsapp-float:hover .whatsapp-float-label{
  opacity:1;
  transform:translateX(0);
}

@keyframes waPulse{
  0%{transform:scale(1);opacity:.6}
  70%{transform:scale(1.6);opacity:0}
  100%{transform:scale(1.6);opacity:0}
}

@keyframes waFloatIn{
  from{opacity:0;transform:translateY(30px) scale(.7)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* Footer WhatsApp button */
.footer-whatsapp-btn{
  display:inline-flex;
  align-items:center;gap:10px;
  padding:12px 24px;
  background:#25D366;
  color:#fff;
  border-radius:var(--radius);
  font-size:.9rem;font-weight:600;
  letter-spacing:.5px;
  text-decoration:none;
  transition:all .35s var(--ease);
  margin-top:8px;
}
.footer-whatsapp-btn i{font-size:1.2rem}
.footer-whatsapp-btn:hover{
  background:#20bd5a;
  transform:translateY(-3px);
  box-shadow:0 8px 20px rgba(37,211,102,.3);
}

/* ---- Responsive adjustments for WhatsApp ---- */
@media(max-width:768px){
  .whatsapp-float{bottom:90px;right:18px}
  .whatsapp-float-icon{width:54px;height:54px;font-size:1.5rem}
  .whatsapp-float-pulse{right:18px;bottom:90px;width:54px;height:54px}
  .whatsapp-float-label{display:none}
}

@media(max-width:480px){
  .whatsapp-float{bottom:80px;right:14px}
  .whatsapp-float-icon{width:50px;height:50px;font-size:1.4rem}
  .whatsapp-float-pulse{right:14px;bottom:80px;width:50px;height:50px}
}
