/* ============================================================
   MAK STUDIO — style.css  v2.0
   Fixes: dark/light mode, undefined CSS vars, invalid CSS,
   cursor:none on mobile, obfuscated emails, panelUp keyframe,
   pkg-tagline, PACKAGES/SERVICES arrays, lbEl outside DOM,
   --card/--border/--muted/--bg/--tr/--ff all defined,
   theme toggle, sunrise/sunset auto mode
   ============================================================ */

/* ─── BRAND COLORS (never change) ───────────────────────────── */
:root {
  --cyan:    #1BB8E8;
  --blue:    #1A7EC8;
  --purple:  #6B35C8;
  --pink:    #D42080;

  --grad:      linear-gradient(135deg,#1BB8E8 0%,#1A7EC8 30%,#6B35C8 65%,#D42080 100%);
  --grad-rev:  linear-gradient(90deg,#D42080 0%,#6B35C8 45%,#1BB8E8 100%);
  --grad-dark: linear-gradient(140deg,#0D1520 0%,#0F2645 40%,#1A1040 70%,#200D20 100%);
  --grad-soft: linear-gradient(135deg,rgba(27,184,232,.08) 0%,rgba(212,32,128,.06) 100%);

  --sh-blue:  0 8px 32px rgba(27,184,232,.28);
  --sh-pink:  0 8px 32px rgba(212,32,128,.28);
  --sh-card:  0 4px 24px rgba(0,0,0,.07);
  --sh-hover: 0 16px 48px rgba(27,184,232,.18);

  --r:  8px;
  --rm: 16px;
  --rl: 24px;
  --rx: 36px;
  --tr: all .3s ease;
  --ff: 'Poppins',sans-serif;
}

/* ─── LIGHT MODE TOKENS (default) ───────────────────────────── */
:root,
[data-theme="light"] {
  --bg:       #FFFFFF;
  --bg-off:   #F6F9FC;
  --bg-alt:   #EEF3FA;
  --card:     #FFFFFF;
  --card-alt: #F6F9FC;
  --border:   #DDE8F2;
  --text:     #1C2B3A;
  --textm:    #4E6070;
  --muted:    #6B7E8E;
  --g3:       #A8BBC8;
  --g5:       #6B7E8E;
  --g7:       #38495A;
  --darker:   #07101A;
  --nav-scroll-bg: rgba(255,255,255,.97);
  --nav-link-color: #38495A;
  --section-alt: #F6F9FC;
  --stat-bg: #FFFFFF;
  --about-q-bg: #FFFFFF;
  --mv-card-bg: #FFFFFF;
  --theme-icon: "🌙";
  color-scheme: light;
}

/* ─── DARK MODE TOKENS ───────────────────────────────────────── */
[data-theme="dark"] {
  --bg:       #0D1520;
  --bg-off:   #0F1D2E;
  --bg-alt:   #111A28;
  --card:     #131F30;
  --card-alt: #0F1D2E;
  --border:   rgba(27,184,232,.14);
  --text:     #E8F0F8;
  --textm:    #9BB0C2;
  --muted:    #7A96AA;
  --g3:       #5A7A8E;
  --g5:       #4A6A80;
  --g7:       #3A5A6E;
  --darker:   #07101A;
  --nav-scroll-bg: rgba(13,21,32,.97);
  --nav-link-color: #9BB0C2;
  --section-alt: #0F1D2E;
  --stat-bg: #111A28;
  --about-q-bg: #131F30;
  --mv-card-bg: #131F30;
  --sh-card:  0 4px 24px rgba(0,0,0,.28);
  --sh-hover: 0 16px 48px rgba(27,184,232,.22);
  --theme-icon: "☀️";
  color-scheme: dark;
}

/* ─── THEME TRANSITION ───────────────────────────────────────── */
*, *::before, *::after {
  transition:
    background-color .35s ease,
    border-color .35s ease,
    color .35s ease,
    box-shadow .35s ease;
}
/* Override for performance-sensitive animations */
.slide, .fade-up, .ticker-inner, .hb, .vis-float-tag,
.vis-ring, .scroll-hint-line, img {
  transition: inherit;
}
.fade-up { transition: opacity .7s ease, transform .7s ease; }
.slide { transition: opacity 1s ease; }

/* ─── RESET ──────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; font-size:16px }
body {
  font-family:'DM Sans',sans-serif;
  color:var(--text); background:var(--bg);
  overflow-x:hidden;
}

img { max-width:100%; height:auto; display:block }

/* ─── SKIP TO CONTENT (accessibility) ───────────────────────── */
.skip-to-content {
  position:fixed;
  top:-100%;
  left:50%;
  transform:translateX(-50%);
  background:var(--cyan);
  color:#fff;
  padding:10px 20px;
  border-radius:0 0 var(--r) var(--r);
  font-family:var(--ff);
  font-size:14px;
  font-weight:600;
  z-index:9999;
  text-decoration:none;
  transition:top .2s ease;
}
.skip-to-content:focus { top:0 }
a { text-decoration:none; color:inherit }
button { font-family:inherit; border:none; background:none; cursor:pointer }
::-webkit-scrollbar { width:3px }
::-webkit-scrollbar-thumb { background:var(--grad) }
section { padding:72px 0 }

/* ─── SCROLL PROGRESS ────────────────────────────────────────── */
.scroll-progress {
  position:fixed; top:0; left:0; height:3px; width:0%;
  background:var(--grad); z-index:9999; pointer-events:none;
  transition:width .1s linear;
}


/* ─── TYPOGRAPHY ─────────────────────────────────────────────── */
h1,h2,h3,h4 { font-family:'Poppins',sans-serif; font-weight:700; line-height:1.15 }
.g-text {
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  font-style:normal;
}
.sec-tag {
  display:inline-block;
  font-family:'Poppins',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  margin-bottom:12px;
}
.sec-h2 { font-size:clamp(26px,6vw,52px); margin-bottom:14px }
.g-line {
  width:48px; height:3px; background:var(--grad);
  border-radius:2px; margin-bottom:22px;
}
.body-p { font-size:15px; line-height:1.85; color:var(--textm) }
.wrap { width:100%; max-width:1200px; margin:0 auto; padding:0 20px }

/* ─── BUTTONS ────────────────────────────────────────────────── */
.btn-g {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:14px 32px;
  background:var(--grad); color:#fff;
  font-family:'Poppins',sans-serif; font-weight:700; font-size:13px; letter-spacing:.5px;
  border-radius:50px; box-shadow:var(--sh-blue);
  transition:transform .3s, box-shadow .3s; white-space:nowrap;
  -webkit-tap-highlight-color:transparent;
}
.btn-g:hover { transform:translateY(-3px); box-shadow:var(--sh-pink) }
.btn-g:active { transform:scale(.97) }
.btn-g.btn-xl { padding:16px 42px; font-size:15px }
.btn-outline-hero {
  display:inline-flex; align-items:center; justify-content:center;
  padding:13px 30px;
  border:2px solid rgba(255,255,255,.4); color:#fff;
  font-family:'Poppins',sans-serif; font-weight:600; font-size:13px;
  border-radius:50px; backdrop-filter:blur(8px);
  background:rgba(255,255,255,.06);
  transition:all .3s; white-space:nowrap;
  -webkit-tap-highlight-color:transparent;
}
.btn-outline-hero:hover { background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.8) }

/* ─── FADE-UP ANIMATION ──────────────────────────────────────── */
.fade-up { opacity:0; transform:translateY(34px); transition:opacity .7s ease, transform .7s ease }
.fade-up.visible { opacity:1; transform:none }
.fu1 { transition-delay:.12s } .fu2 { transition-delay:.22s } .fu3 { transition-delay:.32s }

/* ─────────────────────────────────────────────────────────────
   THEME TOGGLE BUTTON
───────────────────────────────────────────────────────────── */
.theme-toggle {
  display:flex; align-items:center; gap:6px;
  padding:7px 13px; border-radius:50px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);
  color:#fff; font-size:12px; font-weight:600;
  font-family:'Poppins',sans-serif;
  cursor:pointer; transition:all .3s;
  white-space:nowrap; flex-shrink:0;
}
.theme-toggle:hover { background:rgba(255,255,255,.22) }
header.scrolled .theme-toggle {
  background:var(--bg-alt);
  border-color:var(--border);
  color:var(--textm);
}
.tt-icon { font-size:14px; line-height:1 }
.tt-label { font-size:10px; letter-spacing:1px; text-transform:uppercase }

/* drawer theme row */
.drawer-theme-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 0;
}
.dt-label {
  font-size:11px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--g3);
}
.drawer-theme-btn {
  display:flex; align-items:center; gap:8px;
  padding:9px 16px; border-radius:50px;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.14);
  color:#fff; font-size:12px; font-weight:600;
  font-family:'Poppins',sans-serif;
  cursor:pointer; transition:all .3s;
}
.drawer-theme-btn:hover { background:var(--grad); border-color:transparent }

/* ─────────────────────────────────────────────────────────────
   MOBILE SIDE DRAWER
───────────────────────────────────────────────────────────── */
.drawer-backdrop {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.55); backdrop-filter:blur(5px);
  z-index:1400;
}
.drawer-backdrop.show { display:block }

.side-drawer {
  position:fixed; top:0; right:-110%; bottom:0;
  width:min(88vw,340px);
  background:#0D1520;
  z-index:1500;
  display:flex; flex-direction:column; gap:24px;
  padding:24px 28px 40px;
  transition:right .38s cubic-bezier(.4,0,.2,1);
  border-left:1px solid rgba(27,184,232,.12);
  overflow-y:auto;
}
.side-drawer.open { right:0 }

.drawer-head { display:flex; align-items:center; justify-content:space-between }
.drawer-close-btn {
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.08); color:#fff; font-size:16px;
  display:flex; align-items:center; justify-content:center;
  transition:background .3s; flex-shrink:0;
}
.drawer-close-btn:hover { background:var(--grad) }

.drawer-nav { display:flex; flex-direction:column; gap:2px }
.drawer-nav a {
  display:flex; align-items:center; gap:12px;
  padding:14px 0;
  font-family:'Poppins',sans-serif; font-weight:600; font-size:16px;
  color:rgba(255,255,255,.75);
  border-bottom:1px solid rgba(255,255,255,.07);
  transition:color .3s;
}
.drawer-nav a:hover { color:var(--cyan) }
.dn-num {
  font-size:9px; font-weight:700; letter-spacing:2px;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.drawer-cta-wrap { padding-top:4px }
.drawer-book { width:100%; justify-content:center; font-size:14px; padding:15px 20px }

.drawer-contact-info { display:flex; flex-direction:column; gap:10px }
.drawer-contact-info a, .drawer-contact-info span {
  font-size:13px; color:#A8BBC8; transition:color .3s
}
.drawer-contact-info a:hover { color:var(--cyan) }

.drawer-socials { display:flex; gap:8px; flex-wrap:wrap }
.ds-link {
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1);
  color:#6B7E8E; font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  transition:all .3s;
}
.ds-link:hover { background:var(--grad); color:#fff; border-color:transparent }

/* ─────────────────────────────────────────────────────────────
   NAVIGATION
───────────────────────────────────────────────────────────── */
header {
  position:fixed; inset:0 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; z-index:1000;
  transition:background .4s ease, padding .4s ease, box-shadow .4s ease, border-color .4s ease;
}
header.scrolled {
  background:var(--nav-scroll-bg);
  backdrop-filter:blur(20px);
  padding:10px 20px;
  box-shadow:0 4px 24px rgba(27,184,232,.1);
  border-bottom:1px solid var(--border);
}

.nav-brand { display:flex; align-items:center; gap:10px }
.brand-mark { display:flex; align-items:center; gap:10px }

.brand-icon {
  width:40px; height:40px; border-radius:11px;
  background:var(--grad); color:#fff;
  font-family:'Poppins',sans-serif; font-weight:900; font-size:19px;
  display:none; align-items:center; justify-content:center;
  box-shadow:var(--sh-blue); flex-shrink:0;
}
.brand-words { display:flex; flex-direction:column; line-height:1 }
.bw-mak { font-family:'Poppins',sans-serif; font-size:14px; font-weight:700; color:#38495A }
.bw-studio {
  font-family:'Poppins',sans-serif; font-size:11px; font-weight:700;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  letter-spacing:2.5px;
}
.bw-tag { font-size:7.5px; color:#A8BBC8; letter-spacing:1.5px; text-transform:uppercase }

header:not(.scrolled) .bw-mak { color:rgba(255,255,255,.85) }
header:not(.scrolled) .bw-tag  { color:rgba(255,255,255,.35) }
[data-theme="dark"] header.scrolled .bw-mak { color:var(--text) }

.nav-desk { display:none; align-items:center; gap:24px }
.nav-desk a {
  font-family:'Poppins',sans-serif; font-size:13px; font-weight:500;
  color:rgba(255,255,255,.85); position:relative; transition:color .3s;
}
header.scrolled .nav-desk a { color:var(--nav-link-color) }
.nav-desk a::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0;
  height:2px; background:var(--grad); border-radius:1px;
  transform:scaleX(0); transition:transform .3s;
}
.nav-desk a:hover::after, .nav-desk a.active::after { transform:scaleX(1) }
.nav-book-btn {
  padding:10px 22px; background:var(--grad); color:#fff;
  font-family:'Poppins',sans-serif; font-weight:700; font-size:13px;
  border-radius:50px; box-shadow:var(--sh-blue);
  transition:all .3s;
}
.nav-book-btn:hover { transform:translateY(-2px); box-shadow:var(--sh-pink) }

.hamburger {
  display:flex; flex-direction:column; gap:5px; padding:6px;
  background:rgba(255,255,255,.1); border-radius:8px;
  border:1px solid rgba(255,255,255,.2);
}
.hamburger span { width:22px; height:2px; background:#fff; border-radius:2px; transition:all .3s }
header.scrolled .hamburger { background:var(--bg-alt); border-color:var(--border) }
header.scrolled .hamburger span { background:var(--text) }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px) }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0) }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px) }

/* ─────────────────────────────────────────────────────────────
   HERO SLIDER
───────────────────────────────────────────────────────────── */
.hero {
  position:relative; min-height:100vh; min-height:100svh;
  overflow:hidden; background:var(--grad-dark);
}
.hero-bg-blobs { position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0 }
.hb { position:absolute; border-radius:50%; filter:blur(72px) }
.hb1 {
  width:clamp(260px,55vw,520px); height:clamp(260px,55vw,520px);
  background:radial-gradient(circle,var(--cyan),transparent 70%);
  top:-80px; left:-80px; opacity:.32;
  animation:blobFloat 10s ease-in-out infinite;
}
.hb2 {
  width:clamp(220px,45vw,440px); height:clamp(220px,45vw,440px);
  background:radial-gradient(circle,var(--pink),transparent 70%);
  bottom:-80px; right:-60px; opacity:.28;
  animation:blobFloat 10s ease-in-out 3.5s infinite;
}
.hb3 {
  width:clamp(160px,30vw,300px); height:clamp(160px,30vw,300px);
  background:radial-gradient(circle,var(--purple),transparent 70%);
  top:45%; left:50%; opacity:.22;
  animation:blobFloat 10s ease-in-out 6s infinite;
}
@keyframes blobFloat {
  0%,100% { transform:translate(0,0) scale(1) }
  33%      { transform:translate(22px,-16px) scale(1.07) }
  66%      { transform:translate(-16px,22px) scale(.93) }
}
.hero-grid-lines {
  position:absolute; inset:0; z-index:1;
  background-image:
    linear-gradient(rgba(27,184,232,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(27,184,232,.04) 1px,transparent 1px);
  background-size:52px 52px;
}

.slide { position:absolute; inset:0; opacity:0; transition:opacity 1s ease; z-index:2 }
.slide.active { opacity:1 }

.slide-layout {
  position:absolute; inset:0;
  display:flex; align-items:center;
  padding:88px 20px 72px;
  gap:32px;
}
.slide-copy { flex:1; min-width:0; position:relative; z-index:5 }
.slide-visual { display:none; flex:0 0 300px; height:340px; position:relative; z-index:5 }

.slide-eyebrow {
  display:inline-flex; align-items:center; gap:9px;
  background:rgba(255,255,255,.1); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.18); padding:7px 16px;
  border-radius:50px; font-family:'Poppins',sans-serif;
  font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase;
  color:var(--cyan); margin-bottom:20px;
  opacity:0; transform:translateY(12px);
  transition:opacity .7s .3s, transform .7s .3s;
}
.slide.active .slide-eyebrow { opacity:1; transform:none }
.eyebrow-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--grad); display:inline-block;
  animation:pdot 2s ease infinite;
}
@keyframes pdot { 0%,100% { transform:scale(1) } 50% { transform:scale(1.6); opacity:.7 } }

.slide-headline {
  font-family:'Poppins',sans-serif; font-weight:900;
  font-size:clamp(34px,8vw,80px); color:#fff; line-height:1.06;
  margin-bottom:18px;
  opacity:0; transform:translateY(18px);
  transition:opacity .8s .5s, transform .8s .5s;
}
.slide.active .slide-headline { opacity:1; transform:none }

.slide-sub {
  font-size:clamp(13px,1.5vw,15.5px); line-height:1.8;
  color:rgba(255,255,255,.7); max-width:460px; margin-bottom:28px;
  opacity:0; transform:translateY(12px);
  transition:opacity .8s .7s, transform .8s .7s;
}
.slide.active .slide-sub { opacity:1; transform:none }

.slide-ctas {
  display:flex; gap:12px; flex-wrap:wrap; margin-bottom:32px;
  opacity:0; transform:translateY(12px);
  transition:opacity .8s .9s, transform .8s .9s;
}
.slide.active .slide-ctas { opacity:1; transform:none }

.slide-mini-stats {
  display:flex; align-items:center; gap:18px;
  opacity:0; transition:opacity .8s 1.1s;
}
.slide.active .slide-mini-stats { opacity:1 }
.ms-item { display:flex; flex-direction:column }
.ms-item strong { font-family:'Poppins',sans-serif; font-size:18px; font-weight:800; color:#fff; line-height:1 }
.ms-item span   { font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.45) }
.ms-sep { width:1px; height:28px; background:rgba(255,255,255,.14) }

.vis-card {
  position:absolute; border-radius:var(--rl);
  background:rgba(27,184,232,.28);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(12px);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 20px 56px rgba(0,0,0,.38);
}
.vis-a { width:210px; height:260px; top:28px; left:24px; font-size:64px }
.vis-b { width:130px; height:160px; bottom:12px; right:8px; font-size:44px; background:rgba(212,32,128,.28) }
.vis-float-tag {
  position:absolute; top:10px; right:-8px;
  background:var(--grad); color:#fff; padding:8px 13px;
  border-radius:11px; font-family:'Poppins',sans-serif;
  font-size:10px; font-weight:700; white-space:nowrap;
  box-shadow:var(--sh-blue);
  animation:tagFloat 3s ease-in-out infinite;
}
@keyframes tagFloat { 0%,100% { transform:translateY(0) } 50% { transform:translateY(-8px) } }
.vis-ring {
  position:absolute; border-radius:50%;
  border:1.5px solid rgba(27,184,232,.22);
  animation:ringPulse 3.5s ease-in-out infinite;
  pointer-events:none;
}
.vr1 { width:64px; height:64px; top:6px; right:22px }
.vr2 { width:40px; height:40px; bottom:52px; left:8px; border-color:rgba(212,32,128,.28); animation-delay:1.8s }
@keyframes ringPulse { 0%,100% { transform:scale(1); opacity:.6 } 50% { transform:scale(1.4); opacity:.18 } }

.slider-controls {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; align-items:center; gap:14px; z-index:10;
}
.slider-dots { display:flex; gap:7px; align-items:center }
.sdot {
  height:4px; width:16px; border-radius:2px;
  background:rgba(255,255,255,.28); padding:0;
  transition:all .35s ease; cursor:pointer;
}
.sdot.active { width:32px; background:var(--grad) }
.slide-counter { font-family:'Poppins',sans-serif; font-size:10px; color:rgba(255,255,255,.4); letter-spacing:2px }
.slider-arrows { position:absolute; right:20px; bottom:20px; display:flex; gap:8px; z-index:10 }
.sarr {
  width:42px; height:42px; border-radius:50%;
  border:1.5px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.07); backdrop-filter:blur(8px);
  color:#fff; font-size:15px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .3s;
}
.sarr:hover { background:var(--grad); border-color:transparent; box-shadow:var(--sh-blue); transform:scale(1.07) }
.sarr:active { transform:scale(.96) }
.scroll-hint-wrap {
  position:absolute; bottom:28px; left:20px;
  display:none; flex-direction:column; align-items:center; gap:5px; z-index:10;
}
.scroll-hint-line {
  width:1px; height:44px;
  background:linear-gradient(to bottom,var(--cyan),transparent);
  animation:shLine 2s ease infinite;
}
@keyframes shLine { 0%,100% { opacity:.3 } 50% { opacity:1 } }
.scroll-hint-label { font-size:8px; letter-spacing:3px; color:rgba(255,255,255,.3); text-transform:uppercase }

/* ─────────────────────────────────────────────────────────────
   TICKER
───────────────────────────────────────────────────────────── */
.ticker-bar { overflow:hidden; white-space:nowrap; background:var(--grad); padding:13px 0 }
.ticker-inner { display:inline-block; animation:ticker 26s linear infinite }
.ticker-inner span {
  display:inline-block; padding:0 18px;
  font-family:'Poppins',sans-serif; font-size:11px; font-weight:600;
  color:rgba(255,255,255,.9); text-transform:uppercase; letter-spacing:1px;
}
.t-dot { color:rgba(255,255,255,.45) !important; padding:0 4px !important }
@keyframes ticker { 0% { transform:translateX(0) } 100% { transform:translateX(-50%) } }

/* ─────────────────────────────────────────────────────────────
   STATS
───────────────────────────────────────────────────────────── */
.stats-sec { padding:56px 0; background:var(--bg) }
.stats-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  max-width:1200px; margin:0 auto;
}
.stat-item {
  padding:36px 20px; text-align:center;
  border:1px solid var(--border); background:var(--bg);
  transition:background .3s;
}
.stat-item:hover { background:var(--bg-alt) }
.stat-row { display:flex; align-items:baseline; justify-content:center; gap:2px }
.stat-num {
  font-family:'Poppins',sans-serif; font-size:clamp(36px,7vw,58px); font-weight:900;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1;
}
.stat-sfx {
  font-family:'Poppins',sans-serif; font-size:clamp(18px,4vw,28px); font-weight:900;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-label { font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-top:6px }

/* ─────────────────────────────────────────────────────────────
   ABOUT
───────────────────────────────────────────────────────────── */
.about-sec { background:var(--bg-off) }
.about-grid { display:grid; grid-template-columns:1fr; gap:44px; align-items:center; margin-bottom:52px }

.about-img-area { position:relative; max-width:380px; margin:0 auto }
.ai-main {
  width:100%; aspect-ratio:4/5; border-radius:var(--rx);
  background:linear-gradient(135deg,#cce8f8,#e8d0f8);
  display:flex; align-items:center; justify-content:center;
  font-size:clamp(60px,14vw,100px);
  box-shadow:0 24px 64px rgba(27,184,232,.18);
  position:relative; overflow:hidden;
}
.ai-main img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:var(--rx) }
.ai-placeholder { position:relative; z-index:1 }
.ai-yr-badge {
  position:absolute; top:-12px; left:-12px;
  width:76px; height:76px; border-radius:50%;
  background:var(--grad); color:#fff;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  box-shadow:var(--sh-blue); z-index:3;
}
.ai-yr-badge strong { font-family:'Poppins',sans-serif; font-size:18px; font-weight:900; line-height:1 }
.ai-yr-badge span   { font-size:9px; font-weight:600; opacity:.85 }
.ai-accent {
  position:absolute; bottom:-22px; right:-18px;
  width:clamp(110px,26vw,170px); height:clamp(130px,30vw,210px);
  border-radius:var(--rl);
  background:linear-gradient(135deg,#f8d0e8,#d0d0f8);
  border:4px solid var(--bg); box-shadow:0 12px 36px rgba(212,32,128,.18);
  display:flex; align-items:center; justify-content:center;
  font-size:clamp(34px,8vw,56px); overflow:hidden;
}
.ai-accent img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:calc(var(--rl) - 4px) }
.ai-chip {
  position:absolute; bottom:14px; left:14px;
  padding:7px 14px; border-radius:50px;
  font-family:'Poppins',sans-serif; font-size:10px; font-weight:700;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  background-color:var(--bg); border:1px solid rgba(27,184,232,.13);
  box-shadow:var(--sh-card); z-index:4;
}
.about-text { display:flex; flex-direction:column; gap:0 }
.about-quote {
  margin-top:24px; padding:16px 18px;
  background:var(--about-q-bg); border-radius:0 var(--r) var(--r) 0;
  border-left:3px solid; border-image:var(--grad) 1;
  box-shadow:var(--sh-card);
}
.about-quote p    { font-size:13.5px; font-style:italic; color:var(--textm); line-height:1.75 }
.about-quote cite {
  display:block; margin-top:8px;
  font-size:9.5px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.about-badges { display:flex; flex-wrap:wrap; gap:9px; margin-top:20px }
.about-badges span {
  padding:7px 15px; border-radius:50px;
  border:1px solid var(--border);
  font-family:'Poppins',sans-serif; font-size:11px; font-weight:600;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  background-color:var(--bg-off);
}
.mv-row { display:grid; grid-template-columns:1fr; gap:14px }
.mv-card {
  background:var(--mv-card-bg); border-radius:var(--rm);
  padding:32px 24px; box-shadow:var(--sh-card);
  border-top:3px solid; border-image:var(--grad) 1;
  transition:all .4s;
}
.mv-card:hover { transform:translateY(-6px); box-shadow:var(--sh-hover) }
.mv-ico {
  width:52px; height:52px; border-radius:var(--r);
  background:var(--grad-soft); border:1px solid rgba(27,184,232,.12);
  display:flex; align-items:center; justify-content:center;
  font-size:24px; margin-bottom:14px;
}
.mv-card h3 {
  font-family:'Poppins',sans-serif; font-size:19px; font-weight:700; margin-bottom:10px;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.mv-card p { font-size:13.5px; line-height:1.8; color:var(--textm) }

/* ─────────────────────────────────────────────────────────────
   SERVICES
───────────────────────────────────────────────────────────── */
.services-sec { background:var(--bg) }
.sec-hdr { text-align:center; margin-bottom:44px }
.svc-grid { display:grid; grid-template-columns:1fr; gap:14px }
.svc-card {
  background:var(--bg-off); border-radius:var(--rm); padding:28px 22px;
  position:relative; overflow:hidden; border:1px solid var(--border);
  cursor:pointer; transition:all .4s ease;
  -webkit-tap-highlight-color:transparent;
}
.svc-card::before {
  content:''; position:absolute; inset:0;
  background:var(--grad-soft); opacity:0; transition:opacity .4s;
}
.svc-card:hover, .svc-card:active { transform:translateY(-5px); box-shadow:var(--sh-hover); border-color:rgba(27,184,232,.18) }
.svc-card:hover::before, .svc-card:active::before { opacity:1 }
.svc-n {
  position:absolute; top:14px; right:18px;
  font-family:'Poppins',sans-serif; font-size:52px; font-weight:900;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  opacity:.09; line-height:1;
}
.svc-ico {
  width:50px; height:50px; border-radius:var(--r);
  background:var(--grad); display:flex; align-items:center; justify-content:center;
  font-size:22px; margin-bottom:14px; box-shadow:0 6px 18px rgba(27,184,232,.28);
  position:relative; z-index:2;
}
.svc-card h3 { font-family:'Poppins',sans-serif; font-size:17px; font-weight:700; margin-bottom:7px; position:relative; z-index:2 }
.svc-card p   { font-size:13px; line-height:1.8; color:var(--textm); position:relative; z-index:2 }
.svc-arrow {
  display:inline-block; margin-top:14px;
  font-family:'Poppins',sans-serif; font-size:11px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  opacity:0; transform:translateX(-6px);
  transition:all .3s; position:relative; z-index:2;
}
.svc-card:hover .svc-arrow, .svc-card:active .svc-arrow { opacity:1; transform:none }

/* ─────────────────────────────────────────────────────────────
   EVENTS SECTION
───────────────────────────────────────────────────────────── */
.events-sec { background:var(--bg-off) }
.events-intro { display:grid; grid-template-columns:1fr; gap:40px; margin-bottom:8px }
.events-intro-visual {
  position:relative; border-radius:var(--rx); overflow:hidden; min-height:260px;
  background:var(--card); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
}
.events-intro-visual img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:var(--rx) }
.ev-placeholder {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; font-size:2.5rem; width:100%; height:100%; min-height:260px;
}
.ev-pl-label { font-size:.85rem; color:var(--muted); font-weight:600; font-family:'Poppins',sans-serif }
.ev-badge-float {
  position:absolute; bottom:16px; right:16px;
  background:var(--grad); color:#fff; font-size:.72rem; font-weight:700;
  padding:6px 14px; border-radius:40px; letter-spacing:.04em;
}

.ev-types-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:14px; margin:40px 0 }
.ev-type-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--rm);
  padding:20px 14px; text-align:center; transition:var(--tr);
}
.ev-type-card:hover { border-color:var(--cyan); transform:translateY(-3px) }
.ev-type-ico { font-size:1.6rem; margin-bottom:7px }
.ev-type-card h4 { font-size:.82rem; font-weight:700; margin-bottom:4px; color:var(--text) }
.ev-type-card p   { font-size:.75rem; color:var(--muted); line-height:1.45 }

.ev-features-row {
  background:var(--card); border:1px solid var(--border); border-radius:var(--rx);
  padding:32px; margin:40px 0;
}
.ev-feat-title { font-size:1.05rem; font-weight:700; margin-bottom:20px; color:var(--text) }
.ev-feat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:10px }
.ev-feat {
  display:flex; align-items:center; gap:9px;
  font-size:.83rem; color:var(--textm);
  padding:8px 12px; background:var(--bg-off); border-radius:8px;
}
.ef-ico { font-size:1rem; flex-shrink:0 }

/* ─────────────────────────────────────────────────────────────
   REAL ESTATE & PACKAGES — shared
───────────────────────────────────────────────────────────── */
.re-sec      { background:var(--bg) }
.packages-sec { background:var(--bg-off) }

.mobile-swipe-hint {
  text-align:center; font-size:11px; color:var(--muted);
  font-family:'Poppins',sans-serif; letter-spacing:1px; margin-bottom:10px;
}
.pkg-scroll-wrap { overflow-x:auto; scrollbar-width:none; padding:6px 4px 16px }
.pkg-scroll-wrap::-webkit-scrollbar { display:none }
.pkg-row {
  display:flex; gap:18px;
  min-width:max-content;
  padding:4px 0;
}
.pkg-card {
  flex:0 0 clamp(278px,82vw,330px);
  background:var(--card); border-radius:var(--rx);
  padding:34px 26px; border:2px solid var(--border);
  position:relative; overflow:hidden;
  cursor:pointer; transition:all .4s ease;
  -webkit-tap-highlight-color:transparent;
}
.pkg-card:hover, .pkg-card:active {
  transform:translateY(-6px);
  box-shadow:0 24px 60px rgba(27,184,232,.15);
  border-color:rgba(27,184,232,.3);
}
.pkg-featured { background:var(--grad); border-color:transparent }
.pkg-featured:hover { box-shadow:0 24px 60px rgba(212,32,128,.3) }

.pkg-popular-badge {
  position:absolute; top:-1px; left:50%; transform:translateX(-50%);
  background:rgba(255,255,255,.22); color:#fff;
  backdrop-filter:blur(8px);
  font-family:'Poppins',sans-serif; font-size:9px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  padding:5px 16px; border-radius:0 0 10px 10px;
}
.pkg-tier-lbl {
  font-size:8.5px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  margin-bottom:5px; display:block;
}
.pkg-featured .pkg-tier-lbl { background:none; -webkit-text-fill-color:rgba(255,255,255,.65) }
.pkg-name { font-family:'Poppins',sans-serif; font-size:26px; font-weight:800; margin-bottom:8px; color:var(--text) }
.pkg-featured .pkg-name { color:#fff }
.pkg-tagline { font-size:12.5px; color:var(--textm); line-height:1.6; margin-bottom:16px; padding-bottom:16px; border-bottom:1px solid var(--border) }
.pkg-featured .pkg-tagline { color:rgba(255,255,255,.72); border-bottom-color:rgba(255,255,255,.18) }
.pkg-desc { font-size:12.5px; color:var(--textm); line-height:1.6; margin-bottom:16px; padding-bottom:16px; border-bottom:1px solid var(--border) }
.pkg-featured .pkg-desc { color:rgba(255,255,255,.72); border-bottom-color:rgba(255,255,255,.18) }

.pkg-feats { list-style:none; margin-bottom:24px }
.pkg-feats li {
  font-size:12px; color:var(--textm); padding:7px 0;
  border-bottom:1px solid var(--border);
  display:flex; align-items:flex-start; gap:9px; line-height:1.5;
}
.pkg-feats li:last-child { border-bottom:none }
.pkg-featured .pkg-feats li { color:rgba(255,255,255,.85); border-bottom-color:rgba(255,255,255,.14) }
.pkg-feats li::before {
  content:'✓'; flex-shrink:0;
  width:18px; height:18px; border-radius:50%;
  background:var(--grad); color:#fff;
  font-size:9px; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  margin-top:1px;
}
.pkg-featured .pkg-feats li::before { background:rgba(255,255,255,.22) }
.pkg-includes-label { font-size:9px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:6px }
.pkg-featured .pkg-includes-label { color:rgba(255,255,255,.55) }
.pkg-inc li::before { content:'＋' !important; background:var(--grad-soft) !important; color:var(--cyan) !important }
.pkg-featured .pkg-inc li::before { background:rgba(255,255,255,.15) !important; color:#fff !important }

.pkg-btn {
  width:100%; padding:13px; border-radius:50px;
  font-family:'Poppins',sans-serif; font-size:13px; font-weight:700;
  background:linear-gradient(var(--card),var(--card)) padding-box, var(--grad) border-box;
  border:2px solid transparent; color:var(--blue);
  cursor:pointer; transition:all .3s; margin-top:auto;
}
.pkg-btn:hover, .pkg-btn:active { background:var(--grad); color:#fff }
.pkg-featured .pkg-btn { background:#fff; color:var(--blue); border-color:transparent }
.pkg-featured .pkg-btn:hover { background:rgba(255,255,255,.18); color:#fff }

.event-pkg-wrap { overflow:visible; padding-inline:0 }
.event-pkg-row {
  min-width:0;
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:18px;
  align-items:start;
  grid-auto-flow:row dense;
}
.event-pkg-card {
  width:100%;
  flex:none;
  cursor:default;
  display:flex;
  flex-direction:column;
  align-self:start;
  min-height:0;
  grid-column:auto;
  transition:transform .4s ease, box-shadow .4s ease, border-color .4s ease, background .35s ease;
}
.event-pkg-card .pkg-tagline { margin-bottom:18px }
.event-pkg-card:not(.is-expanded) .event-pkg-details { display:none !important }
.event-pkg-kpis {
  display:flex; flex-wrap:wrap; gap:8px;
  margin:2px 0 16px;
}
.event-pkg-kpis span {
  display:inline-flex; align-items:center; justify-content:center;
  min-height:34px; padding:8px 12px; border-radius:999px;
  border:1px solid rgba(27,184,232,.15);
  background:linear-gradient(180deg, rgba(27,184,232,.10), rgba(212,32,128,.08));
  color:var(--text); font-family:'Poppins',sans-serif;
  font-size:10px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase;
}
.pkg-featured .event-pkg-kpis span {
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.18);
  color:#fff;
}
.event-pkg-preview {
  list-style:none;
  display:grid; gap:10px;
  margin:0 0 20px;
}
.event-pkg-preview li {
  position:relative;
  padding-left:18px;
  font-size:12.5px; line-height:1.65; color:var(--textm);
}
.event-pkg-preview li::before {
  content:'';
  position:absolute; left:0; top:.6em;
  width:7px; height:7px; border-radius:50%;
  background:var(--grad);
  box-shadow:0 0 0 4px rgba(27,184,232,.08);
}
.pkg-featured .event-pkg-preview li { color:rgba(255,255,255,.86) }
.pkg-featured .event-pkg-preview li::before {
  background:#fff;
  box-shadow:0 0 0 4px rgba(255,255,255,.12);
}
.pkg-toggle-btn {
  width:100%;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:13px 16px; border-radius:18px;
  border:1px solid rgba(27,184,232,.18);
  background:rgba(27,184,232,.05);
  color:var(--text);
  cursor:zoom-in; transition:all .3s ease;
  font-family:'Poppins',sans-serif; font-size:12px; font-weight:700;
  letter-spacing:1.1px; text-transform:uppercase;
}
.event-pkg-card.is-expanded .pkg-toggle-btn { cursor:zoom-out }
.pkg-toggle-btn:hover, .pkg-toggle-btn:active {
  transform:translateY(-2px);
  border-color:rgba(27,184,232,.34);
  background:rgba(27,184,232,.10);
}
.pkg-toggle-copy { pointer-events:none }
.pkg-toggle-icon {
  width:28px; height:28px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  background:#fff; color:var(--blue);
  font-size:18px; font-weight:700; line-height:1;
  box-shadow:0 10px 26px rgba(17,31,48,.12);
  pointer-events:none;
}
.pkg-featured .pkg-toggle-btn {
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.18);
  color:#fff;
}
.pkg-featured .pkg-toggle-btn:hover, .pkg-featured .pkg-toggle-btn:active {
  border-color:rgba(255,255,255,.32);
  background:rgba(255,255,255,.18);
}
.pkg-featured .pkg-toggle-icon {
  background:#fff;
  color:var(--blue);
}
.event-pkg-details {
  margin-top:18px; padding-top:18px;
  border-top:1px solid var(--border);
  animation:eventPackageReveal .36s ease;
}
.pkg-featured .event-pkg-details { border-top-color:rgba(255,255,255,.18) }
.event-pkg-detail-shell {
  display:grid; gap:16px;
  margin-bottom:18px;
}
.event-pkg-story {
  padding:20px;
  background:var(--card-alt);
  border:1px solid var(--border);
  border-radius:22px;
}
.pkg-featured .event-pkg-story {
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.16);
}
.event-pkg-story-label {
  display:block;
  margin-bottom:10px;
  color:var(--muted);
  font-family:'Poppins',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
}
.pkg-featured .event-pkg-story-label { color:rgba(255,255,255,.62) }
.event-pkg-story p {
  font-size:12.5px; line-height:1.7; color:var(--textm);
  margin-bottom:16px;
}
.pkg-featured .event-pkg-story p { color:rgba(255,255,255,.82) }
.event-pkg-story-points {
  display:flex; flex-wrap:wrap; gap:8px;
}
.event-pkg-story-points span {
  display:inline-flex; align-items:center;
  min-height:32px; padding:7px 11px; border-radius:999px;
  background:var(--bg); border:1px solid rgba(27,184,232,.12);
  font-size:10px; font-weight:700; letter-spacing:.8px;
  color:var(--blue); text-transform:uppercase;
}
[data-theme="dark"] .event-pkg-story-points span {
  border-color:rgba(27,184,232,.22);
  color:var(--cyan);
}
.pkg-featured .event-pkg-story-points span {
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.18);
  color:#fff;
}
.event-pkg-feats { margin-bottom:0 }
.event-pkg-feats li { break-inside:avoid }
.event-pkg-quote-btn { margin-top:0 }
.event-pkg-card.is-expanded {
  box-shadow:0 28px 72px rgba(27,184,232,.16);
  border-color:rgba(27,184,232,.3);
}
.pkg-featured.event-pkg-card.is-expanded {
  box-shadow:0 28px 72px rgba(212,32,128,.28);
}
@keyframes eventPackageReveal {
  from { opacity:0; transform:translateY(10px) }
  to   { opacity:1; transform:translateY(0) }
}

.custom-pkg-banner {
  margin-top:36px; padding:36px 24px;
  background:var(--grad); border-radius:var(--rx);
  box-shadow:0 20px 56px rgba(27,184,232,.22);
  display:flex; flex-direction:column; align-items:center; gap:18px; text-align:center;
}
.cpb-text strong { display:block; font-family:'Poppins',sans-serif; font-size:18px; font-weight:800; color:#fff; margin-bottom:6px }
.cpb-text span   { font-size:13px; color:rgba(255,255,255,.75) }

/* À La Carte cards */
.alacarte-grid { margin-top:56px; display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:18px }
.alacarte-grid h3 { font-size:clamp(1.2rem,2.5vw,1.7rem); margin-bottom:8px; color:var(--text) }
.alacarte-grid > p { color:var(--muted); margin-bottom:28px }

.ac-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--rm);
  padding:26px 22px 22px; cursor:pointer; transition:var(--tr);
  display:flex; flex-direction:column; gap:6px;
}
.ac-card:hover { border-color:var(--cyan); transform:translateY(-4px); box-shadow:var(--sh-hover) }
.ac-ico { font-size:1.9rem; margin-bottom:3px }
.ac-card h4 { font-size:.95rem; font-weight:700; color:var(--text) }
.ac-card p  { font-size:.82rem; color:var(--muted); line-height:1.55; flex:1 }
.ac-btn {
  margin-top:12px; background:transparent;
  border:1px solid var(--border); color:var(--cyan);
  padding:8px 15px; border-radius:40px;
  font-size:.8rem; font-weight:600; cursor:pointer; transition:var(--tr); width:fit-content;
}
.ac-btn:hover { background:var(--cyan); color:#000; border-color:var(--cyan) }

/* Real estate individual services grid */
.re-services-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:18px; margin-top:40px }
.re-svc {
  background:var(--card); border:1px solid var(--border); border-radius:var(--rm);
  padding:22px; cursor:pointer; transition:var(--tr);
}
.re-svc:hover { border-color:var(--cyan); transform:translateY(-3px); box-shadow:var(--sh-hover) }
.re-svc:hover .svc-arrow, .re-svc:active .svc-arrow { opacity:1; transform:none }
.re-svc-ico { font-size:1.7rem; margin-bottom:9px }
.re-svc h4  { font-size:.93rem; font-weight:700; margin-bottom:7px; color:var(--text) }
.re-svc p   { font-size:.81rem; color:var(--muted); line-height:1.55; margin-bottom:10px }
.re-svc .svc-arrow { font-size:.78rem; font-weight:600; color:var(--cyan) }

/* Additional package cards */
.add-pkgs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:22px; margin-top:44px }
.add-pkg-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--rx);
  padding:30px 26px; cursor:pointer; transition:var(--tr); display:flex; flex-direction:column;
}
.add-pkg-card:hover { border-color:var(--cyan); transform:translateY(-4px); box-shadow:var(--sh-hover) }
.apk-icon  { font-size:2.3rem; margin-bottom:13px }
.add-pkg-card h3 { font-size:1.05rem; font-weight:800; margin-bottom:7px; color:var(--text) }
.apk-sub   { font-size:.86rem; color:var(--muted); margin-bottom:18px; line-height:1.6 }

/* ─────────────────────────────────────────────────────────────
   TEAM
───────────────────────────────────────────────────────────── */
.team-sec  { background:var(--bg) }
.team-grid { display:grid; grid-template-columns:1fr; gap:28px }
.team-card { text-align:center }
.team-photo-wrap {
  position:relative; width:100%; max-width:300px;
  aspect-ratio:3/4; margin:0 auto 18px;
  border-radius:var(--rx); overflow:hidden;
  box-shadow:0 16px 48px rgba(27,184,232,.14);
  cursor:pointer;
}
.team-photo {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center top;
  transition:transform .6s ease; display:block;
}
.team-photo-wrap:hover .team-photo { transform:scale(1.05) }
.team-photo-fallback {
  position:absolute; inset:0;
  display:none; align-items:center; justify-content:center; font-size:72px;
}
.tp-grad-1 { background:linear-gradient(135deg,#cce8f8,#e8d0f8) }
.tp-grad-2 { background:linear-gradient(135deg,#f8d0e8,#e8d0f8) }
.tp-grad-3 { background:linear-gradient(135deg,#d0f0e8,#cce8f8) }
.team-hover-layer {
  position:absolute; inset:0; background:var(--grad);
  opacity:0; transition:opacity .38s;
  display:flex; align-items:flex-end; justify-content:center; padding-bottom:22px;
}
.team-photo-wrap:hover .team-hover-layer, .team-photo-wrap:active .team-hover-layer { opacity:.88 }
.team-socials { display:flex; gap:10px }
.team-socials a {
  width:38px; height:38px; border-radius:50%;
  border:2px solid rgba(255,255,255,.6); background:rgba(255,255,255,.15); color:#fff;
  font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center; transition:all .3s;
}
.team-socials a:hover { background:#fff; color:var(--blue) }
.team-name { font-family:'Poppins',sans-serif; font-size:17px; font-weight:700; margin-bottom:4px; color:var(--text) }
.team-role {
  font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ─────────────────────────────────────────────────────────────
   GALLERY
───────────────────────────────────────────────────────────── */
.gallery-sec { background:var(--bg); padding-bottom:56px }
.sec-hdr-split { display:grid; grid-template-columns:1fr; gap:20px; margin-bottom:28px }

.gal-tabs {
  display:flex; gap:8px; overflow-x:auto;
  padding:4px 4px 16px; margin-bottom:8px; scrollbar-width:none;
}
.gal-tabs::-webkit-scrollbar { display:none }
.gal-tab {
  flex-shrink:0; padding:9px 18px; border-radius:50px;
  font-family:'Poppins',sans-serif; font-size:12px; font-weight:600;
  background:var(--bg-off); border:1.5px solid var(--border);
  color:var(--textm); cursor:pointer; transition:all .3s; -webkit-tap-highlight-color:transparent;
}
.gal-tab.active, .gal-tab:hover {
  background:var(--grad); color:#fff; border-color:transparent;
  box-shadow:0 4px 16px rgba(27,184,232,.25);
}

.gal-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  grid-auto-rows:180px;
  gap:8px; padding:0 8px; margin-top:8px;
}
.gal-item {
  border-radius:var(--rm); overflow:hidden; position:relative; cursor:pointer;
  -webkit-tap-highlight-color:transparent; transition:transform .4s ease, opacity .4s ease;
}
.gal-item.hidden { display:none }
.gal-item img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .5s ease }
.gal-item:hover img, .gal-item:active img { transform:scale(1.06) }
.gal-placeholder {
  position:absolute; inset:0; display:none;
  flex-direction:column; align-items:center; justify-content:center; gap:8px;
}
.gal-placeholder span:first-child { font-size:clamp(32px,7vw,52px); opacity:.45 }
.gp-lbl {
  font-family:'Poppins',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:.9;
}
.gp-wedding  { background:linear-gradient(135deg,#cce8f8,#e8d0f8) }
.gp-event    { background:linear-gradient(135deg,#f8e0cc,#f8d0e8) }
.gp-corp     { background:linear-gradient(135deg,#ccf0e8,#cce8f8) }
.gp-re       { background:linear-gradient(135deg,#e8f8cc,#d0f0e8) }
.gp-portrait { background:linear-gradient(135deg,#f8d0e8,#e0ccf8) }
.gp-drone    { background:linear-gradient(135deg,#d0e8f8,#d0d0f8) }
.gal-overlay {
  position:absolute; inset:0; background:var(--grad);
  opacity:0; transition:opacity .35s;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
}
.gal-item:hover .gal-overlay, .gal-item:active .gal-overlay { opacity:.82 }
.gal-zoom    { color:#fff; font-size:28px; line-height:1 }
.gal-cat-lbl { color:#fff; font-family:'Poppins',sans-serif; font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase }
.gi-lg   { grid-column:span 2; grid-row:span 2 }
.gi-tall { grid-row:span 2 }
.gal-cta { display:flex; justify-content:center; margin-top:36px }

/* ─────────────────────────────────────────────────────────────
   LIGHTBOX
───────────────────────────────────────────────────────────── */
.lightbox {
  position:fixed; inset:0; z-index:3000;
  background:rgba(7,16,26,.96); backdrop-filter:blur(16px);
  display:none; align-items:center; justify-content:center; padding:20px;
}
.lightbox.open { display:flex }
.lb-close {
  position:absolute; top:16px; right:16px;
  width:40px; height:40px; border-radius:50%;
  background:rgba(255,255,255,.1); color:#fff; font-size:18px;
  display:flex; align-items:center; justify-content:center;
  z-index:10; transition:background .3s;
}
.lb-close:hover { background:var(--grad) }
.lb-inner { max-width:90vw; max-height:85vh; display:flex; flex-direction:column; align-items:center; gap:12px }
.lb-img { max-width:100%; max-height:75vh; border-radius:var(--rm); object-fit:contain; box-shadow:0 32px 80px rgba(0,0,0,.5) }
.lb-placeholder {
  max-width:80vw; min-width:200px; min-height:200px; border-radius:var(--rm);
  display:none; align-items:center; justify-content:center; font-size:80px;
  background:var(--grad-soft); border:1px solid rgba(27,184,232,.15);
}
.lb-caption {
  font-family:'Poppins',sans-serif; font-size:12px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.lb-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.2);
  color:#fff; font-size:18px; display:flex; align-items:center; justify-content:center;
  z-index:10; transition:all .3s; cursor:pointer;
}
.lb-nav:hover { background:var(--grad); border-color:transparent }
.lb-prev { left:12px } .lb-next { right:12px }

/* ─────────────────────────────────────────────────────────────
   CONTACT CTA
───────────────────────────────────────────────────────────── */
.contact-sec { background:var(--grad-dark); padding:96px 0; position:relative; overflow:hidden; text-align:center }
.contact-inner { position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; gap:20px }
.contact-h2 { font-family:'Poppins',sans-serif; font-size:clamp(30px,7vw,62px); font-weight:900; color:#fff; line-height:1.1 }
.contact-sub   { font-size:15px; color:rgba(255,255,255,.62); max-width:440px; line-height:1.8 }
.contact-btns  { display:flex; gap:12px; flex-wrap:wrap; justify-content:center }
.contact-chips { display:flex; flex-wrap:wrap; gap:9px; justify-content:center; margin-top:8px }
.contact-chip  {
  padding:10px 18px; border-radius:50px;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.78); font-size:12.5px; backdrop-filter:blur(8px); transition:all .3s;
}
a.contact-chip:hover { background:rgba(255,255,255,.18); color:#fff }

/* ─────────────────────────────────────────────────────────────
   FOOTER
───────────────────────────────────────────────────────────── */
.site-footer { background:#07101A }
.footer-body {
  display:flex; flex-direction:column; gap:36px;
  padding:52px 20px 36px; max-width:1200px; margin:0 auto;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.footer-brand { margin-bottom:16px; align-items:center }
.footer-brand-logo {
  width:54px; height:54px; flex-shrink:0; object-fit:contain;
  border-radius:16px; padding:7px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 18px 40px rgba(0,0,0,.18);
}
.footer-brand .bw-mak { color:#E7F4FF }
.footer-brand .bw-studio { font-size:12px; letter-spacing:3px }
.footer-brand .bw-tag { color:#7F98AA; font-size:8px; letter-spacing:1.9px }
.footer-brand-col p { font-size:13px; color:#4A6A80; line-height:1.8; max-width:300px; margin-top:12px }
.footer-socials {
  display:flex; flex-wrap:wrap; gap:10px; margin-top:20px;
}
.footer-social-link {
  --social-accent: rgba(27,184,232,.6);
  width:42px; height:42px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(179,199,214,.55);
  transition:transform .3s ease, border-color .3s ease, background .3s ease, color .3s ease, box-shadow .3s ease;
}
.footer-social-link svg { width:17px; height:17px; flex-shrink:0; display:block }
.footer-social-link:hover {
  transform:translateY(-3px);
  border-color:var(--social-accent);
  background:rgba(255,255,255,.08);
  color:#fff;
  box-shadow:0 6px 18px rgba(0,0,0,.22), 0 0 10px var(--social-accent);
}
.footer-social-icon { display:none }
.footer-social-text { display:none }
.social-instagram { --social-accent: rgba(214,63,132,.65) }
.social-facebook  { --social-accent: rgba(70,132,255,.60) }
.social-threads   { --social-accent: rgba(150,150,150,.65) }
.social-linkedin  { --social-accent: rgba(0,127,177,.65) }
.social-tiktok    { --social-accent: rgba(52,220,195,.60) }
.social-youtube   { --social-accent: rgba(255,78,91,.65) }
.social-pinterest { --social-accent: rgba(227,59,89,.65) }
.social-x         { --social-accent: rgba(200,215,230,.45) }
.footer-links-area { display:grid; grid-template-columns:1fr; gap:24px }
.fc { display:flex; flex-direction:column }
.fc h4 {
  font-family:'Poppins',sans-serif; font-size:9px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase; margin-bottom:14px;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.fc a { font-size:13px; color:#4A6A80; margin-bottom:9px; transition:color .3s }
.fc a:hover { color:var(--cyan) }
.footer-bottom { background:#07101A }
.fb-grad-bar   { height:3px; background:var(--grad-rev) }
.fb-row { display:flex; flex-direction:column; align-items:center; gap:5px; padding:18px 20px; text-align:center; max-width:1200px; margin:0 auto }
.fb-row span   { font-size:11.5px; color:#38495A }
.fb-row strong { color:var(--cyan) }
.footer-credit-link {
  color:#DFF4FF;
  font-weight:700;
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.footer-credit-link:hover { opacity:.84 }

/* ─────────────────────────────────────────────────────────────
   STICKY MOBILE CTA
───────────────────────────────────────────────────────────── */
.sticky-cta {
  position:fixed; bottom:0; left:0; right:0; z-index:900;
  padding:10px 14px; padding-bottom:calc(10px + env(safe-area-inset-bottom));
  background:rgba(7,16,26,.96); backdrop-filter:blur(14px);
  border-top:1px solid rgba(27,184,232,.2);
  transform:translateY(100%); transition:transform .4s ease;
}
.sticky-cta.show { transform:translateY(0) }
.sticky-cta-btn {
  width:100%; padding:15px;
  background:var(--grad); color:#fff;
  font-family:'Poppins',sans-serif; font-size:14px; font-weight:700;
  border-radius:50px; border:none; cursor:pointer;
  box-shadow:0 6px 22px rgba(27,184,232,.38);
  display:flex; align-items:center; justify-content:center; gap:6px;
  transition:all .3s; letter-spacing:.4px;
}
.sticky-cta-btn:active { transform:scale(.98) }

/* ─────────────────────────────────────────────────────────────
   MODAL
───────────────────────────────────────────────────────────── */
.modal-overlay {
  position:fixed; inset:0;
  background:rgba(7,16,26,.88); backdrop-filter:blur(14px);
  z-index:2000; display:none; align-items:flex-end; justify-content:center;
}
.modal-overlay.open { display:flex }
.modal-panel {
  background:var(--card); width:100%; max-width:680px;
  max-height:93vh; overflow-y:auto;
  border-radius:28px 28px 0 0; position:relative;
  animation:panelUp .4s cubic-bezier(.4,0,.2,1);
  box-shadow:0 -20px 80px rgba(27,184,232,.18);
}
/* FIXED: was `transform:none scale(1)` — invalid. Use just translateY(0) */
@keyframes panelUp { from { transform:translateY(100%) } to { transform:translateY(0) } }
.modal-accent-bar  { height:5px; background:var(--grad); border-radius:28px 28px 0 0 }
.modal-close-btn {
  position:sticky; top:10px; float:right; margin:10px 14px 0 0;
  width:34px; height:34px; border-radius:50%;
  background:var(--bg-off); color:var(--muted); font-size:15px;
  display:flex; align-items:center; justify-content:center; z-index:5; transition:all .3s;
}
.modal-close-btn:hover { background:var(--grad); color:#fff }
.modal-header { padding:16px 22px 18px; border-bottom:1px solid var(--border); clear:both }
.modal-title  {
  font-family:'Poppins',sans-serif; font-size:clamp(20px,5vw,26px);
  font-weight:800; color:var(--text); margin:6px 0 8px;
}
.modal-pkg-tag {
  display:inline-block; padding:4px 13px; border-radius:50px;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  background-color:var(--bg-off); border:1px solid var(--border);
  font-family:'Poppins',sans-serif; font-size:11px; font-weight:700;
}
.modal-body { padding:18px 22px 32px }
.form-info-note {
  background:var(--grad-soft); border:1px solid rgba(27,184,232,.14); border-radius:var(--r);
  padding:12px 15px; font-size:12.5px; color:var(--textm); line-height:1.65; margin-bottom:22px;
}
.form-row { display:grid; grid-template-columns:1fr; gap:13px; margin-bottom:13px }
.form-field { display:flex; flex-direction:column; gap:5px }
.form-field label {
  font-size:8.5px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.form-field input, .form-field select, .form-field textarea {
  background:var(--bg-off); border:2px solid var(--border);
  border-radius:var(--r); color:var(--text);
  font-family:'DM Sans',sans-serif; font-size:14px;
  padding:13px 14px; outline:none; width:100%;
  transition:border-color .3s, box-shadow .3s;
  -webkit-appearance:none; appearance:none;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
  border-color:var(--cyan); box-shadow:0 0 0 3px rgba(27,184,232,.1); background:var(--card);
}
.form-field textarea { resize:vertical; min-height:96px }
.form-submit-btn {
  width:100%; padding:15px; background:var(--grad); color:#fff;
  font-family:'Poppins',sans-serif; font-size:14px; font-weight:700;
  border:none; border-radius:50px; cursor:pointer; box-shadow:var(--sh-blue); transition:all .3s;
}
.form-submit-btn:hover  { transform:translateY(-2px); box-shadow:var(--sh-pink) }
.form-submit-btn:active { transform:scale(.98) }
.form-submit-btn:disabled { opacity:.65; cursor:not-allowed; transform:none }

.success-wrap  { padding:44px 22px; text-align:center }
.success-emoji { font-size:56px; margin-bottom:14px }
.success-h2    {
  font-family:'Poppins',sans-serif; font-size:24px; font-weight:800; margin-bottom:12px;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.success-p { font-size:14px; color:var(--textm); line-height:1.8 }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — 580px+
═══════════════════════════════════════════════════════════ */
@media(min-width:580px) {
  .stats-grid { grid-template-columns:repeat(4,1fr) }
  .stat-item { border-right:1px solid var(--border) }
  .stat-item:last-child { border-right:0 }
  .svc-grid { grid-template-columns:repeat(2,1fr) }
  .team-grid { grid-template-columns:repeat(3,1fr) }
  .form-row { grid-template-columns:1fr 1fr }
  .gal-grid { grid-template-columns:repeat(3,1fr); grid-auto-rows:200px }
  .gi-lg    { grid-column:span 2 }
  .gi-tall  { grid-row:span 2 }
  .mv-row   { grid-template-columns:1fr 1fr }
  .mobile-swipe-hint { display:none }
  .pkg-scroll-wrap { overflow-x:visible }
  .pkg-row { min-width:auto; display:grid; grid-template-columns:repeat(2,1fr) }
  .pkg-card { flex:none }
  .event-pkg-row { grid-template-columns:repeat(2,minmax(0,1fr)) }
  .event-pkg-card.is-expanded { grid-column:1 / -1 }
  .event-pkg-detail-shell { grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr); gap:18px }
  .event-pkg-feats { column-count:2; column-gap:18px }
  .footer-links-area { grid-template-columns:repeat(2,minmax(0,1fr)) }
  .footer-links-area .fc:last-child { grid-column:1 / -1 }
  .ev-types-grid { grid-template-columns:repeat(4,1fr) }
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — 900px+
═══════════════════════════════════════════════════════════ */
@media(min-width:900px) {
  header { padding:20px 56px }
  header.scrolled { padding:12px 56px }
  .hamburger { display:none }
  .nav-desk { display:flex }
  .sticky-cta { display:none }
  .wrap { padding:0 56px }
  section { padding:96px 0 }

  .slide-layout { padding:110px 56px 90px; gap:48px }
  .slide-visual { display:flex }
  .scroll-hint-wrap { display:flex }

  .about-grid { grid-template-columns:1fr 1fr; gap:72px; margin-bottom:64px }
  .about-img-area { max-width:none; margin:0 }

  .svc-grid { grid-template-columns:repeat(3,1fr) }

  .events-intro { grid-template-columns:1fr 1fr; align-items:center }
  .ev-feat-grid { grid-template-columns:repeat(3,1fr) }

  .pkg-row { grid-template-columns:repeat(3,1fr) }
  .event-pkg-row { grid-template-columns:repeat(3,minmax(0,1fr)) }
  .event-pkg-card.is-expanded { grid-column:span 2 }
  .footer-links-area { grid-template-columns:repeat(3,minmax(0,1fr)) }
  .footer-links-area .fc:last-child { grid-column:auto }

  .sec-hdr-split { grid-template-columns:1fr 1fr; gap:60px; align-items:end; margin-bottom:32px }

  .gal-grid {
    grid-template-columns:repeat(4,1fr);
    grid-template-rows:280px 280px;
    gap:12px; padding:0 56px;
  }
  .gi-lg   { grid-column:span 2; grid-row:span 2 }
  .gi-tall { grid-row:span 2; grid-column:span 1 }

  .footer-body { flex-direction:row; gap:60px; padding:64px 56px 48px }
  .footer-brand-col { flex:0 0 250px }
  .footer-links-area { flex:1 }
  .fb-row { flex-direction:row; justify-content:space-between; padding:18px 56px }

  .modal-overlay { align-items:center; padding:20px }
  .modal-panel { border-radius:var(--rx); max-height:90vh }
  .modal-header { padding:32px 40px 22px }
  .modal-body   { padding:24px 40px 36px }
  .success-wrap { padding:52px 40px }
  @keyframes panelUp { from { opacity:0; transform:translateY(28px) scale(.97) } to { opacity:1; transform:translateY(0) } }

  .custom-pkg-banner { flex-direction:row; text-align:left; padding:44px 52px }
  .mv-row { grid-template-columns:1fr 1fr }
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — 1200px+
═══════════════════════════════════════════════════════════ */
@media(min-width:1200px) {
  .slide-visual { width:400px }
  .vis-a { width:240px; height:290px }
  .vis-b { width:145px; height:175px }
  .pkg-row { grid-template-columns:repeat(4,1fr) }
  .event-pkg-row { grid-template-columns:repeat(4,minmax(0,1fr)) }
  .event-pkg-card.is-expanded { grid-column:span 2 }
}

/* ═══════════════════════════════════════════════════════════
   ACCESSIBILITY & REDUCED MOTION
═══════════════════════════════════════════════════════════ */
@media(prefers-reduced-motion:reduce) {
  *, *::before, *::after {
    animation-duration:.001ms !important;
    transition-duration:.001ms !important;
  }
}
:focus-visible { outline:3px solid var(--cyan); outline-offset:3px; border-radius:4px }
@media(hover:none) {
  .svc-card:active  { transform:translateY(-4px); box-shadow:var(--sh-hover) }
  .btn-g:active     { transform:scale(.97) }
  .pkg-card:active  { transform:translateY(-4px) }
  .ac-card:active   { transform:translateY(-4px) }
}
