/* ════════════════════════════════════════════════════════════════
   SS Events & Caters — WHITE LUXURY THEME
   Complete Design System
   ════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,600&family=Jost:wght@300;400;500;600;700&display=swap');

/* ── CSS Custom Properties ── */
:root {
  --purple:       #4B1060;
  --purple-2:     #5E1878;
  --purple-3:     #3A0A4A;
  --purple-soft:  #F3EAF8;
  --gold:         #D4A017;
  --gold-2:       #E8B830;
  --gold-soft:    #FDF5DC;
  --white:        #FFFFFF;
  --off-white:    #FDFAF5;
  --cream:        #F5EFE3;
  --light-bg:     #F8F4EF;
  --text-dark:    #1A1215;
  --text-mid:     #5A4A60;
  --text-light:   #8B7A95;
  --border:       rgba(75,16,96,0.12);
  --border-gold:  rgba(212,160,23,0.3);
  --shadow-sm:    0 2px 12px rgba(75,16,96,0.08);
  --shadow-md:    0 8px 32px rgba(75,16,96,0.12);
  --shadow-lg:    0 20px 60px rgba(75,16,96,0.18);
  --font-serif:   'Cormorant Garamond', Georgia, serif;
  --font-sans:    'Jost', 'Segoe UI', sans-serif;
  --container:    1280px;
  --gutter:       48px;
  --section-py:   100px;
  --ease:         cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-out:     cubic-bezier(0.16,1,0.3,1);
}

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-sans);background:var(--white);color:var(--text-dark);overflow-x:hidden;line-height:1.7}
a{text-decoration:none;color:inherit;transition:color .3s}
img{max-width:100%;height:auto;display:block;object-fit:cover}
button{border:none;cursor:pointer;background:none;font-family:inherit}
ul{list-style:none}
input,select,textarea{font-family:var(--font-sans)}

/* ════════════════════════════════════════════════════════════════
   PRELOADER
   ════════════════════════════════════════════════════════════════ */
#preloader{
  position:fixed;inset:0;z-index:9999;background:var(--white);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .6s ease,visibility .6s
}
#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center}
.preloader-logo{
  font-family:var(--font-serif);font-size:clamp(3rem,8vw,6rem);
  font-weight:600;color:var(--purple);letter-spacing:.18em;line-height:1
}
.preloader-tag{
  font-size:.68rem;font-weight:400;letter-spacing:.45em;text-transform:uppercase;
  color:var(--text-light);margin-top:6px;margin-bottom:28px
}
.preloader-bar{width:180px;height:2px;background:var(--cream);margin:0 auto;overflow:hidden}
.preloader-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--gold));animation:pl-load 2s ease forwards}
@keyframes pl-load{from{width:0}to{width:100%}}

/* ════════════════════════════════════════════════════════════════
   UTILITIES
   ════════════════════════════════════════════════════════════════ */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.eyebrow{
  font-size:.68rem;font-weight:600;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);margin-bottom:12px;display:block
}
.eyebrow.purple{color:var(--purple)}
.eyebrow.white{color:rgba(255,255,255,.7)}

.heading-xl{font-family:var(--font-serif);font-size:clamp(2.8rem,5vw,5.5rem);font-weight:400;line-height:1.1;color:var(--text-dark)}
.heading-lg{font-family:var(--font-serif);font-size:clamp(2.2rem,4vw,4rem);font-weight:400;line-height:1.15;color:var(--text-dark)}
.heading-md{font-family:var(--font-serif);font-size:clamp(1.6rem,2.5vw,2.6rem);font-weight:400;line-height:1.2;color:var(--text-dark)}
.heading-sm{font-family:var(--font-serif);font-size:1.4rem;font-weight:500;color:var(--text-dark)}
.heading-xl em,.heading-lg em,.heading-md em,.heading-sm em{font-style:italic;color:var(--purple)}

.heading-xl.white,.heading-lg.white,.heading-md.white{color:var(--white)}
.heading-xl.white em,.heading-lg.white em,.heading-md.white em{color:var(--gold-2)}

.body-text{font-size:.98rem;color:var(--text-mid);line-height:1.9;margin-bottom:18px}
.body-text.white{color:rgba(255,255,255,.8)}

/* Divider */
.divider{display:flex;align-items:center;gap:14px;margin:18px 0}
.divider-line{flex:1;height:1px;background:var(--border)}
.divider-icon{color:var(--gold);font-size:.75rem;flex-shrink:0}
.divider.gold .divider-line{background:var(--border-gold)}
.divider.left .divider-line:first-child{display:none}
.divider.left .divider-line:last-child{flex:0 0 60px}
.divider.center{justify-content:center}
.divider.center .divider-line{flex:0 0 60px}
.divider.white .divider-line{background:rgba(255,255,255,.2)}
.divider.white .divider-icon{color:var(--gold-2)}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:14px 36px;
  font-size:.76rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  transition:all .35s var(--ease);cursor:pointer;border:2px solid transparent;flex-shrink:0
}
.btn-purple{background:var(--purple);color:var(--white);border-color:var(--purple)}
.btn-purple:hover{background:var(--purple-2);border-color:var(--purple-2);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-gold{background:var(--gold);color:var(--white);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-2);border-color:var(--gold-2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(212,160,23,.35)}
.btn-outline-purple{background:transparent;color:var(--purple);border-color:var(--purple)}
.btn-outline-purple:hover{background:var(--purple);color:var(--white)}
.btn-outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,.5)}
.btn-outline-white:hover{background:rgba(255,255,255,.12);border-color:var(--white)}
.btn-white{background:var(--white);color:var(--purple);border-color:var(--white)}
.btn-white:hover{background:var(--cream);transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* ── Section Header ── */
.section-header{margin-bottom:56px}
.section-header.center{text-align:center}
.section-header.center .divider{justify-content:center}
.section-subtitle{font-size:.98rem;color:var(--text-mid);max-width:580px;margin-top:16px;line-height:1.85}
.section-header.center .section-subtitle{margin-left:auto;margin-right:auto}

/* ── Reveal Animations ── */
.reveal-up,.reveal-left,.reveal-right,.reveal-fade{
  opacity:0;transition:opacity .85s var(--ease),transform .85s var(--ease)
}
.reveal-up{transform:translateY(40px)}
.reveal-left{transform:translateX(-40px)}
.reveal-right{transform:translateX(40px)}
.reveal-fade{transform:scale(.97)}
.reveal-up.in,.reveal-left.in,.reveal-right.in,.reveal-fade.in{opacity:1;transform:none}
.d1{transition-delay:.1s!important}
.d2{transition-delay:.2s!important}
.d3{transition-delay:.3s!important}
.d4{transition-delay:.4s!important}

/* ════════════════════════════════════════════════════════════════
   NAVIGATION
   ════════════════════════════════════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 0;transition:all .4s var(--ease);background:transparent
}
.navbar.scrolled{
  background:var(--purple-3);
  padding:14px 0;box-shadow:0 8px 32px rgba(0,0,0,0.3)
}
.navbar.solid{
  background:var(--purple-3);padding:14px 0;
  box-shadow:0 8px 32px rgba(0,0,0,0.3)
}
.nav-inner{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);display:flex;align-items:center}
.nav-logo{display:flex;align-items:center;height:48px;width:180px;position:relative;z-index:1001}
.nav-logo img{
  height:150px;
  width:auto;
  display:block;
  transition:all 0.4s var(--ease);
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
  filter:drop-shadow(0 4px 12px rgba(0,0,0,0.1));
  z-index: 1002;
}
.navbar.scrolled .nav-logo img{height:110px}
.logo-mark{display:none} /* Hide old text logo spans just in case */
.logo-name{display:none}
.nav-links{display:flex;align-items:center;gap:0;margin:0 auto}
.nav-link{
  display:block;padding:8px 18px;font-size:.74rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;color:var(--cream);
  position:relative;transition:color .3s
}
.nav-link::after{
  content:'';position:absolute;bottom:2px;left:18px;right:18px;height:2px;
  background:var(--gold);transform:scaleX(0);transition:transform .3s var(--ease);transform-origin:left
}
.nav-link:hover,.nav-link.active{color:var(--gold)}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}
.nav-cta{
  margin-left:28px;padding:10px 24px;background:var(--gold);color:var(--text-dark);
  font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  flex-shrink:0;transition:all .3s;border:2px solid var(--gold)
}
.nav-cta:hover{background:var(--gold);border-color:var(--gold);transform:translateY(-1px);box-shadow:0 4px 16px rgba(212,160,23,.3)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;margin-left:16px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--cream);transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
.mob-menu{
  position:fixed;top:0;right:-100%;width:min(360px,100vw);height:100vh;
  background:var(--purple-3);z-index:999;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  box-shadow:-4px 0 32px rgba(75,16,96,.15);transition:right .5s var(--ease)
}
.mob-menu.open{right:0}
.mob-link{
  font-family:var(--font-serif);font-size:1.8rem;color:var(--cream);
  padding:15px 0;transition:all .3s;display:block
}
.mob-link.active,.mob-link:hover{color:var(--gold);padding-left:10px}
.mob-divider{height:1px;background:rgba(255,255,255,0.1);width:100%;margin:4px auto}

/* ════════════════════════════════════════════════════════════════
   PAGE HERO BANNER (inner pages)
   ════════════════════════════════════════════════════════════════ */
.page-hero{
  position:relative;height:440px;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:64px;
  background:linear-gradient(135deg,#000 0%,var(--text-dark) 100%)
}
.page-hero-img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.22}
.page-hero-content{position:relative;z-index:2;padding:0 var(--gutter);max-width:var(--container);width:100%;margin:0 auto}
.breadcrumb{
  display:flex;align-items:center;gap:10px;margin-top:16px;
  font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.55)
}
.breadcrumb a{color:rgba(255,255,255,.55);transition:color .3s}
.breadcrumb a:hover,.breadcrumb span{color:var(--gold-2)}
.crumb-sep{color:rgba(255,255,255,.3)}

/* ════════════════════════════════════════════════════════════════
   HERO (home)
   ════════════════════════════════════════════════════════════════ */
.hero{
  position:relative;height:100vh;min-height:680px;
  display:flex;align-items:center;overflow:hidden
}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.08);will-change:transform;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.5) 55%,rgba(0,0,0,0.2) 100%)
}
.hero-content{
  position:relative;z-index:2;padding:0 var(--gutter);max-width:var(--container);width:100%;margin:0 auto
}
.hero-inner{max-width:660px}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(8px);padding:8px 18px;margin-bottom:28px;
  font-size:.68rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-2)
}
.hero-badge span{width:6px;height:6px;background:var(--gold-2);border-radius:50%;flex-shrink:0}
.hero-title{
  font-family:var(--font-serif);font-size:clamp(3.5rem,7vw,7rem);
  font-weight:400;line-height:1.06;color:var(--white);margin-bottom:22px;
  opacity:0;transform:translateY(28px);transition:all 1s .1s var(--ease)
}
.hero-title em{font-style:italic;color:var(--gold-2)}
.hero-title.in{opacity:1;transform:none}
.hero-sub{
  font-size:clamp(.92rem,1.4vw,1.08rem);font-weight:300;
  color:rgba(255,255,255,.82);line-height:1.85;margin-bottom:38px;
  opacity:0;transform:translateY(22px);transition:all .9s .3s var(--ease)
}
.hero-sub.in{opacity:1;transform:none}
.hero-btns{
  display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;transform:translateY(22px);transition:all .9s .45s var(--ease)
}
.hero-btns.in{opacity:1;transform:none}

/* Hero scroll cue */
.scroll-cue{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2;
  animation:cue-bob 2.2s ease-in-out infinite
}
.cue-dot{width:8px;height:8px;background:rgba(255,255,255,.5);border-radius:50%}
.cue-text{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.5)}
@keyframes cue-bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* ════════════════════════════════════════════════════════════════
   STATS BAR
   ════════════════════════════════════════════════════════════════ */
.stats-bar{background:var(--purple);padding:0}
.stats-inner{
  max-width:var(--container);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:repeat(4,1fr)
}
.stat-cell{
  text-align:center;padding:30px 20px;position:relative
}
.stat-cell+.stat-cell::before{
  content:'';position:absolute;left:0;top:20%;height:60%;
  width:1px;background:rgba(255,255,255,.15)
}
.stat-number{
  font-family:var(--font-serif);font-size:3rem;font-weight:400;
  color:var(--gold-2);line-height:1;display:inline
}
.stat-sfx{font-family:var(--font-serif);font-size:2rem;color:var(--gold-2)}
.stat-label{font-size:.65rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:4px}

/* ════════════════════════════════════════════════════════════════
   MARQUEE
   ════════════════════════════════════════════════════════════════ */
.marquee-ribbon{background:var(--gold);padding:12px 0;overflow:hidden}
.marquee-track{display:flex;white-space:nowrap;animation:marquee 28s linear infinite}
.marquee-track span{font-size:.68rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--white);padding:0 28px}
.marquee-track .dot-sep{padding:0;color:rgba(255,255,255,.5)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ════════════════════════════════════════════════════════════════
   SPLIT SERVICES SECTION (Reference design)
   ════════════════════════════════════════════════════════════════ */
.split-services{display:grid;grid-template-columns:1fr 1fr;min-height:480px}
.split-left{
  background:linear-gradient(140deg,#000 0%,var(--text-dark) 100%);
  padding:64px var(--gutter);display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden
}
.split-left::after{
  content:'';position:absolute;top:0;right:-60px;bottom:0;width:120px;
  background:linear-gradient(135deg,var(--purple) 50%,transparent 50%);
  z-index:10
}
.split-right{
  background:var(--white);padding:64px var(--gutter);
  display:flex;flex-direction:column;justify-content:center
}
.icon-services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px 24px;
  position:relative;z-index:5
}
.icon-svc-item{text-align:center;cursor:default}
.icon-svc-item:hover .icon-svc-circle{background:rgba(255,255,255,.15);transform:translateY(-4px)}
.icon-svc-circle{
  width:80px;height:80px;background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.15);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 12px;transition:all .35s;color:var(--gold-2)
}
.icon-svc-circle svg{width:36px;height:36px}
.icon-svc-label{font-size:.78rem;font-weight:400;letter-spacing:.06em;color:rgba(255,255,255,.88);text-align:center}

.split-right-content{max-width:420px}
.split-right-content .heading-lg{font-size:clamp(1.8rem,3vw,2.8rem);margin-bottom:16px}
.split-right-content .body-text{margin-bottom:28px}

/* ════════════════════════════════════════════════════════════════
   ABOUT SECTION (white)
   ════════════════════════════════════════════════════════════════ */
.about-sec{padding:var(--section-py) 0;background:var(--off-white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-img-stack{position:relative;padding-bottom:40px;padding-right:40px}
.about-img-main{
  width:100%;aspect-ratio:4/5;overflow:hidden;
  box-shadow:var(--shadow-lg);position:relative
}
.about-img-main img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.about-img-main:hover img{transform:scale(1.04)}
.about-img-sm{
  position:absolute;bottom:0;right:0;width:52%;aspect-ratio:4/3;
  overflow:hidden;border:5px solid var(--white);box-shadow:var(--shadow-md)
}
.about-img-sm img{width:100%;height:100%;object-fit:cover}
.about-badge{
  position:absolute;top:-16px;left:-16px;width:94px;height:94px;
  background:var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center
}
.badge-n{font-family:var(--font-serif);font-size:2.2rem;font-weight:700;color:var(--white);line-height:1}
.badge-t{font-size:.52rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.85);text-align:center;line-height:1.3;margin-top:3px}
.about-list{display:flex;flex-direction:column;gap:16px;margin:28px 0}
.about-list-item{display:flex;gap:14px;align-items:flex-start;padding:14px;background:var(--white);border-left:3px solid var(--gold);box-shadow:var(--shadow-sm)}
.ali-icon{width:40px;height:40px;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold)}
.ali-icon svg{width:20px;height:20px}
.ali-title{font-family:var(--font-serif);font-size:1rem;font-weight:600;color:var(--text-dark);display:block;margin-bottom:2px}
.ali-desc{font-size:.84rem;color:var(--text-light)}

/* ════════════════════════════════════════════════════════════════
   HOW IT WORKS — PROCESS STEPS
   ════════════════════════════════════════════════════════════════ */
.process-sec{padding:var(--section-py) 0;background:var(--white)}
.process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:56px;
  position:relative
}
.process-steps::before{
  content:'';position:absolute;top:40px;left:10%;right:10%;height:2px;
  background:linear-gradient(90deg,var(--purple-soft),var(--purple),var(--gold),var(--purple),var(--purple-soft));
  z-index:0
}
.process-step{
  text-align:center;padding:0 24px;position:relative;z-index:1;cursor:default
}
.ps-num{
  width:80px;height:80px;background:var(--white);border:3px solid var(--purple);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;font-family:var(--font-serif);font-size:2rem;font-weight:400;
  color:var(--purple);transition:all .35s
}
.process-step:hover .ps-num{background:var(--purple);color:var(--white);box-shadow:0 8px 24px rgba(75,16,96,.3)}
.ps-icon{
  width:80px;height:80px;background:var(--purple-soft);border:3px solid var(--purple);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;color:var(--purple);transition:all .35s
}
.ps-icon svg{width:32px;height:32px}
.process-step:hover .ps-icon{background:var(--purple);color:var(--white);box-shadow:0 8px 24px rgba(75,16,96,.3)}
.ps-title{font-family:var(--font-serif);font-size:1.25rem;font-weight:600;color:var(--text-dark);margin-bottom:10px}
.ps-desc{font-size:.86rem;color:var(--text-light);line-height:1.7}

/* ════════════════════════════════════════════════════════════════
   SERVICES CARDS (white)
   ════════════════════════════════════════════════════════════════ */
.services-sec{padding:var(--section-py) 0;background:var(--light-bg)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.svc-card{
  background:var(--white);border:1px solid var(--border);
  padding:36px 28px;transition:all .4s var(--ease);cursor:default;
  position:relative;overflow:hidden
}
.svc-card::before{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--purple),var(--gold));
  transform:scaleX(0);transition:transform .4s var(--ease);transform-origin:left
}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon-wrap{
  width:64px;height:64px;background:var(--purple-soft);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
  color:var(--purple);transition:all .35s
}
.svc-icon-wrap svg{width:30px;height:30px}
.svc-card:hover .svc-icon-wrap{background:var(--purple);color:var(--white)}
.svc-num-tag{
  position:absolute;top:20px;right:20px;
  font-family:var(--font-serif);font-size:3rem;font-weight:700;
  color:rgba(75,16,96,.06);line-height:1
}
.svc-title{font-family:var(--font-serif);font-size:1.4rem;font-weight:600;color:var(--text-dark);margin-bottom:10px}
.svc-desc{font-size:.88rem;color:var(--text-light);line-height:1.75;margin-bottom:18px}
.svc-link{
  font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--purple);display:inline-flex;align-items:center;gap:6px;
  transition:gap .3s
}
.svc-link svg{width:14px;height:14px;transition:transform .3s}
.svc-card:hover .svc-link svg{transform:translateX(4px)}

/* ════════════════════════════════════════════════════════════════
   WHY US — FEATURE SECTION
   ════════════════════════════════════════════════════════════════ */
.whyus-sec{padding:var(--section-py) 0;background:var(--white)}
.whyus-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.features-list{display:flex;flex-direction:column;gap:20px;margin:32px 0}
.feature-item{
  display:flex;gap:16px;align-items:flex-start;padding:20px;
  border:1px solid var(--border);transition:all .35s
}
.feature-item:hover{border-color:var(--purple);box-shadow:var(--shadow-sm);background:var(--purple-soft)}
.fi-icon{
  width:48px;height:48px;background:var(--purple);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--white)
}
.fi-icon svg{width:22px;height:22px}
.fi-title{font-family:var(--font-serif);font-size:1.05rem;font-weight:600;color:var(--text-dark);display:block;margin-bottom:3px}
.fi-desc{font-size:.85rem;color:var(--text-light);line-height:1.6}
.whyus-visual{position:relative}
.whyus-img{width:100%;aspect-ratio:4/5;object-fit:cover;box-shadow:var(--shadow-lg)}
.whyus-quote{
  position:absolute;bottom:-24px;left:-24px;right:40px;
  background:var(--purple);padding:28px;color:var(--white)
}
.wq-icon{color:var(--gold-2);margin-bottom:10px;opacity:.6}
.wq-icon svg{width:24px;height:24px;fill:currentColor}
.wq-text{font-family:var(--font-serif);font-size:1.04rem;font-style:italic;line-height:1.65;margin-bottom:10px;color:rgba(255,255,255,.9)}
.wq-cite{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2)}

/* ════════════════════════════════════════════════════════════════
   CTA BANNER — PURPLE
   ════════════════════════════════════════════════════════════════ */
.cta-purple{
  background:linear-gradient(135deg,#000 0%,var(--text-dark) 100%);
  padding:88px 0;position:relative;overflow:hidden
}
.cta-purple::before{
  content:'';position:absolute;top:-50%;right:-10%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(212,160,23,.1) 0%,transparent 70%);
  pointer-events:none
}
.cta-inner{text-align:center;position:relative;z-index:1;padding:0 24px}
.cta-inner .heading-lg{color:var(--white)}
.cta-inner .heading-lg em{color:var(--gold-2)}
.cta-subtitle{font-size:1rem;color:rgba(255,255,255,.75);max-width:560px;margin:16px auto 36px;line-height:1.85}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ════════════════════════════════════════════════════════════════
   GALLERY (white/light)
   ════════════════════════════════════════════════════════════════ */
.gallery-sec{padding:var(--section-py) 0;background:var(--light-bg)}
.gallery-filters{display:flex;gap:8px;justify-content:center;margin-top:40px;margin-bottom:44px;flex-wrap:wrap}
.gf-btn{
  padding:9px 22px;font-size:.7rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-mid);border:1.5px solid var(--border);background:var(--white);transition:all .3s
}
.gf-btn:hover,.gf-btn.active{background:var(--purple);border-color:var(--purple);color:var(--white)}
.gallery-masonry{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:280px;gap:6px}
.g-item{position:relative;overflow:hidden;cursor:pointer}
.g-item.tall{grid-row:span 2}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .65s var(--ease)}
.g-item:hover img{transform:scale(1.07)}
.g-cap{
  position:absolute;inset:0;background:rgba(0,0,0,0.75);
  opacity:0;transition:opacity .4s;display:flex;align-items:flex-end;padding:20px
}
.g-item:hover .g-cap{opacity:1}
.g-cap span{font-family:var(--font-serif);font-size:1.1rem;color:var(--white);padding-bottom:4px;border-bottom:2px solid var(--gold-2)}
.g-item.hidden{display:none}

/* ════════════════════════════════════════════════════════════════
   TESTIMONIALS (white)
   ════════════════════════════════════════════════════════════════ */
.testi-sec{padding:var(--section-py) 0;background:var(--white)}
.testi-slider{overflow:hidden;margin-top:52px}
.testi-track{display:flex;gap:20px;transition:transform .65s var(--ease)}
.testi-card{
  min-width:calc(33.333% - 14px);flex-shrink:0;
  background:var(--off-white);border:1.5px solid var(--border);
  padding:36px 30px;transition:all .35s;position:relative;overflow:hidden
}
.testi-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--purple),var(--gold))
}
.testi-card:hover{box-shadow:var(--shadow-md);border-color:rgba(75,16,96,.25);transform:translateY(-4px)}
.tst-stars{color:var(--gold);font-size:.95rem;letter-spacing:4px;margin-bottom:16px}
.tst-text{font-family:var(--font-serif);font-size:1.05rem;font-style:italic;color:var(--text-mid);line-height:1.82;margin-bottom:24px}
.tst-author{display:flex;align-items:center;gap:14px}
.tst-av{
  width:46px;height:46px;background:var(--purple);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif);font-size:.95rem;font-weight:600;color:var(--white)
}
.tst-name{font-family:var(--font-serif);font-size:1rem;font-weight:600;color:var(--text-dark);display:block}
.tst-event{font-size:.76rem;color:var(--text-light)}
.testi-controls{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:36px}
.testi-arrow{
  width:44px;height:44px;border:1.5px solid var(--border);color:var(--purple);
  font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .3s;background:var(--white)
}
.testi-arrow:hover{background:var(--purple);color:var(--white);border-color:var(--purple)}
.testi-dots{display:flex;gap:7px}
.t-dot{width:7px;height:7px;background:var(--border);cursor:pointer;transition:all .3s;border-radius:50%}
.t-dot.active{background:var(--purple);width:22px;border-radius:4px}

/* ════════════════════════════════════════════════════════════════
   VALUES / APPROACH SECTION
   ════════════════════════════════════════════════════════════════ */
.values-sec{padding:var(--section-py) 0;background:var(--purple)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:52px}
.value-card{
  padding:44px 32px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);transition:all .4s
}
.value-card:hover{background:rgba(255,255,255,.1);transform:translateY(-4px)}
.vc-icon{
  width:56px;height:56px;background:rgba(212,160,23,.15);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--gold-2)
}
.vc-icon svg{width:26px;height:26px}
.vc-num{font-family:var(--font-serif);font-size:.85rem;font-weight:500;color:var(--gold-2);letter-spacing:.2em;margin-bottom:8px}
.vc-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:400;color:var(--white);margin-bottom:12px}
.vc-desc{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.8}

/* ════════════════════════════════════════════════════════════════
   TEAM
   ════════════════════════════════════════════════════════════════ */
.team-sec{padding:var(--section-py) 0;background:var(--off-white)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:52px}
.team-card{background:var(--white);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .4s}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.team-img{aspect-ratio:3/4;overflow:hidden}
.team-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.team-card:hover .team-img img{transform:scale(1.06)}
.team-info{padding:18px 20px;border-top:3px solid var(--gold)}
.t-name{font-family:var(--font-serif);font-size:1.2rem;font-weight:600;color:var(--text-dark);margin-bottom:4px}
.t-role{font-size:.72rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--purple)}

/* ════════════════════════════════════════════════════════════════
   SERVICES DETAIL (services page)
   ════════════════════════════════════════════════════════════════ */
.svc-detail-sec{padding:var(--section-py) 0;background:var(--white)}
.svc-detail-item{
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
  padding:72px 0;border-bottom:1px solid var(--border)
}
.svc-detail-item:last-child{border-bottom:none}
.svc-detail-item.rev{direction:rtl}
.svc-detail-item.rev>*{direction:ltr}
.svc-detail-img{overflow:hidden;box-shadow:var(--shadow-lg)}
.svc-detail-img img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .8s var(--ease);display:block}
.svc-detail-img:hover img{transform:scale(1.04)}
.svc-detail-num{font-family:var(--font-serif);font-size:4.5rem;font-weight:700;color:rgba(75,16,96,.08);line-height:1;margin-bottom:4px}
.svc-includes{margin:20px 0}
.svc-includes li{
  font-size:.9rem;color:var(--text-mid);padding:9px 0;
  border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px
}
.svc-includes li::before{content:'✓';color:var(--purple);font-weight:700;flex-shrink:0}

/* ════════════════════════════════════════════════════════════════
   PRICING
   ════════════════════════════════════════════════════════════════ */
.pricing-sec{padding:var(--section-py) 0;background:var(--light-bg)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}
.price-card{
  padding:44px 36px;background:var(--white);border:2px solid var(--border);
  display:flex;flex-direction:column;transition:all .4s;position:relative
}
.price-card:hover{border-color:var(--purple);transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.price-card.featured{background:var(--purple);border-color:var(--purple)}
.price-card.featured:hover{background:var(--purple-2)}
.pc-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--white);font-size:.64rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;padding:5px 14px;white-space:nowrap
}
.pc-label{font-size:.68rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--purple);margin-bottom:12px}
.price-card.featured .pc-label{color:var(--gold-2)}
.pc-name{font-family:var(--font-serif);font-size:2rem;font-weight:400;color:var(--text-dark);margin-bottom:6px}
.price-card.featured .pc-name{color:var(--white)}
.pc-price{font-family:var(--font-serif);font-size:3.5rem;font-weight:300;color:var(--purple);line-height:1;margin-bottom:4px}
.price-card.featured .pc-price{color:var(--gold-2)}
.pc-from{font-size:.75rem;color:var(--text-light);letter-spacing:.1em;margin-bottom:24px}
.price-card.featured .pc-from{color:rgba(255,255,255,.55)}
.pc-divider{height:1px;background:var(--border);margin-bottom:24px}
.price-card.featured .pc-divider{background:rgba(255,255,255,.15)}
.pc-features{display:flex;flex-direction:column;gap:10px;flex:1;margin-bottom:32px}
.pc-features li{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--text-mid)}
.price-card.featured .pc-features li{color:rgba(255,255,255,.82)}
.pc-features li::before{content:'✓';color:var(--purple);font-weight:700;flex-shrink:0}
.price-card.featured .pc-features li::before{color:var(--gold-2)}
.pc-cta .btn{width:100%;justify-content:center}

/* ════════════════════════════════════════════════════════════════
   CONTACT (white)
   ════════════════════════════════════════════════════════════════ */
.contact-sec{padding:var(--section-py) 0;background:var(--white)}
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:72px;align-items:start}
.ci-item{padding:22px 0;border-bottom:1px solid var(--border);display:flex;gap:16px;align-items:flex-start}
.ci-item:first-child{padding-top:0}
.ci-icon{
  width:46px;height:46px;background:var(--purple-soft);border:1px solid rgba(75,16,96,.15);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--purple)
}
.ci-icon svg{width:20px;height:20px}
.ci-label{font-size:.65rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:5px}
.ci-val{font-size:.92rem;color:var(--text-mid);line-height:1.7}
.ci-val a{color:var(--text-mid);transition:color .3s}
.ci-val a:hover{color:var(--purple)}
.social-row{display:flex;gap:10px;margin-top:24px}
.soc-btn{
  width:42px;height:42px;border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-light);background:var(--white);transition:all .3s
}
.soc-btn svg{width:17px;height:17px}
.soc-btn:hover{background:var(--purple);border-color:var(--purple);color:var(--white)}
.cform{display:flex;flex-direction:column;gap:14px}
.cform-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform-group{display:flex;flex-direction:column;gap:0}
.cform-group label{font-size:.65rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mid);margin-bottom:7px}
.cform-group input,.cform-group select,.cform-group textarea{
  background:var(--off-white);border:1.5px solid var(--border);
  color:var(--text-dark);padding:13px 16px;font-size:.92rem;outline:none;transition:border-color .3s;width:100%
}
.cform-group input::placeholder,.cform-group textarea::placeholder{color:var(--text-light)}
.cform-group input:focus,.cform-group select:focus,.cform-group textarea:focus{border-color:var(--purple);background:var(--white)}
.cform-group select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234B1060' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-color:var(--off-white)}
.cform-group select option{background:var(--white)}
.cform-group textarea{resize:vertical;min-height:120px}
.cform-submit .btn{width:100%;justify-content:center;padding:16px}
.cform-note{font-size:.76rem;color:var(--text-light);text-align:center;margin-top:4px}

/* Map */
.map-sec{height:360px;background:var(--light-bg);border-top:1px solid var(--border);overflow:hidden;position:relative}
.map-placeholder{
  width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  background:linear-gradient(135deg,var(--purple-soft),var(--cream))
}
.map-placeholder .map-icon{color:var(--purple);opacity:.4}
.map-placeholder .map-icon svg{width:44px;height:44px}
.map-text{font-family:var(--font-serif);font-size:1.35rem;color:var(--text-mid)}
.map-addr{font-size:.78rem;color:var(--text-light);letter-spacing:.15em;text-transform:uppercase;text-align:center}

/* FAQ */
.faq-sec{padding:var(--section-py) 0;background:var(--off-white)}
.faq-list{max-width:800px;margin:52px auto 0;display:flex;flex-direction:column;gap:4px}
.faq-item{background:var(--white);border:1.5px solid var(--border);overflow:hidden;transition:border-color .3s}
.faq-item:hover{border-color:rgba(75,16,96,.2)}
.faq-q{
  width:100%;text-align:left;padding:22px 24px;display:flex;justify-content:space-between;
  align-items:center;background:none;cursor:pointer;color:var(--text-dark);
  font-family:var(--font-serif);font-size:1.1rem;font-weight:500;gap:12px
}
.faq-ico{color:var(--purple);font-size:1.5rem;transition:transform .3s;flex-shrink:0;line-height:1}
.faq-ico.open{transform:rotate(45deg)}
.faq-a{padding:0 24px 22px;color:var(--text-mid);font-size:.9rem;line-height:1.85;display:none}
.faq-a.open{display:block}

/* ════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════ */
.site-footer{background:var(--purple-3);border-top:3px solid var(--gold)}
.footer-main{padding:72px 0}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:52px}
.footer-brand .footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.footer-logo img{height:60px;width:auto;display:block}
.footer-brand .logo-mark{color:var(--gold-2)}
.footer-brand .logo-name{color:rgba(255,255,255,.7)}
.footer-about{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.82;margin-bottom:22px}
.footer-social{display:flex;gap:9px;flex-wrap:wrap}
.fs-btn{width:38px;height:38px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);transition:all .3s}
.fs-btn svg{width:16px;height:16px}
.fs-btn:hover{background:var(--gold);border-color:var(--gold);color:var(--white)}
.footer-col h5{font-size:.68rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-2);margin-bottom:20px}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{font-size:.9rem;color:rgba(255,255,255,.55);display:inline-block;transition:all .3s}
.footer-col ul li a:hover{color:var(--gold-2);transform:translateX(4px)}
.footer-contact-list li{display:flex;align-items:flex-start;gap:9px;margin-bottom:12px!important}
.footer-contact-list li svg{flex-shrink:0;color:var(--gold-2);margin-top:3px}
.footer-contact-list li span,.footer-contact-list li a{font-size:.88rem;color:rgba(255,255,255,.55)}
.footer-contact-list li a:hover{color:var(--gold-2)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:20px 0;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px
}
.footer-bottom p,.footer-bottom a{font-size:.78rem;color:rgba(255,255,255,.35);letter-spacing:.05em}
.footer-bottom a:hover{color:var(--gold-2)}

/* ════════════════════════════════════════════════════════════════
   FLOATING UI
   ════════════════════════════════════════════════════════════════ */
.wa-float{
  position:fixed;bottom:28px;right:28px;width:52px;height:52px;
  background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--white);z-index:900;box-shadow:0 6px 24px rgba(37,211,102,.4);transition:all .3s
}
.wa-float svg{width:26px;height:26px}
.wa-float:hover{transform:scale(1.1);box-shadow:0 10px 32px rgba(37,211,102,.5)}
.btt-btn{
  position:fixed;bottom:92px;right:28px;width:42px;height:42px;
  background:var(--purple);color:var(--white);font-size:1.1rem;border:none;
  display:flex;align-items:center;justify-content:center;z-index:900;
  opacity:0;visibility:hidden;transition:all .3s;cursor:pointer
}
.btt-btn.show{opacity:1;visibility:visible}
.btt-btn:hover{background:var(--gold);transform:translateY(-3px)}
.toast-msg{
  position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(16px);
  background:var(--purple);color:var(--white);padding:12px 28px;font-size:.84rem;font-weight:500;
  letter-spacing:.06em;z-index:10000;opacity:0;visibility:hidden;transition:all .4s var(--ease);white-space:nowrap;
  box-shadow:var(--shadow-lg)
}
.toast-msg.active{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════ */
@media(max-width:1200px){
  :root{--section-py:80px;--gutter:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .footer-brand{grid-column:1/-1}
  .pricing-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .split-services{grid-template-columns:1fr 1fr}
}
@media(max-width:1024px){
  .about-grid,.whyus-layout,.contact-layout,.svc-detail-item,.svc-detail-item.rev{
    grid-template-columns:1fr;gap:48px;direction:ltr
  }
  .svc-detail-item.rev>*{direction:ltr}
  .about-img-stack{padding-right:0;padding-bottom:48px}
  .about-img-sm{right:-10px;bottom:0}
  .whyus-visual{order:-1}
  .whyus-quote{left:0;right:0;bottom:-16px}
  .testi-card{min-width:calc(50% - 10px)}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:32px}
  .process-steps::before{display:none}
  .split-services{grid-template-columns:1fr}
  .split-left::after{display:none}
  .services-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  :root{--section-py:60px;--gutter:20px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .hero-title{font-size:clamp(2.8rem,10vw,4.5rem)}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-cell+.stat-cell::before{display:none}
  .stat-cell:nth-child(odd){border-right:1px solid rgba(255,255,255,.15)}
  .stat-cell:nth-child(3),.stat-cell:nth-child(4){border-top:1px solid rgba(255,255,255,.15)}
  .services-grid{grid-template-columns:1fr}
  .gallery-masonry{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .g-item.tall{grid-row:span 1}
  .testi-card{min-width:100%}
  .values-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .icon-services-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .icon-svc-circle{width:60px;height:60px}
  .icon-svc-circle svg{width:26px;height:26px}
  .nav-logo img{height:60px} /* Scaled down for mobile but still prominent */
  .navbar.scrolled .nav-logo img{height:50px}
  .split-left,.split-right{padding:44px 24px}
  .page-hero{height:340px;padding-bottom:44px}
  .cform-row{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .gallery-masonry{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .cta-btns{flex-direction:column;align-items:center}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .icon-services-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:32px}
}
