/* ==== Theme tokens ======================================================= */
:root{
  --ink:#1b1230;
  --muted:#6a5f7a;
  --magenta:#c2188f;
  --gold:#ffd24e;
  --band:linear-gradient(90deg,rgba(255,210,78,.88),rgba(194,24,143,.88));
  --shadow:0 10px 30px rgba(26,18,37,.08)
}

*{box-sizing:border-box}
html,body{margin:0}
body{font-family:Poppins,system-ui,Arial,sans-serif;color:var(--ink);line-height:1.6}
img{max-width:100%;display:block}
.container{width:min(1120px,92vw);margin:0 auto;padding-inline:clamp(12px,3vw,24px)}
h1,h2,h3{margin:0 0 .6rem}
h2{font-size:clamp(1.6rem,3vw,2rem)}
.sub{color:var(--muted)}
a{color:inherit}

/* ==== Top bar ============================================================ */
.topbar{background:#0f0b15;color:#cfc9d8;font-size:.95rem}
.topbar a{color:#cfc9d8;text-decoration:none}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0}
.topbar-right{display:flex;align-items:center;gap:.65rem;white-space:nowrap}
.topbar-right .phone-ico{filter:grayscale(100%) brightness(5);display:inline-block;width:16px;height:16px;background:url('../icons/icon-phone.png') center/contain no-repeat}
.topbar-right .fb-ico img{width:18px;height:18px;display:inline-block;vertical-align:middle}

/* ==== Header + navigation =============================================== */
header{position:sticky;top:0;z-index:60;background:linear-gradient(180deg,rgba(194,24,143,.98),rgba(194,24,143,.94))}
.nav{display:flex;align-items:center;gap:1rem;padding:.65rem 0}
.brand{color:#fff;text-decoration:none;font-weight:800;display:flex;align-items:center;gap:.5rem;padding-right:12px;border-right:1px solid #ffffff3f}
.logo{background:#ffd6ea;border-radius:10px;padding:2px 6px}
.footer-brand{display:flex;align-items:center;gap:.5rem;font-weight:800}
.gold{color:var(--gold)}

.menu{flex:1;display:flex;align-items:center;gap:.6rem}
.menu>a,.menu .menu-item>a{color:#fff;text-decoration:none;font-weight:700;padding:.5rem .7rem;border-radius:10px;display:inline-flex;align-items:center;gap:.35rem}

/* desktop chevron indicators */
.menu .menu-item{position:relative}
.menu .has-sub>a::after{
  content:"";width:8px;height:8px;display:inline-block;
  border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:translateY(-1px) rotate(45deg);transition:transform .18s;
}
.submenu{
  display:none;position:absolute;top:100%;left:0;min-width:240px;
  background:#fff;border:1px solid #eee;border-radius:12px;padding:.5rem;
  box-shadow:0 18px 45px rgba(26,18,37,.18)
}
.submenu a{display:block;color:#1b1230;text-decoration:none;padding:.5rem;border-radius:8px}
.submenu a:hover{background:#f6eef3;color:var(--magenta)}

.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;padding:.42rem .70rem;font-weight:700;border:1px solid #ddd;text-decoration:none;color:#1b1230;background:#fff}
.btn-primary{background:var(--magenta);border-color:var(--magenta);color:#fff}
.btn-outline-magenta{background:#fff;color:var(--magenta);border-color:var(--magenta)}
.btn-gold{background:var(--gold);border-color:#e6c23b;color:#3d2a00}
.header-cta{margin-left:auto}

/* responsive nav */
.nav-toggle{display:none}
@media(max-width:980px){
  .nav-toggle{display:inline-block;background:#fff;border:1px solid #ddd;border-radius:10px;padding:.4rem .6rem}
  .menu{
    position:absolute;left:0;right:0;top:64px;background:#fff;border-top:1px solid #eee;
    display:none;flex-direction:column;padding:.5rem;z-index:70
  }
  .menu>a,.menu .menu-item>a{color:#1b1230}
  .has-sub.open>.submenu{display:block;position:static;border:none;box-shadow:none;padding-left:.6rem}
  .has-sub.open>a::after{transform:rotate(-135deg)}
}
@media(min-width:981px){
  .menu .menu-item:hover>.submenu{display:block}
  .menu .menu-item:hover>a::after{transform:rotate(-135deg)}
}

/* ==== Sections / hero ==================================================== */
.section{padding:clamp(2.2rem,5vw,4rem) 0}
.white{background:#fff}
.alt{background:#f6eef3}
.gradient{background:var(--band)}
.hero{background-image:url('../img/hero-001.jpg');background-size:cover;background-position:center}
.display{font-size:clamp(2.2rem,6vw,4.6rem);line-height:1.05;color:#fff}
.lead{color:#fff;opacity:.9}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;min-height:50vh;padding:clamp(3rem,6vw,6rem) 0}
.hero-ctas{display:flex;gap:.6rem}

/* cards and service blocks */
.cards{display:grid;gap:1rem}
.four{grid-template-columns:repeat(4,1fr)}
.three{grid-template-columns:repeat(3,1fr)}
.card{border:1px solid #eee;border-radius:16px;padding:1rem;background:#fff;box-shadow:var(--shadow)}
.ph{border-radius:12px;border:1px solid #eee;margin:.5rem 0}

/* ==== Video Highlights ==================================================== */
.videos-title{color:#000}
.video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.video-card{display:flex;flex-direction:column;gap:.5rem}
.video-caption{color:#1b1230;font-weight:600;font-size:.95rem;padding-inline:.2rem}
.video-thumb{display:block;aspect-ratio:16/9;border-radius:16px;background-size:cover;background-position:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.video-thumb::after{z-index:1;content:"";position:absolute;inset:0;background:linear-gradient(to top, rgba(0,0,0,.32), rgba(0,0,0,0) 50%)}
.video-thumb .play{z-index:2;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:#ffffffcc;box-shadow:0 6px 20px rgba(0,0,0,.25)}
.video-thumb .play::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-34%,-50%);width:0;height:0;border-left:18px solid #000;border-top:12px solid transparent;border-bottom:12px solid transparent}
.video-thumb:hover .play{background:#fff}
#vidModal{padding:0;border:none;background:transparent}
#vidModal::backdrop{background:rgba(0,0,0,.6)}
#vidPlayer{width:min(960px,92vw);max-height:86vh;border-radius:16px;display:block}

/* ==== FAQ ================================================================ */
.faq details{margin:.5rem 0;border:1px solid #eee;border-radius:12px;background:#fff;box-shadow:var(--shadow)}
.faq summary{cursor:pointer;padding:.8rem 1rem;font-weight:700;list-style:none;display:flex;align-items:center;gap:.6rem}
.faq summary::before{content:'▸';transition:transform .2s}
.faq details[open] summary::before{transform:rotate(90deg)}
.faq details>div{padding:.8rem 1rem;border-top:1px solid #f1e9f7}

/* ==== Footer ============================================================= */
.site-footer.magenta{background:linear-gradient(180deg,#c2188f,#b21782);color:#fff}
.footer-grid-3{display:grid;grid-template-columns:1.4fr 1.2fr 1.2fr;gap:1.2rem;padding:2rem 0}
.site-footer h4{font-weight:500;letter-spacing:.08em;text-transform:uppercase;margin:.1rem 0 .6rem}
.site-footer a{color:#fff;text-decoration:none}
.site-footer .linklist{list-style:none;padding:0;margin:0}
.site-footer .linklist li{margin:.35rem 0}
.footer-brand .logo{background:#ffd6ea;border-radius:10px;padding:2px 6px}
.social-row{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin-top:.8rem}
.social-row img{width:28px;height:28px;background:#ffffff26;border-radius:8px;padding:4px}
.subfooter{background:#0f0b15;color:#fff}
.subfooter a{color:#fff;text-decoration:none}
.subfooter-inner{display:flex;justify-content:space-between;align-items:center;padding:.9rem 0}

/* ==== Gallery grid + Lightbox (arrows included) ========================= */
/* Square, Instagram-like tiles */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  margin:32px 0 80px;
}
.gallery-grid a{
  display:block;width:100%;aspect-ratio:1/1;overflow:hidden;
  border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.08);
  background:#f6f3f8;position:relative;
}
.gallery-grid img{
  width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease;
}
.gallery-grid a:hover img{transform:scale(1.03)}

/* Lightbox overlay + controls */
.lightbox{position:fixed;inset:0;background:rgba(10,8,14,.85);backdrop-filter:saturate(120%) blur(2px);display:none;align-items:center;justify-content:center;z-index:9999;padding:20px}
.lightbox.open{display:flex}
.lightbox-inner{position:relative;max-width:min(92vw,1200px);max-height:86vh;width:100%;display:grid;grid-template-rows:1fr auto;gap:12px}
.lightbox-figure{position:relative;width:100%;height:100%;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.35);background:#111}
.lightbox-figure img{width:100%;height:100%;object-fit:contain;background:#111}
.lightbox-caption{color:#fff;font-weight:500;text-align:center;font-size:clamp(14px,2.8vw,18px);opacity:.9}
.lb-close{position:absolute;top:10px;right:10px;width:40px;height:40px;border-radius:999px;background:rgba(255,255,255,.14);border:0;cursor:pointer}
.lb-close::before,.lb-close::after{content:"";position:absolute;left:50%;top:50%;width:20px;height:2px;background:#fff;transform-origin:center}
.lb-close::before{transform:translate(-50%,-50%) rotate(45deg)}
.lb-close::after{transform:translate(-50%,-50%) rotate(-45deg)}
.lb-btn{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:999px;border:0;cursor:pointer;background:rgba(255,255,255,.16);transition:background .2s ease, transform .2s ease;display:grid;place-items:center}
.lb-btn:hover{background:rgba(255,255,255,.28);transform:translateY(-50%) scale(1.04)}
.lb-btn:active{transform:translateY(-50%) scale(.98)}
.lb-btn.prev{left:12px}
.lb-btn.next{right:12px}
.lb-btn::before{content:"";width:12px;height:12px;border-top:2px solid #fff;border-right:2px solid #fff;transform:rotate(45deg)}
.lb-btn.prev::before{transform:rotate(225deg)}
.lb-btn.next::before{transform:rotate(45deg)}
body.lb-lock{overflow:hidden}
@media(max-width:640px){.lb-btn{width:52px;height:52px}}

/* Responsive gallery/video grids */
@media(max-width:980px){
  .four{grid-template-columns:1fr 1fr}
  .three{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .video-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){.video-grid{grid-template-columns:1fr}}
