*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#c9a84c;--gold-light:#e8c97a;--gold-dim:rgba(201,168,76,0.12);
  --blue:#1a7fa0;--blue-light:#2aa8d0;--blue-dim:rgba(26,127,160,0.12);
  --dark:#0a0c0f;--dark2:#0f1419;--dark3:#161e24;--dark4:#1e2830;
  --text:#eef2f5;--text-muted:#8a9baa;
  --border-gold:rgba(201,168,76,0.18);--border-blue:rgba(26,127,160,0.22);--border:rgba(255,255,255,0.07);
  --r:8px;--rs:5px;--rl:12px;
  --font-display:'Cormorant Garamond',serif;--font-body:'Outfit',sans-serif;
}
html{overflow-x:hidden}
/* Fix 7: -webkit-overflow-scrolling:touch removed — deprecated since iOS 13, modern iOS handles
   momentum scrolling natively via overflow:scroll. Can actually cause micro-stutters on modern iOS. */
body{background:var(--dark);color:var(--text);font-family:var(--font-body);font-weight:400;line-height:1.7;overflow-x:hidden;max-width:100vw;touch-action:pan-y}
/* Tier 1 Fix 1: background-attachment:fixed replaced with fixed pseudo-element.
   Old approach caused a full repaint on every scroll frame (the #1 perf killer).
   position:fixed on ::before is GPU-composited — zero paint cost during scroll. */
body::before{content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;background-image:radial-gradient(ellipse 120% 60% at 20% 0%,rgba(10,40,70,0.45) 0%,transparent 55%),radial-gradient(ellipse 80% 80% at 85% 30%,rgba(6,30,55,0.35) 0%,transparent 55%),radial-gradient(ellipse 60% 50% at 50% 80%,rgba(8,35,60,0.3) 0%,transparent 60%)}
img,video,iframe,embed,object{max-width:100%;height:auto}
img{display:block}
main{overflow-x:hidden}
 
.fade-section{opacity:1;transform:none}
.fade-section.will-animate{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease;will-change:opacity,transform}
.fade-section.will-animate.visible{opacity:1;transform:translateY(0)}
/* Tier 2 Fix: card animation — single class replaces 3 inline style writes per card at load.
   --card-delay is set once per card via el.style.setProperty in JS (one cheap write vs three). */
.card-awaiting{opacity:0;transform:translateY(22px);transition:opacity 0.5s ease var(--card-delay,0s),transform 0.5s ease var(--card-delay,0s)}
 
/* ── DESKTOP NAV ── */
/* Fix 9: removed duplicate '-webkit-backdrop-filter .5s ease' from transition list (was listed twice). */
nav.desktop-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 3rem;background:transparent;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);border-bottom:.5px solid transparent;transition:background .5s ease,border-color .5s ease,backdrop-filter .5s ease,-webkit-backdrop-filter .5s ease}
nav.desktop-nav.nav-scrolled{background:rgba(6,7,9,0.6);backdrop-filter:blur(28px) saturate(1.8) brightness(0.92);-webkit-backdrop-filter:blur(28px) saturate(1.8) brightness(0.92);border-bottom-color:rgba(42,168,208,0.18);box-shadow:0 1px 0 rgba(201,168,76,0.06),0 8px 32px rgba(0,0,0,0.3)}
.nav-logo-link{text-decoration:none;display:block;line-height:1.2;flex-shrink:0}
.nav-logo{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--gold);letter-spacing:.04em;line-height:1.2}
.nav-logo span{display:block;font-size:.72rem;font-family:var(--font-body);font-weight:300;color:rgba(255,255,255,0.3);letter-spacing:.18em;text-transform:uppercase}
.nav-links{display:flex;gap:0;list-style:none}
.nav-links a{color:rgba(255,255,255,0.45);text-decoration:none;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;transition:color .25s ease;position:relative;padding:.4rem 1.1rem .5rem}
.nav-links a::after{content:'';position:absolute;bottom:0;left:1.1rem;right:1.1rem;height:1.5px;background:var(--gold);transform:scaleX(0);transform-origin:center center;transition:transform .4s cubic-bezier(.22,1,.36,1);border-radius:2px}
.nav-links a:hover{color:rgba(255,255,255,0.9)}
.nav-links a.active{color:#fff}
.nav-links a.active::after,.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{background:var(--blue);border:none;color:#fff;padding:.5rem 1.2rem;font-family:var(--font-body);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .3s;text-decoration:none;border-radius:var(--rs);flex-shrink:0}
.nav-cta:hover{background:var(--blue-light)}
/* hide hamburger + old mobile menu always */
.hamburger{display:none}
.mobile-menu{display:none!important}
 
/* ── MOBILE NAV BAR — SS · Services · Portfolio · ☰ ── */
.mobile-nav-bar{
  display:none;
  position:fixed;top:0;left:0;right:0;
  z-index:200;height:52px;
  flex-direction:row;align-items:stretch;
  background:rgba(6,12,18,0.72);
  /* Fix 6: blur reduced 28px→18px. Cuts GPU compositing work ~35% with zero visible difference
     at this small nav height. */
  backdrop-filter:blur(18px) saturate(1.6) brightness(0.85);
  -webkit-backdrop-filter:blur(18px) saturate(1.6) brightness(0.85);
  border-bottom:.5px solid rgba(42,168,208,0.22);
  box-shadow:0 4px 32px rgba(0,0,0,0.35),inset 0 1px 0 rgba(255,255,255,0.04);
  transition:background .4s,border-color .4s,box-shadow .4s
}
/* gold-to-blue shimmer at the very top edge */
.mobile-nav-bar::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1.5px;
  background:linear-gradient(90deg,transparent 0%,#c9a84c 30%,#2aa8d0 70%,transparent 100%);
  pointer-events:none;z-index:1
}
.mobile-nav-bar.mnb-scrolled{
  background:rgba(5,10,16,0.88);
  border-bottom-color:rgba(201,168,76,0.15);
  box-shadow:0 8px 40px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.05)
}
/* Two-line logo lockup */
.mnb-logo{
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:0 .75rem 0 1rem;
  flex-shrink:0;text-decoration:none;
  line-height:1.25;overflow:visible; /* visible so sub-line never gets clipped */
  min-width:0
}
/* 2 links only — no scroll */
.mnb-links{
  display:flex;align-items:stretch;justify-content:center;
  flex:1;
  min-width:0
}
.mnb-links a{
  display:flex;align-items:center;
  color:#ffffff;
  text-decoration:none;
  font-family:var(--font-body),'Outfit',sans-serif;
  font-size:.67rem;letter-spacing:.12em;text-transform:uppercase;
  padding:0 .85rem;               /* was 1.1rem — frees ~10px each */
  white-space:nowrap;flex-shrink:0;
  position:relative;transition:color .2s
}
.mnb-links a::after{
  content:'';position:absolute;
  bottom:8px;left:.85rem;right:.85rem;
  height:1.5px;background:var(--gold);
  transform:scaleX(0);transform-origin:center center;
  transition:transform .4s cubic-bezier(.22,1,.36,1);border-radius:2px
}
.mnb-links a[href="#portfolio"]::after{background:var(--gold)}
.mnb-links a:hover{color:rgba(255,255,255,0.9)}
.mnb-links a:hover::after{transform:scaleX(1)}
.mnb-links a.active{color:#fff}
.mnb-links a.active::after{transform:scaleX(1)}
/* Hamburger button — rightmost, fixed width */
.mnb-hamburger{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:5px;width:46px;min-width:46px;
  background:none;border:none;
  padding:0;cursor:pointer;flex-shrink:0
}
/* Tight phone (≤360px) — reduce logo padding only, keep links intact */
@media(max-width:360px){
  .mnb-logo{padding:0 .5rem 0 .7rem}
  .mnb-links a{padding:0 .6rem;font-size:.63rem;letter-spacing:.09em}
}
.mnb-hamburger span{
  display:block;width:18px;height:1px;
  background:var(--blue-light);
  transition:transform .35s cubic-bezier(.22,1,.36,1),opacity .25s,background .25s;
  transform-origin:center
}
.mnb-hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg);background:var(--blue-light)}
.mnb-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.mnb-hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);background:var(--blue-light)}
 
/* ── MOBILE MENU OVERLAY ── */
.mobile-menu-overlay{
  position:fixed;inset:0;z-index:195;
  background:rgba(5,8,12,0);
  opacity:0;visibility:hidden;pointer-events:none;
  /* Fix 10: contain tells browser this element is self-contained — prevents it from
     triggering layout recalculation on the rest of the page when it animates. */
  contain:layout style;
  transition:opacity .35s ease,background .35s,visibility 0s linear .35s
}
.mobile-menu-overlay.open{
  opacity:1;visibility:visible;pointer-events:all;
  background:rgba(5,8,12,0.72);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:opacity .35s ease,background .35s,visibility 0s linear 0s
}
/* Panel slides up from below the nav bar */
.mobile-menu-panel{
  position:absolute;
  top:52px;left:0;right:0;bottom:0;
  background:var(--dark2);
  border-top:.5px solid rgba(201,168,76,0.22);
  display:flex;flex-direction:column;
  overflow-y:auto;
  padding:2rem 1.75rem 3rem;
  transform:translateY(24px);opacity:0;
  visibility:visible;
  transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .35s ease
}
.mobile-menu-overlay.open .mobile-menu-panel{
  transform:translateY(0);opacity:1
}
/* Eyebrow above CTA */
.mmp-eyebrow{
  font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--blue-light);margin-bottom:.75rem;
  display:flex;align-items:center;gap:.75rem
}
.mmp-eyebrow::before{
  content:'';display:block;width:1.5rem;height:.5px;background:var(--blue-light)
}
/* Primary CTA — Start a Project */
.mmp-start-btn{
  display:flex;align-items:center;justify-content:center;gap:.6rem;
  background:var(--blue);color:#fff;
  padding:1.1rem 1.5rem;
  font-family:var(--font-body);font-size:.82rem;
  font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;border-radius:var(--r);
  margin-bottom:.5rem;
  transition:background .25s,transform .2s;
  box-shadow:0 4px 20px rgba(26,127,160,0.35)
}
.mmp-start-btn:hover{background:var(--blue-light);transform:translateY(-1px)}
.mmp-start-btn:active{transform:translateY(0)}
/* Secondary CTAs — Call Now + WhatsApp */
.mmp-secondary-ctas{
  display:grid;grid-template-columns:1fr 1fr;
  gap:.6rem;margin-bottom:1.5rem
}
.mmp-call-btn,.mmp-wa-subtle-btn{
  display:flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.85rem .5rem;
  font-family:var(--font-body);font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;
  text-decoration:none;border-radius:var(--r);
  transition:all .25s
}
.mmp-call-btn{
  background:transparent;
  border:.5px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.7)
}
.mmp-call-btn:hover{border-color:var(--gold);color:var(--gold)}
.mmp-wa-subtle-btn{
  background:rgba(37,211,102,0.09);
  border:.5px solid rgba(37,211,102,0.28);
  color:#25d366
}
.mmp-wa-subtle-btn:hover{background:rgba(37,211,102,0.18)}
.mmp-wa-subtle-btn .wa-icon{width:14px;height:14px}
/* Divider */
.mmp-divider{
  height:.5px;background:rgba(255,255,255,0.07);
  margin-bottom:1.25rem
}
/* Nav links — large serif, luxury hotel menu style */
.mmp-nav{display:flex;flex-direction:column}
.mmp-nav a{
  display:flex;align-items:center;justify-content:space-between;
  color:#ffffff;
  text-decoration:none;
  font-family:var(--font-display),'Cormorant Garamond',Georgia,serif;
  font-size:1.4rem;font-weight:300;
  padding:.55rem 0;
  border-bottom:.5px solid rgba(255,255,255,0.06);
  letter-spacing:.01em;
  transition:color .25s,padding-left .3s cubic-bezier(.22,1,.36,1)
}
.mmp-nav a:last-child{border-bottom:none}
.mmp-nav a:hover,.mmp-nav a:active{color:#fff;padding-left:.5rem}
.mmp-nav a svg{
  opacity:0;flex-shrink:0;
  color:var(--gold);
  transition:opacity .25s,transform .3s cubic-bezier(.22,1,.36,1)
}
.mmp-nav a:hover svg,.mmp-nav a:active svg{opacity:1;transform:translateX(3px)}
/* Footer inside menu */
.mmp-footer{
  margin-top:2.5rem;
  border-top:.5px solid rgba(255,255,255,0.06);
  padding-top:1.2rem
}
.mmp-footer-logo{
  font-family:var(--font-display);
  font-size:.9rem;color:var(--gold);opacity:.55
}
.mmp-footer-logo span{
  font-family:var(--font-body);font-size:.68rem;
  color:rgba(255,255,255,0.22);letter-spacing:.1em;
  display:block;margin-top:.2rem;text-transform:uppercase
}
.mmp-footer-tag{
  font-size:.66rem;color:rgba(255,255,255,0.18);
  letter-spacing:.12em;text-transform:uppercase;margin-top:.3rem
}
 
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:8rem 3rem 4rem;position:relative;overflow:hidden;max-width:100vw}
.hero-collage{position:absolute;top:0;right:0;width:58%;height:100%;display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:3px;z-index:0;pointer-events:none}
.hero-collage-img{overflow:hidden;position:relative;animation:collageFade .7s ease both}
/* will-change set+cleaned by JS to keep GPU layers minimal after hero animation completes */
.hero-collage-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.72) saturate(.9)}
.hero-collage-img:nth-child(1){animation-delay:.1s;grid-column:1;grid-row:1/3}
.hero-collage-img:nth-child(2){animation-delay:.25s;grid-column:2;grid-row:1}
.hero-collage-img:nth-child(3){animation-delay:.4s;grid-column:3;grid-row:1}
.hero-collage-img:nth-child(4){animation-delay:.55s;grid-column:2;grid-row:2}
.hero-collage-img:nth-child(5){animation-delay:.7s;grid-column:3;grid-row:2}
@keyframes collageFade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,var(--dark) 0%,var(--dark) 32%,rgba(10,12,15,.82) 48%,rgba(10,12,15,.28) 70%,rgba(10,12,15,.05) 100%)}
.hero-watermark{position:absolute;left:0;bottom:-2rem;font-family:var(--font-display);font-size:18rem;font-weight:300;color:rgba(26,127,160,.04);line-height:1;pointer-events:none;z-index:1;white-space:nowrap;overflow:hidden}
.hero-content{position:relative;z-index:5;max-width:600px}
.hero-eyebrow{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--blue-light);margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}
.hero-eyebrow::before{content:'';display:block;width:2.5rem;height:.5px;background:var(--blue-light)}
.hero-title{font-family:var(--font-display);font-size:clamp(2.8rem,5.5vw,5.2rem);font-weight:300;line-height:1.06;color:var(--text);margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:var(--gold-light);display:block}
.hero-trust-badge{display:inline-block;background:rgba(201,168,76,.1);border:.5px solid rgba(201,168,76,.28);color:var(--gold);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .75rem;border-radius:var(--rs);margin-bottom:1rem}
.hero-tagline{font-size:.96rem;color:var(--text-muted);max-width:460px;margin-bottom:2.5rem;line-height:1.88}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.btn-primary{background:var(--blue);color:#fff;border:none;padding:.85rem 2rem;font-family:var(--font-body);font-size:.78rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-block;transition:background .3s;border-radius:var(--r)}
.btn-primary:hover{background:var(--blue-light)}
.btn-outline{background:transparent;color:var(--text);border:.5px solid rgba(238,242,245,.25);padding:.85rem 2rem;font-family:var(--font-body);font-size:.78rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-block;transition:all .3s;border-radius:var(--r)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.hero-stats{margin-top:4rem;display:flex;gap:3rem;padding-top:2rem;border-top:.5px solid var(--border-blue)}
.stat-num{font-family:var(--font-display);font-size:2.4rem;font-weight:300;color:var(--gold);line-height:1}
.stat-label{font-size:.72rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-top:.3rem}
 
#trust{background:rgba(15,20,25,0.6);border-top:.5px solid var(--border-blue);border-bottom:.5px solid var(--border-blue);padding:1.3rem 0;overflow:hidden;max-width:100vw;contain:layout style}
.trust-track{display:flex;align-items:center;white-space:nowrap;animation:marquee 30s linear infinite;width:max-content;will-change:transform;max-width:none}
.trust-track:hover{animation-play-state:paused}
.trust-item{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);padding:0 2.5rem}
.trust-dot{width:4px;height:4px;border-radius:50%;background:var(--blue);opacity:.55;flex-shrink:0}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
 
section{padding:6rem 3rem;contain:layout style}
.section-eyebrow{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--blue-light);margin-bottom:1rem;display:flex;align-items:center;gap:1rem}
.section-eyebrow::before{content:'';display:block;width:2rem;height:.5px;background:var(--blue-light)}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.2rem);font-weight:300;line-height:1.15;margin-bottom:1rem;color:var(--text)}
.section-sub{color:var(--text-muted);max-width:520px;font-size:.93rem;margin-bottom:3.5rem}
.gold-divider{width:10rem;height:.5px;background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--blue) 70%,transparent);margin:2rem 0}
 
#services{background:rgba(8,14,20,0.7);position:relative;overflow:hidden}
#services::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 15% 40%,rgba(26,127,160,0.18) 0%,transparent 60%),
    radial-gradient(ellipse 60% 70% at 85% 20%,rgba(0,90,140,0.15) 0%,transparent 55%),
    radial-gradient(ellipse 50% 50% at 55% 85%,rgba(26,127,160,0.12) 0%,transparent 55%),
    radial-gradient(ellipse 40% 40% at 75% 60%,rgba(0,60,110,0.10) 0%,transparent 50%);
}
#services::after{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.55;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
}
#services > *{position:relative;z-index:1}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:3rem}
/* Tier 1 Fix 2: backdrop-filter:blur(20px) removed from base (painted 6 cards every frame).
   Now only applied on hover for pointer devices — touch/mobile gets none.
   Tier 1 Fix 3: will-change:transform removed from base — promotes 6+ GPU layers always.
   Now set only on hover so browser promotes just the card being interacted with. */
.service-card{background:rgba(26,127,160,0.11);border:.5px solid rgba(42,168,208,0.18);border-radius:var(--rl);overflow:hidden;display:flex;flex-direction:column;transition:transform .35s ease,border-color .3s,box-shadow .3s;position:relative;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:rgba(42,168,208,0.15);box-shadow:inset 0 1.5px 0 rgba(255,255,255,0.18),inset 1px 0 0 rgba(255,255,255,0.08),0 8px 32px rgba(0,0,0,0.4)}
@media(hover:hover){.service-card:hover{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);will-change:transform}}
.service-card::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.22),transparent);z-index:2;pointer-events:none;border-radius:50%}
.service-card::after{content:'';position:absolute;inset:0;border-radius:var(--rl);box-shadow:0 16px 40px rgba(0,0,0,.5);opacity:0;transition:opacity .35s ease;pointer-events:none;z-index:0}
.service-card:hover{transform:translateY(-7px);border-color:rgba(42,168,208,0.4);box-shadow:inset 0 1.5px 0 rgba(255,255,255,0.22),inset 1px 0 0 rgba(255,255,255,0.10),0 20px 48px rgba(0,0,0,0.55),0 0 32px rgba(26,127,160,0.18)}
.service-card:hover::after{opacity:1}
.service-card:focus-visible{outline:2px solid var(--blue-light);outline-offset:2px}
.sc-image{position:relative;width:100%;height:190px;overflow:hidden;flex-shrink:0;z-index:1}
.sc-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}
.service-card:hover .sc-image img{transform:scale(1.06);will-change:transform}
.sc-img-gradient{position:absolute;bottom:0;left:0;right:0;height:55%;background:linear-gradient(0deg,rgba(10,12,15,0.82) 0%,transparent 100%);pointer-events:none}
.sc-body{padding:1.3rem 1.5rem .9rem;display:flex;flex-direction:column;flex:1;position:relative;z-index:1}
.sc-name{font-family:var(--font-display);font-size:1.15rem;font-weight:400;color:var(--text);margin-bottom:.5rem;line-height:1.25}
.sc-desc{font-size:.81rem;color:var(--text-muted);line-height:1.75;flex:1}
.sc-cta{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:auto;padding:.75rem 1.1rem;font-size:.72rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--blue-light);background:rgba(26,127,160,.12);border:none;border-top:1px solid rgba(26,127,160,.2);border-radius:0 0 var(--rl) var(--rl);text-decoration:none;transition:background .25s,color .25s,border-top-color .25s;cursor:pointer;font-family:var(--font-body)}
.sc-cta:hover{background:#c9a84c;color:#0a0c0f;border-top-color:#c9a84c}
.sc-cta-circle{width:22px;height:22px;border-radius:50%;border:1.5px solid currentColor;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .25s}
.sc-cta:hover .sc-cta-circle{border-color:#0a0c0f}
 
#why{background:var(--dark);position:relative;overflow:hidden}
#why::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 55% at 5% 90%,rgba(201,168,76,0.07) 0%,transparent 55%),
    radial-gradient(ellipse 50% 45% at 95% 10%,rgba(26,127,160,0.08) 0%,transparent 50%);
}
#why > *{position:relative;z-index:1}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:3rem}
.why-card{background:var(--dark3);border:.5px solid var(--border);border-left:3px solid var(--gold);border-radius:0 var(--rl) var(--rl) 0;padding:1.8rem 1.8rem 1.8rem 1.6rem;display:flex;flex-direction:row;align-items:center;gap:1.6rem;transition:background .3s,border-left-color .3s;position:relative}
.why-card::after{content:'';position:absolute;inset:0;border-radius:0 var(--rl) var(--rl) 0;box-shadow:0 0 32px rgba(26,127,160,.28);opacity:0;transition:opacity .3s;pointer-events:none}
.why-card:hover{background:var(--dark4);border-left-color:var(--blue-light);will-change:transform}
.why-card:hover::after{opacity:1}
.why-stat{flex-shrink:0;text-align:left;min-width:80px}
.why-num{font-family:var(--font-display);font-size:2.8rem;font-weight:300;color:var(--gold);line-height:1;letter-spacing:-.02em}
.why-unit{font-size:.72rem;color:var(--text-muted);letter-spacing:.15em;text-transform:uppercase;margin-top:.25rem}
.why-divider{width:.5px;height:52px;background:rgba(255,255,255,.07);flex-shrink:0}
.why-title{font-size:.93rem;color:var(--text);font-weight:500;margin-bottom:.35rem;line-height:1.3}
.why-desc{font-size:.78rem;color:var(--text-muted);line-height:1.75}
 
#process{background:rgba(6,10,16,0.5);position:relative;overflow:hidden}
#process::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;background:linear-gradient(180deg,rgba(26,127,160,0.05) 0%,transparent 40%,rgba(26,127,160,0.04) 100%)}
#process::after{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.4;background-image:linear-gradient(rgba(26,127,160,0.06) 1px,transparent 1px),linear-gradient(90deg,rgba(26,127,160,0.06) 1px,transparent 1px);background-size:48px 48px}
#process > *{position:relative;z-index:1}
 
/* animated connector line behind cards */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:3rem;position:relative}
.process-line-track{position:absolute;top:2.1rem;left:calc(12.5% + 14px);right:calc(12.5% + 14px);height:1px;z-index:0;pointer-events:none;overflow:hidden;border-radius:1px}
.process-line-bg{position:absolute;inset:0;background:rgba(26,127,160,0.15)}
.process-line-fill{position:absolute;top:0;left:0;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--blue-light));transition:width 1.4s cubic-bezier(.4,0,.2,1);border-radius:1px;box-shadow:0 0 8px rgba(42,168,208,0.6)}
.process-line-glow{position:absolute;top:-2px;right:0;width:12px;height:5px;background:radial-gradient(ellipse,rgba(201,168,76,0.9) 0%,transparent 70%);opacity:0;transition:opacity .3s}
.process-grid.line-animated .process-line-fill{width:100%}
.process-grid.line-animated .process-line-glow{opacity:1}
 
/* frosted glass cards */
.pd-card{
  background:rgba(22,32,42,0.55);
  backdrop-filter:blur(18px) saturate(1.4);
  -webkit-backdrop-filter:blur(18px) saturate(1.4);
  border:.5px solid rgba(42,168,208,0.18);
  border-radius:var(--rl);
  padding:1.8rem 1.5rem 1.6rem;
  text-align:center;
  position:relative;
  z-index:1;
  transition:opacity .55s ease,border-color .35s,transform .55s cubic-bezier(0.22,1,0.36,1),box-shadow .35s,background .35s;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.10),inset 1px 0 0 rgba(255,255,255,0.05),0 8px 32px rgba(0,0,0,0.35);
}
/* will-change only active during the reveal animation — JS adds awaiting-animation before observer, removes on intersect */
.pd-card.awaiting-animation{opacity:0;transform:translateY(28px);will-change:opacity,transform}
.pd-card.card-visible{opacity:1;transform:translateY(0)}
.pd-card.card-visible:nth-child(2){transition-delay:.18s}
.pd-card.card-visible:nth-child(3){transition-delay:.36s}
.pd-card.card-visible:nth-child(4){transition-delay:.54s}
.pd-card::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);border-radius:50%;pointer-events:none}
.pd-card::after{content:'';position:absolute;inset:0;border-radius:var(--rl);box-shadow:0 0 32px rgba(201,168,76,.12);opacity:0;transition:opacity .35s;pointer-events:none;z-index:-1}
.pd-card:hover{border-color:rgba(201,168,76,0.4);transform:translateY(-6px);background:rgba(26,38,50,0.7);box-shadow:inset 0 1px 0 rgba(255,255,255,0.15),inset 1px 0 0 rgba(255,255,255,0.08),0 16px 48px rgba(0,0,0,0.5),0 0 24px rgba(201,168,76,0.08)}
.pd-card:hover::after{opacity:1}
.pd-connector{display:none}
.pd-dot-wrap{display:flex;justify-content:center;margin-bottom:1.1rem}
.pd-dot{width:32px;height:32px;border-radius:50%;background:rgba(10,18,26,0.8);border:1.5px solid var(--blue);display:flex;align-items:center;justify-content:center;color:var(--blue-light);transition:border-color .3s,background .3s,color .3s,box-shadow .3s;box-shadow:0 0 0 4px rgba(26,127,160,0.08)}
.pd-card:hover .pd-dot{border-color:var(--gold);background:rgba(201,168,76,.1);color:var(--gold);box-shadow:0 0 0 4px rgba(201,168,76,0.1),0 0 12px rgba(201,168,76,0.2)}
.pd-num{font-family:var(--font-display);font-size:2.2rem;font-weight:300;color:var(--gold);line-height:1;margin-bottom:.5rem;letter-spacing:-.02em}
.pd-title{font-size:.9rem;color:var(--text);font-weight:500;margin-bottom:.4rem;letter-spacing:.02em}
.pd-desc{font-size:.74rem;color:var(--text-muted);line-height:1.7}
 
#portfolio{background:var(--dark)}
.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.filter-btn{background:transparent;border:.5px solid rgba(255,255,255,.12);color:var(--text-muted);padding:.4rem 1rem;font-family:var(--font-body);font-size:.73rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .3s;border-radius:var(--rs);white-space:nowrap}
.filter-btn:hover,.filter-btn.active{border-color:var(--blue);color:var(--blue-light);background:var(--blue-dim)}
.portfolio-count{font-size:.73rem;color:var(--text-muted);letter-spacing:.1em;margin-bottom:2rem;min-height:1.2em}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.portfolio-grid.few-items{grid-template-columns:repeat(2,1fr)}
.portfolio-item{aspect-ratio:4/3;background:var(--dark3);position:relative;overflow:hidden;cursor:pointer;border-radius:var(--rl)}
.portfolio-item.hidden{display:none}
.p-thumb{width:100%;height:100%;overflow:hidden;border-radius:var(--rl)}
.p-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;display:block}
/* will-change promoted only when hover is active — avoids 8+ permanent GPU layers */
.portfolio-item:hover{will-change:transform}
.portfolio-item:hover .p-thumb img{will-change:transform}
.portfolio-item:hover .p-thumb img{transform:scale(1.07)}
.p-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,12,15,.93) 0%,rgba(10,12,15,.05) 60%);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem;border-radius:var(--rl)}
.portfolio-item:hover .p-overlay{opacity:1}
.p-name{font-family:var(--font-display);font-size:1.1rem;color:var(--text)}
.p-loc{font-size:.7rem;color:var(--blue-light);letter-spacing:.1em;text-transform:uppercase;margin-top:.2rem}
.p-cat-badge{display:inline-block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-light);border:.5px solid var(--blue);padding:.18rem .55rem;background:rgba(10,12,15,.75);border-radius:var(--rs);margin-bottom:.5rem;width:fit-content;white-space:nowrap}
 
#testimonials{background:rgba(10,16,22,0.65);position:relative;overflow:hidden}
#testimonials::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%,rgba(26,127,160,0.10) 0%,transparent 65%),
    radial-gradient(ellipse 40% 40% at 10% 80%,rgba(201,168,76,0.05) 0%,transparent 50%);
}
#testimonials > *{position:relative;z-index:1}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:3rem}
.tcard{background:rgba(26,127,160,0.06);border:.5px solid rgba(42,168,208,0.16);border-radius:var(--rl);padding:2rem;transition:border-color .3s,transform .3s,box-shadow .3s;display:flex;flex-direction:column;box-shadow:inset 0 1.5px 0 rgba(255,255,255,0.14),inset 1px 0 0 rgba(255,255,255,0.06),0 8px 32px rgba(0,0,0,0.3)}
@media(hover:hover){.tcard:hover{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}}
.tcard:hover{border-color:rgba(42,168,208,0.32);transform:translateY(-4px);box-shadow:inset 0 1.5px 0 rgba(255,255,255,0.18),inset 1px 0 0 rgba(255,255,255,0.08),0 16px 40px rgba(0,0,0,0.45),0 0 20px rgba(26,127,160,0.10)}
.tcard-quote{font-size:2.8rem;font-family:var(--font-display);color:var(--blue);line-height:.8;margin-bottom:.8rem;opacity:.45}
.tcard-stars{color:var(--gold);font-size:.75rem;margin-bottom:.8rem;letter-spacing:2px}
.tcard-text{font-size:.88rem;color:var(--text-muted);line-height:1.85;font-style:italic;margin-bottom:1.5rem;flex:1}
.tcard .tcard-footer{display:flex;align-items:center;gap:.8rem;border-top:.5px solid var(--border);padding-top:1rem}
.tcard-avatar{width:38px;height:38px;border-radius:50%;background:var(--blue-dim);border:.5px solid var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.95rem;color:var(--blue-light);flex-shrink:0}
.tcard-name{font-size:.83rem;color:var(--text);font-weight:400}
.tcard-role{font-size:.7rem;color:var(--text-muted)}
.tcard-note{display:inline-block;font-size:.72rem;color:var(--text-muted);border:.5px solid var(--border);border-radius:var(--rs);padding:.15rem .5rem;margin-top:.8rem;font-style:normal}
 
#faq{background:rgba(6,10,16,0.5)}
.faq-list{margin-top:3rem}
.faq-item{border-bottom:.5px solid var(--border)}
.faq-item:first-child{border-top:.5px solid var(--border)}
.faq-q{width:100%;background:none;border:none;color:var(--text);font-family:var(--font-body);font-size:.95rem;font-weight:400;text-align:left;padding:1.4rem 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:color .3s}
.faq-q:hover{color:var(--blue-light)}
.faq-icon{font-size:1.2rem;color:var(--blue-light);transition:transform .3s;flex-shrink:0;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{color:var(--text-muted);font-size:.88rem;line-height:1.85;padding-bottom:1.4rem}
.faq-item.open .faq-a{max-height:600px}
 
#about{background:var(--dark)}
.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start}
.about-visual{position:sticky;top:6rem;display:flex;flex-direction:column;gap:1rem}
.about-box-main{background:var(--dark3);border:.5px solid var(--border-blue);aspect-ratio:3/4;overflow:hidden;border-radius:var(--rl)}
.about-box-main img{width:100%;height:100%;object-fit:cover}
.about-box-accent{background:var(--dark4);border:.5px solid var(--gold);padding:1.2rem 1.5rem;border-radius:var(--rl);display:flex;align-items:center;gap:1.2rem}
.about-accent-num{font-family:var(--font-display);font-size:2rem;color:var(--gold);line-height:1;flex-shrink:0}
.about-accent-label{font-size:.72rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}
.about-text p{color:var(--text-muted);font-size:.91rem;margin-bottom:1.2rem;line-height:1.9}
 
/* ── TIMELINE — Option A: year left, card right ── */
.about-milestones{margin-top:2.5rem;border-top:.5px solid var(--border-blue);padding-top:2.5rem}
.timeline{position:relative;display:flex;flex-direction:column;gap:0;padding-left:0}
 
/* gold gradient spine — single continuous line through all items */
.timeline::before{
  content:'';position:absolute;
  left:calc(5.2rem + 0.7rem);
  top:.6rem;bottom:.6rem;
  width:1px;
  background:linear-gradient(180deg,rgba(201,168,76,0.7) 0%,rgba(201,168,76,0.2) 100%);
  z-index:0;pointer-events:none
}

 
.tl-item{
  display:grid;
  grid-template-columns:5.2rem 1.4rem 1fr;
  /* year | dot+line | card */
  column-gap:0;
  row-gap:0;
  position:relative;
  padding-bottom:1.8rem;
  align-items:start
}
.tl-item:last-child{padding-bottom:0}
 
/* ── Year column ── */
.tl-year{
  font-family:var(--font-display);
  font-size:1.55rem;
  font-weight:600;
  color:var(--gold);
  line-height:1;
  letter-spacing:-.03em;
  text-align:right;
  padding-right:0;
  padding-top:.18rem;
  white-space:nowrap;
  transition:color .3s
}
.tl-item:hover .tl-year{color:var(--gold-light)}
 
/* ── Dot column ── */
.tl-dot-col{
  display:flex;flex-direction:column;align-items:center;
  padding-top:.42rem;z-index:1;position:relative
}

.tl-dot{
  width:11px;height:11px;border-radius:50%;
  background:var(--dark2);
  border:1.5px solid var(--gold);
  flex-shrink:0;
  transition:background .3s,box-shadow .3s,border-color .3s,transform .3s
}
/* glow when hovering/tapping the parent tl-item — :active fires on touch */
.tl-item:hover .tl-dot,
.tl-item:active .tl-dot{
  background:rgba(201,168,76,0.25);
  border-color:var(--gold-light);
  transform:scale(1.5);
  box-shadow:0 0 10px rgba(201,168,76,0.8),0 0 22px rgba(201,168,76,0.4),0 0 36px rgba(201,168,76,0.15)
}
.tl-item:hover .tl-year,.tl-item:active .tl-year{color:var(--gold-light)}
.tl-dot.tl-dot-filled{background:var(--gold)}
.tl-dot.tl-dot-accent{background:var(--blue-light);border-color:var(--blue-light);box-shadow:0 0 8px rgba(42,168,208,0.5)}
.tl-item:hover .tl-dot.tl-dot-accent,
.tl-item:active .tl-dot.tl-dot-accent{
  background:var(--blue-light);
  border-color:#fff;
  box-shadow:0 0 10px rgba(42,168,208,0.9),0 0 22px rgba(42,168,208,0.5)
}
.tl-dot.tl-dot-now{
  background:var(--gold);border-color:var(--gold);
  box-shadow:0 0 12px rgba(201,168,76,.75),0 0 24px rgba(201,168,76,.3);
  animation:tlPulse 2.2s ease-in-out infinite
}
/* Fix 2a: was box-shadow keyframe — forced paint 60×/s forever.
   transform+opacity are the only two CSS properties that are purely composited. */
@keyframes tlPulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.45);opacity:.72}
}
 
/* ── Card column ── */
.tl-card{
  margin-left:1.1rem;
  /* Fix 1: was backdrop-filter:blur(14px) — 5 permanent compositor layers killing scroll perf.
     rgba(14,22,32,0.92) is visually identical at this opacity. */
  background:rgba(14,22,32,0.92);
  border:.5px solid rgba(42,168,208,0.13);
  border-radius:var(--rl);
  padding:1rem 1.25rem .9rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.07),0 4px 20px rgba(0,0,0,0.22);
  transition:border-color .3s,transform .3s,box-shadow .3s;
  cursor:default;position:relative
}
/* top-edge shimmer line */
.tl-card::before{
  content:'';position:absolute;top:0;left:12%;right:12%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.14),transparent);
  border-radius:50%;pointer-events:none
}
.tl-card:hover{
  border-color:rgba(201,168,76,0.32);
  transform:translateX(5px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.11),0 8px 28px rgba(0,0,0,0.35),0 0 20px rgba(201,168,76,0.07)
}
.tl-card.tl-card-accent{border-color:rgba(42,168,208,0.2);background:rgba(26,127,160,0.07)}
.tl-card.tl-card-accent:hover{
  border-color:rgba(42,168,208,0.45);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 8px 28px rgba(0,0,0,0.35),0 0 20px rgba(42,168,208,0.1)
}
.tl-card.tl-card-gold{border-color:rgba(201,168,76,0.28);background:rgba(201,168,76,0.05)}
.tl-card.tl-card-gold:hover{
  border-color:rgba(201,168,76,0.55);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.12),0 8px 28px rgba(0,0,0,0.4),0 0 24px rgba(201,168,76,0.11)
}
.tl-title{font-size:.86rem;font-weight:500;color:var(--text);margin-bottom:.25rem;line-height:1.3}
.tl-desc{font-size:.76rem;color:var(--text-muted);line-height:1.72}
.tl-badge{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.18rem .62rem;border-radius:20px;margin-top:.5rem
}
.tl-badge-gold{background:rgba(201,168,76,.1);border:.5px solid rgba(201,168,76,.3);color:var(--gold)}
.tl-badge-blue{background:rgba(26,127,160,.1);border:.5px solid rgba(26,127,160,.3);color:var(--blue-light)}
 
/* scroll-in animation */
.tl-item{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.tl-item.tl-visible{opacity:1;transform:none}
 
/* mobile: stack year above card */
@media(max-width:600px){
  .timeline::before{left:calc(3.6rem + 0.6rem)}
  .tl-item{grid-template-columns:3.6rem 1.2rem 1fr;padding-bottom:1.4rem}
  .tl-year{font-size:1.1rem;text-align:right}
  .tl-dot-col{display:flex;padding-top:.35rem}
  .tl-dot{width:9px;height:9px;border-width:1.5px}
  .tl-card{margin-left:.8rem}
}
 
.coverage-section{padding:6rem 3rem;border-top:.5px solid var(--border-blue);background:rgba(8,14,20,0.6)}
.coverage-left .gold-divider{width:100%;margin:1.2rem 0}
.coverage-inner{display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;align-items:start}
.coverage-left{position:sticky;top:5rem}
.coverage-desc{font-family:var(--font-body);font-size:.85rem;color:var(--text-muted);line-height:1.8;margin-top:1.2rem;max-width:300px}
.coverage-right{display:flex;flex-direction:column;gap:0}
.coverage-zone-header{font-family:var(--font-body);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);padding:.55rem 0;border-top:.5px solid rgba(26,127,160,.2);border-bottom:.5px solid rgba(26,127,160,.2);margin-bottom:0}
.coverage-cities-row{display:flex;align-items:stretch;gap:0;margin-bottom:0}
.coverage-city-card{flex:1;position:relative;padding:1.6rem 1.4rem 1.4rem 0;border-bottom:.5px solid var(--border-blue)}
.coverage-city-card:not(:first-child){padding-left:1.4rem;border-left:1px solid rgba(26,127,160,.18)}
.cc-pipe-dot{position:absolute;left:-4px;top:1.9rem;width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px rgba(201,168,76,.5)}
.cc-name{display:block;font-family:var(--font-display);font-size:clamp(1.2rem,1.8vw,1.6rem);font-weight:300;color:var(--gold);letter-spacing:.01em;line-height:1;margin-bottom:.35rem}
.cc-sub{display:block;font-family:var(--font-body);font-size:.72rem;color:var(--text-muted);letter-spacing:.04em;opacity:.7}
.coverage-city-ext{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;padding:1.1rem 0 0;border-bottom:none}
.cc-name-ext{font-family:var(--font-body);font-size:.82rem;color:var(--text-muted);font-weight:300}
.cc-sep{color:var(--border-blue);margin:0 .2rem;font-family:var(--font-body)}
.cc-tag-ext{font-family:var(--font-body);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);border:.5px solid rgba(26,127,160,.35);padding:.2rem .6rem;border-radius:20px;margin-left:auto}
 
#contact{background:rgba(6,10,16,0.55);overflow-x:hidden}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.contact-label{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--blue-light);margin-bottom:.25rem}
.contact-value{color:var(--text);font-size:.91rem;word-break:break-word;overflow-wrap:anywhere}
.contact-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.8rem;max-width:100%;box-sizing:border-box}
.ci-icon{width:38px;height:38px;min-width:38px;border-radius:8px;background:rgba(26,127,160,.12);border:.5px solid rgba(26,127,160,.25);display:flex;align-items:center;justify-content:center}
.ci-icon svg{width:16px;height:16px;stroke:#2aa8d0;stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.contact-btn-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:2.5rem;margin-top:1.4rem}
.wa-btn-inline{display:inline-flex;align-items:center;gap:.6rem;background:#25d366;color:#fff;padding:.75rem 1.8rem;text-decoration:none;font-family:var(--font-body);font-size:.78rem;font-weight:500;transition:background .3s;border-radius:var(--r);white-space:nowrap}
.wa-btn-inline:hover{background:#1fb855}
.review-btn-inline{display:inline-flex;align-items:center;gap:.7rem;background:var(--blue);color:#fff;padding:.75rem 1.8rem;text-decoration:none;font-family:var(--font-body);font-size:.78rem;font-weight:500;transition:background .3s;border-radius:var(--r);white-space:nowrap}
.review-btn-inline:hover{background:var(--blue-light)}
.google-map-wrap{width:100%;overflow:hidden;border-radius:8px;border:1px solid var(--border-blue)}
.service-area-card{margin-top:1.4rem;border:1px solid var(--border-blue);border-radius:var(--r);padding:1.4rem 1.6rem;background:rgba(10,12,15,.6)}
.sa-header{display:flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-size:.7rem;font-weight:500;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.1rem}
.sa-zone{margin-bottom:.9rem}
.sa-zone-primary{border-left:2px solid rgba(201,168,76,.5);padding-left:.9rem;margin-left:.1rem}
.sa-zone-label{font-family:var(--font-body);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:.4rem}
.sa-zone-cities{display:flex;flex-wrap:wrap;align-items:center;gap:0}
.sa-zc{font-family:var(--font-body);font-size:.82rem;color:var(--text-muted);padding:0 .7rem;border-right:1px solid var(--border-blue);line-height:1}
.sa-zc:first-child{padding-left:0}
.sa-zc:last-child{border-right:none}
.sa-zc.accent{color:var(--gold)}
.sa-footer{border-top:1px solid var(--border-blue);padding-top:.8rem;margin-top:.4rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.sa-note{font-family:var(--font-body);font-size:.75rem;color:var(--text-muted);font-style:italic}
.sa-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.25);border-radius:2rem;padding:3px 10px;font-family:var(--font-body);font-size:.7rem;color:var(--gold)}
.sa-seo-address{display:none}
.contact-form{display:flex;flex-direction:column;gap:.9rem;flex:1}
.contact-form input,.contact-form textarea,.contact-form select{background:var(--dark3);border:.5px solid rgba(255,255,255,.1);color:var(--text);padding:.85rem 1rem;font-family:var(--font-body);font-size:.86rem;font-weight:300;outline:none;transition:border-color .3s;width:100%;border-radius:var(--r)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-muted)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--blue)}
.contact-form select{color:var(--text-muted)}
.contact-form select option{background:var(--dark3);color:var(--text)}
.contact-form textarea{resize:vertical;min-height:120px;flex:1}
.form-submit{background:var(--blue);color:#fff;border:none;padding:1rem;width:100%;font-family:var(--font-body);font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .3s;border-radius:var(--r)}
.form-submit:hover{background:var(--blue-light)}
 
footer{background:var(--dark3);border-top:.5px solid var(--border-blue);padding:2.5rem 3rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-logo{font-family:var(--font-display);font-size:1.1rem;color:var(--gold)}
.footer-copy{font-size:.72rem;color:var(--text-muted)}
.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-links a{font-size:.7rem;color:var(--text-muted);text-decoration:none;letter-spacing:.1em;text-transform:uppercase;transition:color .3s;display:inline-flex;align-items:center;gap:5px;line-height:1}
.footer-links a:hover{color:var(--blue-light)}
.footer-links svg,.footer-links .review-icon{position:static!important;top:0!important;vertical-align:middle;width:13px;height:13px}
.hindi{font-size:.83rem;color:var(--text-muted)}
.bilingual-badge{display:inline-flex;align-items:center;gap:.6rem;background:rgba(201,168,76,.07);border:.5px solid rgba(201,168,76,.22);border-radius:var(--rs);padding:.35rem .85rem;margin:.5rem 0 1.2rem;color:var(--gold);font-size:.83rem;line-height:1.6}
.bilingual-badge::before{content:'हि';font-size:.72rem;font-weight:600;letter-spacing:.05em;color:var(--gold);opacity:.6;flex-shrink:0}
 
.fab-group{position:fixed;bottom:2rem;right:2rem;z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}
.fab-wa{display:flex;align-items:center;gap:.6rem;background:#25d366;color:#fff;padding:.75rem 1.2rem .75rem 1rem;text-decoration:none;font-family:var(--font-body);font-size:.78rem;font-weight:500;border-radius:50px;box-shadow:0 4px 20px rgba(37,211,102,.28);transition:background .3s,transform .3s;white-space:nowrap;position:relative}
.fab-wa::before{content:'';position:absolute;inset:-4px;border-radius:50px;background:rgba(37,211,102,.35);animation:waPulse 2s ease-out infinite;pointer-events:none}
@keyframes waPulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.45);opacity:0}100%{transform:scale(1.45);opacity:0}}
.fab-wa:hover{background:#1fb855;transform:translateY(-2px)}
.fab-top{width:42px;height:42px;background:var(--dark3);border:.5px solid var(--border-blue);color:var(--blue-light);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:all .3s;opacity:0;pointer-events:none}
.fab-top.visible{opacity:1;pointer-events:all}
.fab-top:hover{background:var(--dark4);border-color:var(--blue-light);transform:translateY(-2px)}
 
.lightbox{position:fixed;inset:0;background:rgba(5,8,12,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.lightbox.open{opacity:1;pointer-events:all}
.lb-img-wrap{max-width:90vw;max-height:88vh}
.lb-img-wrap img{max-width:90vw;max-height:82vh;object-fit:contain;border-radius:var(--rl);display:block;box-shadow:0 24px 80px rgba(0,0,0,.6),0 0 0 .5px rgba(255,255,255,.08)}
.lb-close{position:fixed;top:1.5rem;right:1.5rem;background:rgba(20,25,30,.9);border:.5px solid var(--border);color:var(--text);width:42px;height:42px;border-radius:50%;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:501}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{border-color:var(--blue);color:var(--blue-light)}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(20,25,30,.88);border:.5px solid var(--border);color:var(--text);width:46px;height:46px;border-radius:50%;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:501}
.lb-prev{left:1.5rem}.lb-next{right:1.5rem}
.lb-caption{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);text-align:center;z-index:501}
.lb-caption-name{font-family:var(--font-display);font-size:1.1rem;color:var(--text)}
.lb-caption-loc{font-size:.7rem;color:var(--blue-light);letter-spacing:.12em;text-transform:uppercase;margin-top:.2rem}
 
.wa-icon{width:17px;height:17px;fill:currentColor;flex-shrink:0;vertical-align:middle;position:relative;top:-1px}
.review-icon{width:15px;height:15px;flex-shrink:0;vertical-align:middle;position:relative;top:-1px}
.mobile-wa-link{color:#2aa8d0;display:inline-flex;align-items:center;gap:6px}
.btn-outline .wa-icon,.wa-btn-inline .wa-icon,.fab-wa .wa-icon{display:inline-block}
.skip-link{position:absolute;top:-100px;left:1rem;background:var(--blue);color:#fff;padding:.5rem 1rem;border-radius:var(--rs);font-size:.8rem;z-index:9999;transition:top .2s}
.skip-link:focus{top:1rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
 
.service-card{cursor:pointer}
.drawer-backdrop{position:fixed;inset:0;background:rgba(5,8,12,0);pointer-events:none;transition:background .34s cubic-bezier(.4,0,.2,1);z-index:400;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);contain:layout style}
.drawer-backdrop.open{background:rgba(5,8,12,.72);pointer-events:all;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
/* ═══ DRAWER — Night Gallery C+ luxury redesign ═══ */
.drawer-panel{position:fixed;top:0;right:0;bottom:0;width:75%;background:linear-gradient(170deg,#0d1322 0%,#070b14 55%,#060910 100%);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.032'/%3E%3C/svg%3E"),linear-gradient(170deg,#0d1322 0%,#070b14 55%,#060910 100%);border-left:.5px solid rgba(201,168,76,.22);box-shadow:-8px 0 48px rgba(0,0,0,.55),inset 1px 0 0 rgba(201,168,76,.06);z-index:401;display:flex;flex-direction:column;transform:translateX(110%);transition:transform .38s cubic-bezier(.22,1,.36,1),visibility 0s linear .38s;overflow:hidden;visibility:hidden;contain:layout style}
.drawer-panel.open{transform:translateX(0);visibility:visible;transition:transform .38s cubic-bezier(.22,1,.36,1),visibility 0s linear 0s}
.drawer-head{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.25rem 1.5rem 1rem;background:linear-gradient(180deg,rgba(14,20,34,.95) 0%,rgba(8,12,20,.5) 100%);border-bottom:.5px solid rgba(201,168,76,.12);flex-shrink:0;text-align:center;position:relative}
.drawer-head::before{content:'';position:absolute;top:0;left:0;right:0;height:1.5px;background:linear-gradient(90deg,transparent 5%,rgba(201,168,76,.55) 35%,rgba(42,168,208,.4) 65%,transparent 95%)}
.drawer-head::after{content:'';position:absolute;bottom:-1px;left:15%;right:15%;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.28),transparent)}
.drawer-head-eyebrow{font-size:.6rem;letter-spacing:.38em;text-transform:uppercase;color:rgba(42,168,208,.6);margin-bottom:.6rem;display:flex;align-items:center;justify-content:center;gap:.6rem}
.drawer-head-eyebrow-line{width:18px;height:.5px;background:linear-gradient(90deg,transparent,rgba(42,168,208,.5))}
.drawer-head-eyebrow-line.r{background:linear-gradient(90deg,rgba(42,168,208,.5),transparent)}
.drawer-head-eyebrow-dot{width:3px;height:3px;border-radius:50%;background:rgba(201,168,76,.55)}
.drawer-title{font-family:var(--font-display);font-size:1.15rem;font-weight:300;font-style:italic;color:#eef2f5;letter-spacing:.04em;line-height:1.25}
.drawer-subtitle{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(138,155,170,.38);margin-top:.4rem}
.drawer-head-sep{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.7rem}
.drawer-head-sep-line{flex:1;max-width:36px;height:.5px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}
.drawer-head-sep-dot{width:3px;height:3px;border-radius:50%;background:rgba(201,168,76,.2)}
.drawer-svc-tabs{display:flex;overflow-x:auto;gap:0;border-bottom:.5px solid rgba(201,168,76,.08);background:rgba(5,8,14,.75);scrollbar-width:none;flex-shrink:0;padding:0 2px}
.drawer-svc-tabs::-webkit-scrollbar{display:none}
.drawer-svc-tab{display:flex;align-items:center;gap:4px;padding:.65rem .85rem;background:none;border:none;border-bottom:1.5px solid transparent;color:rgba(138,155,170,.32);font-family:var(--font-body);font-size:.62rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;white-space:nowrap;transition:color .25s,border-color .25s;flex-shrink:0;position:relative}
.drawer-svc-tab::before{content:'';position:absolute;top:0;left:25%;right:25%;height:1px;background:transparent;transition:background .25s}
.drawer-svc-tab svg{opacity:.4;transition:opacity .2s;flex-shrink:0}
.drawer-svc-tab:hover{color:rgba(138,155,170,.65);border-bottom-color:rgba(201,168,76,.2)}
.drawer-svc-tab.active{color:#c9a84c;border-bottom-color:rgba(201,168,76,.6)}
.drawer-svc-tab.active::before{background:linear-gradient(90deg,transparent,rgba(201,168,76,.22),transparent)}
.drawer-svc-tab.active svg{opacity:1}
.drawer-reno-subtabs{display:none;gap:4px;padding:.55rem 1rem;border-bottom:.5px solid rgba(42,58,72,.5);background:rgba(8,11,18,.6);flex-shrink:0}
.drawer-reno-subtab{display:flex;align-items:center;gap:5px;padding:.28rem .75rem;background:none;border:.5px solid rgba(255,255,255,.08);border-radius:20px;color:rgba(138,155,170,.45);font-family:var(--font-body);font-size:.68rem;letter-spacing:.06em;cursor:pointer;transition:all .2s}
.drawer-reno-subtab:hover{border-color:rgba(42,168,208,.35);color:rgba(42,168,208,.75)}
.drawer-reno-subtab.active{background:rgba(201,168,76,.08);border-color:rgba(201,168,76,.3);color:#c9a84c}
.drawer-filters{display:none!important;gap:5px;padding:.75rem 1.25rem;overflow-x:auto;flex-shrink:0;scrollbar-width:none;border-bottom:.5px solid rgba(255,255,255,.05)}
.drawer-filters::-webkit-scrollbar{display:none}
.drawer-filter-pill{background:transparent;border:.5px solid rgba(255,255,255,.08);color:rgba(138,155,170,.4);padding:.26rem .8rem;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;border-radius:20px;white-space:nowrap;transition:all .22s;cursor:pointer;font-family:var(--font-body)}
.drawer-filter-pill:hover{border-color:rgba(42,168,208,.4);color:rgba(42,168,208,.8)}
.drawer-filter-pill.active{border-color:rgba(42,168,208,.5);color:var(--blue-light);background:rgba(26,127,160,.1)}
.drawer-body{flex:1;overflow:hidden!important;overflow-x:hidden;scrollbar-width:none}
.drawer-body::-webkit-scrollbar{display:none;width:3px}
.drawer-body::-webkit-scrollbar-track{background:transparent}
.drawer-body::-webkit-scrollbar-thumb{background:rgba(201,168,76,.2);border-radius:2px}
.drawer-panel.open .drawer-body{scrollbar-width:thin!important}
.drawer-panel.open .drawer-body::-webkit-scrollbar{display:block!important}
.drawer-body-inner{height:100%;padding:0}
.drawer-pool-preview{border:.5px solid var(--border-blue);border-radius:var(--rl);overflow:hidden;margin-bottom:1.25rem}
.drawer-pool-visual{height:260px;position:relative;background:#0d2d45;overflow:hidden}
.drawer-pool-water{position:absolute;inset:0;background:linear-gradient(180deg,#1a2830,#0d2d45);transition:background .4s ease;display:flex;align-items:flex-end;justify-content:center;padding-bottom:9px;z-index:1}
.drawer-pool-label{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.4);background:rgba(0,0,0,.35);padding:2px 8px;border-radius:8px;position:relative;z-index:2}
.drawer-pool-info{background:var(--dark);padding:.6rem .85rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.drawer-pool-name{font-family:var(--font-body);font-size:.85rem;font-weight:500;color:var(--text)}
.drawer-pool-tags{display:flex;gap:4px;flex-wrap:wrap}
.drawer-pool-tag{font-size:.72rem;padding:1px 6px;border-radius:8px;background:var(--blue-dim);color:var(--blue-light);border:.5px solid var(--border-blue)}
.drawer-section-head{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem .5rem;border-bottom:.5px solid rgba(201,168,76,.08);margin-bottom:0}
.drawer-section-title{font-family:var(--font-display);font-size:.88rem;font-weight:300;font-style:italic;color:rgba(238,242,245,.7);letter-spacing:.03em}
.drawer-section-count{font-size:.68rem;color:rgba(138,155,170,.35);letter-spacing:.08em;font-family:var(--font-body)}
.drawer-tile-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.drawer-tile{border-radius:var(--r);overflow:hidden;cursor:pointer;border:1.5px solid transparent;transition:border-color .2s,transform .2s}
.drawer-tile.hidden{display:none}
.drawer-tile:hover{border-color:rgba(201,168,76,.4);transform:translateY(-2px)}
.drawer-tile.selected{border-color:var(--gold);box-shadow:0 0 0 1px rgba(201,168,76,.15)}
.drawer-tile.shortlisted{border-color:rgba(201,168,76,.5)}
.drawer-tile.previewing{border-color:var(--blue-light);box-shadow:0 0 0 1px rgba(42,168,208,.2)}
.drawer-tile-swatch{height:70px;position:relative;overflow:hidden}
.drawer-tile-check{position:absolute;top:4px;right:4px;width:15px;height:15px;border-radius:50%;background:var(--gold);display:none;align-items:center;justify-content:center;font-size:8px;color:var(--dark);font-weight:700}
.drawer-tile.selected .drawer-tile-check{display:flex}
.drawer-tile-name{background:rgba(10,15,22,.9);padding:5px 6px;font-size:.75rem;font-family:var(--font-body);color:rgba(238,242,245,.7);line-height:1.3;text-align:center;letter-spacing:.03em}
.drawer-tile.selected .drawer-tile-name,.drawer-tile.shortlisted .drawer-tile-name{color:#c9a84c}
.drawer-tile.previewing .drawer-tile-name{color:var(--blue-light)}
.drawer-tile.tile-flash{animation:tileflash .4s ease}
@keyframes tileflash{0%{box-shadow:0 0 0 0 rgba(201,168,76,.8)}50%{box-shadow:0 0 18px 4px rgba(201,168,76,.45)}100%{box-shadow:0 0 0 0 rgba(201,168,76,0)}}
.dt-plus{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:rgba(10,12,15,.75);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-family:var(--font-body);z-index:2}
.dt-plus:hover{background:rgba(201,168,76,.85);border-color:var(--gold);color:var(--dark);transform:scale(1.1)}
.dt-plus.added{background:var(--gold);border-color:var(--gold);color:var(--dark);font-size:10px;font-weight:700}
.sw-ocean{background:repeating-linear-gradient(45deg,#1a6b9a,#1a6b9a 5px,#1e7aad 5px,#1e7aad 10px)}
.sw-cobalt{background:repeating-linear-gradient(45deg,#1e4fa3,#1e4fa3 5px,#2458b8 5px,#2458b8 10px)}
.sw-mist{background:repeating-linear-gradient(45deg,#5ba3c9,#5ba3c9 5px,#6ab3d9 5px,#6ab3d9 10px)}
.sw-sapphire{background:repeating-linear-gradient(45deg,#1a3a78,#1a3a78 5px,#204588 5px,#204588 10px)}
.sw-pearl{background:repeating-linear-gradient(45deg,#5bc4c0,#5bc4c0 5px,#6ad4d0 5px,#6ad4d0 10px)}
.sw-aurora{background:repeating-linear-gradient(45deg,#6a5ab5,#6a5ab5 5px,#7a68c5 5px,#7a68c5 10px)}
.sw-bronze{background:repeating-linear-gradient(45deg,#b8862a,#b8862a 5px,#c89438 5px,#c89438 10px)}
.sw-fteal{background:repeating-linear-gradient(45deg,#2a7a6a,#2a7a6a 5px,#348a78 5px,#348a78 10px)}
.sw-sand{background:repeating-linear-gradient(45deg,#c4a882,#c4a882 5px,#d0b890 5px,#d0b890 10px)}
.sw-ivory{background:repeating-linear-gradient(45deg,#ddd5c4,#ddd5c4 5px,#e8e0d0 5px,#e8e0d0 10px)}
.sw-rose{background:repeating-linear-gradient(45deg,#9a4060,#9a4060 5px,#aa5070 5px,#aa5070 10px)}
.sw-slate{background:repeating-linear-gradient(45deg,#7a8b96,#7a8b96 5px,#8a9ba8 5px,#8a9ba8 10px)}
.sw-terra{background:repeating-linear-gradient(45deg,#b86040,#b86040 5px,#c87050 5px,#c87050 10px)}
.sw-fgrn{background:repeating-linear-gradient(45deg,#2a5a2a,#2a5a2a 5px,#3a6a3a 5px,#3a6a3a 10px)}
.sw-blk{background:repeating-linear-gradient(45deg,#1a1e24,#1a1e24 5px,#22272f 5px,#22272f 10px)}
.sw-volc{background:repeating-linear-gradient(45deg,#2d2a2a,#2d2a2a 5px,#3a3535 5px,#3a3535 10px)}
.drawer-cat-grid,.drawer-compare-grid{display:grid;gap:7px;padding:.85rem 1rem}
.drawer-cat-grid{grid-template-columns:1fr}
.drawer-compare-grid{grid-template-columns:repeat(2,1fr)}
.drawer-cat-item{border-radius:8px;overflow:hidden;border:.5px solid rgba(255,255,255,.06);border-left:.5px solid rgba(201,168,76,.1);border-top:.5px solid rgba(255,255,255,.08);background:linear-gradient(135deg,rgba(255,255,255,.03) 0%,rgba(255,255,255,.012) 100%);box-shadow:0 4px 16px rgba(0,0,0,.25);cursor:pointer;transition:border-color .25s,box-shadow .25s,transform .25s;position:relative;display:flex;flex-direction:row;align-items:stretch}
.drawer-cat-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,rgba(201,168,76,.35),rgba(42,168,208,.15),transparent)}
.drawer-cat-item:hover{border-color:rgba(201,168,76,.2);border-left-color:rgba(201,168,76,.35);box-shadow:0 8px 24px rgba(0,0,0,.4);transform:translateY(-1px)}
.drawer-cat-item.selected{border-color:rgba(201,168,76,.28);border-left-color:rgba(201,168,76,.55);background:linear-gradient(135deg,rgba(201,168,76,.07) 0%,rgba(255,255,255,.015) 100%)}
.drawer-cat-item.selected::before{background:linear-gradient(180deg,#c9a84c,rgba(42,168,208,.35))}
.drawer-cat-thumb{width:90px;min-width:90px;height:auto;overflow:hidden;background-size:cover;background-position:center;position:relative;flex-shrink:0}
.drawer-cat-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;display:block}
.drawer-cat-item:hover .drawer-cat-thumb img{transform:scale(1.05)}
.drawer-cat-caption{flex:1;padding:.65rem .9rem;display:flex;flex-direction:column;justify-content:center;border-left:.5px solid rgba(255,255,255,.05);position:relative}
.drawer-cat-name{font-family:var(--font-display);font-size:.95rem;font-weight:400;color:rgba(238,242,245,.85);margin-bottom:.15rem;line-height:1.2;letter-spacing:.01em}
.drawer-cat-desc{font-size:.72rem;color:rgba(138,155,170,.5);line-height:1.55}
.drawer-cat-badge{display:inline-block;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(42,168,208,.7);border:.5px solid rgba(42,168,208,.22);padding:1px 6px;border-radius:10px;margin-top:5px}
.drawer-cat-item.selected .drawer-cat-name{color:#e8c97a}
.drawer-cat-item.selected .drawer-cat-badge{color:rgba(201,168,76,.8);border-color:rgba(201,168,76,.3)}
.drawer-compare-card{background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(255,255,255,.012));border:.5px solid rgba(255,255,255,.06);border-top:.5px solid rgba(255,255,255,.09);border-left:.5px solid rgba(201,168,76,.1);border-radius:8px;padding:1rem;cursor:pointer;transition:border-color .25s,transform .25s,box-shadow .25s;box-shadow:0 4px 16px rgba(0,0,0,.25);position:relative}
.drawer-compare-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,rgba(201,168,76,.25),rgba(42,168,208,.1),transparent)}
.drawer-compare-card:hover{border-color:rgba(201,168,76,.2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.drawer-compare-card.selected{border-color:rgba(201,168,76,.3);background:linear-gradient(135deg,rgba(201,168,76,.07),rgba(255,255,255,.015))}
.drawer-compare-card.selected::before{background:linear-gradient(180deg,#c9a84c,rgba(42,168,208,.3))}
.drawer-cc-icon{width:36px;height:36px;border-radius:var(--r);background:rgba(26,127,160,.1);border:.5px solid rgba(42,168,208,.2);display:flex;align-items:center;justify-content:center;margin-bottom:.6rem;font-size:1rem}
.drawer-cc-name{font-family:var(--font-display);font-size:.95rem;font-weight:400;color:rgba(238,242,245,.85);margin-bottom:.2rem;letter-spacing:.01em}
.drawer-cc-desc{font-size:.71rem;color:rgba(138,155,170,.48);line-height:1.55;margin-bottom:.65rem}
.drawer-cc-specs{display:flex;flex-direction:column;gap:2px}
.drawer-cc-spec{display:flex;align-items:center;justify-content:space-between;font-size:.7rem;padding:3px 0;border-bottom:.5px solid rgba(255,255,255,.05)}
.drawer-cc-spec:last-child{border-bottom:none}
.drawer-cc-spec-k{color:rgba(138,155,170,.45)}
.drawer-cc-spec-v{color:rgba(42,168,208,.7)}
.drawer-compare-card.selected .drawer-cc-spec-v{color:#c9a84c}
.drawer-compare-card.selected .drawer-cc-name{color:#e8c97a}
.drawer-foot{flex-shrink:0;border-top:.5px solid rgba(255,255,255,.06);padding:.75rem 1.25rem;background:rgba(5,7,12,.85)}
.drawer-global-foot{flex-shrink:0;border-top:.5px solid rgba(201,168,76,.12);padding:.85rem 1.25rem .95rem;background:linear-gradient(180deg,rgba(6,10,18,.92),rgba(4,7,13,.97))}
.drawer-global-foot-label{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(42,168,208,.5);display:flex;align-items:center;gap:.6rem;margin-bottom:.55rem}
.drawer-global-foot-label::before{content:'';width:12px;height:.5px;background:rgba(42,168,208,.45)}
.drawer-shortlist-row{display:flex;flex-wrap:wrap;gap:5px;min-height:20px;margin-bottom:.65rem}
.drawer-shortlist-chip{font-size:.72rem;background:rgba(201,168,76,.08);border:.5px solid rgba(201,168,76,.28);color:rgba(201,168,76,.9);padding:2px 8px;border-radius:20px;display:inline-flex;align-items:center;gap:4px}
.drawer-shortlist-chip button{color:rgba(201,168,76,.4);font-size:.75rem;background:none;border:none;line-height:1;padding:0;cursor:pointer;transition:color .15s;font-family:var(--font-body)}
.drawer-shortlist-chip button:hover{color:#c9a84c}
.drawer-shortlist-empty{font-size:.72rem;color:rgba(138,155,170,.3);font-style:italic;letter-spacing:.03em}
.drawer-foot-actions{display:flex;gap:8px}
.drawer-wa-btn{flex:1;background:linear-gradient(135deg,rgba(37,211,102,.9),rgba(28,170,82,.82));color:#fff;border:none;padding:.78rem 1rem;border-radius:7px;font-size:.72rem;font-weight:500;letter-spacing:.08em;display:flex;align-items:center;justify-content:center;gap:7px;transition:opacity .2s,transform .15s;cursor:pointer;font-family:var(--font-body);box-shadow:0 4px 16px rgba(37,211,102,.18),inset 0 1px 0 rgba(255,255,255,.15)}
.drawer-wa-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}
.drawer-wa-btn:active:not(:disabled){transform:translateY(0)}
.drawer-wa-btn:disabled{background:rgba(37,211,102,.1);color:rgba(255,255,255,.25);cursor:default;box-shadow:none}
.drawer-foot-hint{font-size:.68rem;color:rgba(138,155,170,.35);text-align:center;margin-top:.45rem;letter-spacing:.04em;font-style:italic}
.dt-layout{display:grid;grid-template-columns:45% 55%;height:100%;overflow:hidden}
.dt-left{position:sticky;top:0;height:100%;display:flex;flex-direction:column;border-right:.5px solid rgba(201,168,76,.1);overflow:hidden;background:rgba(6,9,15,.6)}
.dt-left .drawer-pool-visual{flex:1;min-height:0;position:relative;background:linear-gradient(180deg,#1a2830,#0d2d45);overflow:hidden}
.dt-left-info{padding:.75rem 1rem .6rem;border-bottom:.5px solid rgba(201,168,76,.08);flex-shrink:0;text-align:center}
.dt-tile-name{font-family:var(--font-display);font-size:.88rem;font-weight:400;font-style:italic;color:rgba(238,242,245,.8);line-height:1.2;margin-bottom:.3rem;text-align:center}
.dt-tile-tags{display:flex;gap:4px;flex-wrap:wrap;justify-content:center}
.dt-enquiry{flex-shrink:0;padding:.85rem 1rem;background:rgba(4,7,12,.8);border-top:.5px solid rgba(201,168,76,.1)}
.dt-enq-label{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(42,168,208,.5);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}
.dt-enq-label::before{content:'';display:block;width:1rem;height:.5px;background:rgba(42,168,208,.45)}
.dt-enquiry .drawer-shortlist-row{display:flex;flex-wrap:wrap;gap:5px;min-height:18px;margin-bottom:.55rem}
.dt-enquiry .drawer-wa-btn{width:100%}
.dt-enquiry .drawer-foot-hint{font-size:.68rem;color:rgba(138,155,170,.32);text-align:center;margin-top:.4rem;letter-spacing:.04em;font-style:italic}
.dt-right{height:100%;display:flex;flex-direction:column;overflow:hidden}
.dt-filters-sticky{flex-shrink:0;position:sticky;top:0;background:rgba(5,8,14,.88);border-bottom:.5px solid rgba(255,255,255,.05);z-index:10}
.dt-filters-bar{display:flex;gap:5px;padding:.65rem .9rem .55rem;overflow-x:auto;scrollbar-width:none;flex-wrap:wrap}
.dt-filters-bar::-webkit-scrollbar{display:none}
.dt-count{font-size:.68rem;color:rgba(138,155,170,.38);letter-spacing:.06em;padding:0 .9rem .55rem;font-family:var(--font-body);font-style:italic}
.dt-tiles-scroll{flex:1;overflow-y:auto;scrollbar-width:none}
.dt-tiles-scroll::-webkit-scrollbar{display:none;width:3px}
.dt-tiles-scroll::-webkit-scrollbar-thumb{background:rgba(201,168,76,.2);border-radius:2px}
.drawer-panel.open .dt-tiles-scroll{scrollbar-width:thin!important}
.drawer-panel.open .dt-tiles-scroll::-webkit-scrollbar{display:block!important}
.dt-tiles-scroll .drawer-tile-grid{grid-template-columns:repeat(3,1fr);padding:.65rem .9rem .9rem;gap:7px}
 
.field-error{font-size:.75rem;color:#E24B4A;margin-top:.3rem;padding:.25rem 0;line-height:1.4;display:block}
.contact-form input.error,.contact-form select.error,.contact-form textarea.error{border-color:#E24B4A}
 
/* ── PORTFOLIO EXPAND ── */
.portfolio-item.portfolio-collapsed{display:none}
.portfolio-expand-wrap{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:.5px solid var(--border-blue)}
.portfolio-expand-btn{display:inline-flex;align-items:center;gap:.65rem;background:transparent;border:.5px solid rgba(42,168,208,0.3);color:var(--blue-light);padding:.7rem 1.8rem;font-family:var(--font-body);font-size:.75rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;border-radius:var(--r);transition:all .3s}
.portfolio-expand-btn:hover{background:var(--blue-dim);border-color:var(--blue-light);color:#fff}
.portfolio-expand-btn svg{transition:transform .35s cubic-bezier(.22,1,.36,1)}
.portfolio-expand-btn.expanded svg{transform:rotate(180deg)}
.portfolio-expand-count{font-size:.68rem;opacity:.65;font-style:italic}
 
/* ── FAQ EXPAND ── */
.faq-item.faq-collapsed{display:none}
.faq-expand-wrap{margin-top:1.5rem;text-align:center}
.faq-expand-btn{display:inline-flex;align-items:center;gap:.65rem;background:transparent;border:.5px solid rgba(201,168,76,0.25);color:var(--gold);padding:.65rem 1.6rem;font-family:var(--font-body);font-size:.75rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;border-radius:var(--r);transition:all .3s}
.faq-expand-btn:hover{background:var(--gold-dim);border-color:var(--gold)}
.faq-expand-btn svg{transition:transform .35s cubic-bezier(.22,1,.36,1)}
.faq-expand-btn.expanded svg{transform:rotate(180deg)}
.hero-review-badge{display:inline-flex;align-items:center;gap:.55rem;background:rgba(201,168,76,.08);border:.5px solid rgba(201,168,76,.25);border-radius:var(--rs);padding:.28rem .85rem;margin-bottom:1rem;flex-wrap:wrap}
.hrb-stars{color:var(--gold);font-size:.78rem;letter-spacing:2px;line-height:1}
.hrb-text{font-size:.72rem;color:var(--text-muted);letter-spacing:.08em}
.hrb-dot{width:3px;height:3px;border-radius:50%;background:var(--border-gold);flex-shrink:0}
.hero-drawer-hint{display:inline-flex;align-items:center;gap:.55rem;color:var(--blue-light);font-size:.78rem;letter-spacing:.05em;border:.5px solid rgba(26,127,160,.3);border-radius:var(--rs);padding:.4rem .9rem;margin-bottom:2rem;cursor:pointer;transition:all .25s;background:rgba(26,127,160,.06)}
.hero-drawer-hint:hover{background:rgba(26,127,160,.14);border-color:var(--blue-light)}
.contact-scarcity{display:block;margin-top:.75rem;font-size:.78rem;color:var(--gold);letter-spacing:.04em;border-left:2px solid rgba(201,168,76,.4);padding-left:.75rem;line-height:1.65;word-break:break-word}
.contact-reassurance{background:rgba(26,127,160,.06);border:.5px solid var(--border-blue);border-radius:var(--rl);padding:1.1rem 1.3rem;margin-bottom:1.8rem;display:flex;flex-direction:column;gap:.6rem}
.cr-item{display:flex;align-items:center;gap:.6rem;font-size:.82rem;color:var(--text-muted);line-height:1.4}
.cr-item svg{stroke:var(--blue-light);flex-shrink:0}
.cf-intro{font-size:.82rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.6;font-style:italic}
.cf-reassure{font-size:.72rem;color:rgba(138,155,170,.55);text-align:center;margin-top:.6rem;line-height:1.6;letter-spacing:.03em}
.portfolio-drawer-hint{display:flex;align-items:center;gap:.75rem;background:rgba(26,127,160,.06);border:.5px solid var(--border-blue);border-radius:var(--rl);padding:.9rem 1.2rem;margin-bottom:1.5rem;cursor:pointer;transition:all .25s;color:var(--text-muted);font-size:.82rem;line-height:1.5;flex-wrap:wrap}
.portfolio-drawer-hint:hover{background:rgba(26,127,160,.13);border-color:var(--blue-light);color:var(--text)}
.portfolio-drawer-hint svg:first-child{color:var(--blue-light);flex-shrink:0}
.portfolio-drawer-hint span{flex:1;min-width:0}
.pdh-cta{display:inline-flex;align-items:center;gap:4px;color:var(--blue-light);font-size:.75rem;font-weight:500;letter-spacing:.06em;white-space:nowrap;flex-shrink:0}
.portfolio-drawer-hint:focus-visible{outline:2px solid var(--blue-light);outline-offset:2px}
.warranty-strip{display:flex;align-items:center;justify-content:center;gap:0;background:rgba(201,168,76,.06);border:.5px solid var(--border-gold);border-radius:var(--r);padding:.7rem 1rem;margin-bottom:1rem;flex-wrap:wrap}
.ws-item{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--gold);letter-spacing:.03em;padding:.1rem .8rem}
.ws-item svg{stroke:var(--gold);flex-shrink:0;opacity:.75}
.ws-sep{width:1px;height:14px;background:rgba(201,168,76,.25);flex-shrink:0}
.services-grid-build{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:1rem}
.services-grid-restore{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:1rem}
.svc-track-label{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:var(--text-muted);letter-spacing:.04em;margin-bottom:0}
.svc-track-pill{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.22rem .75rem;border-radius:20px;flex-shrink:0}
.svc-track-pill.build{background:rgba(26,127,160,.12);color:var(--blue-light);border:.5px solid rgba(26,127,160,.3)}
.svc-track-pill.restore{background:rgba(201,168,76,.1);color:var(--gold);border:.5px solid rgba(201,168,76,.3)}
.service-card-restore{background:rgba(26,127,160,0.07);border:.5px solid rgba(42,168,208,0.18);box-shadow:inset 0 1.5px 0 rgba(255,255,255,0.16),inset 1px 0 0 rgba(255,255,255,0.07),0 8px 32px rgba(0,0,0,0.35)}
.service-card-restore::before{background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent)}
.service-card-restore:hover{border-color:rgba(42,168,208,0.4);box-shadow:inset 0 1.5px 0 rgba(255,255,255,0.20),inset 1px 0 0 rgba(255,255,255,0.10),0 16px 40px rgba(0,0,0,0.5),0 0 24px rgba(26,127,160,0.15)}
.service-card-restore .sc-cta{color:var(--blue-light);background:rgba(26,127,160,.08);border-top-color:rgba(42,168,208,.2)}
.service-card-restore .sc-cta:hover{background:var(--blue);color:#fff;border-top-color:var(--blue)}
.sc-includes{display:flex;flex-wrap:wrap;gap:4px;margin-top:.6rem;margin-bottom:.1rem}
.sc-includes span{font-size:.68rem;background:rgba(26,127,160,.1);border:.5px solid rgba(26,127,160,.2);color:var(--blue-light);padding:1px 7px;border-radius:20px;white-space:nowrap}
.service-card-restore .sc-includes span{background:rgba(26,127,160,.07);border-color:rgba(42,168,208,.2);color:var(--blue-light)}
/* Tier 3: Touch device hover-state fix.
   On phones, :hover "sticks" after tap — transform hangs, looks broken.
   @media(hover:none) ensures no hover transform is applied on touch-only devices. */
@media(hover:none){
  .service-card:hover{transform:none}
  .tcard:hover{transform:none}
  .why-card:hover{transform:none}
  .portfolio-item:hover{transform:none}
  .drawer-cat-item:hover{transform:none}
}
 
*:not(html)::-webkit-scrollbar{display:none}
*:not(html){scrollbar-width:none}
 
@media(max-width:1100px){
  .services-grid,.services-grid-build{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .hero-collage{width:52%}
  .svc-more{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  nav.desktop-nav{display:none!important}
  .mobile-nav-bar{display:flex}
  section{padding:2.5rem 1.5rem}
  .coverage-section{padding:2.5rem 1.5rem}
  #hero{padding:6rem 1.5rem 4rem;align-items:center;text-align:center}
  main,section{overflow-x:hidden}#trust{overflow:hidden}
  .hero-collage{width:100%;height:100%;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr 1fr;opacity:1;overflow:hidden}
  .hero-collage-img:nth-child(1){grid-column:1;grid-row:1/3}
  .hero-collage-img:nth-child(2){grid-column:2;grid-row:1}
  .hero-collage-img:nth-child(3){grid-column:2;grid-row:2}
  .hero-collage-img:nth-child(4){grid-column:1;grid-row:3}
  .hero-collage-img:nth-child(5){grid-column:2;grid-row:3}
  .hero-collage img{filter:brightness(.55) saturate(.85)}
  .hero-overlay{background:linear-gradient(135deg,rgba(10,12,15,.92) 0%,rgba(10,12,15,.75) 50%,rgba(10,12,15,.6) 100%)}
  .hero-eyebrow{justify-content:center}.hero-eyebrow::before{display:none}
  .hero-title{font-size:clamp(2.2rem,8vw,3rem);text-align:center}
  .hero-tagline{text-align:center;margin-left:auto;margin-right:auto;max-width:100%}
  .hero-actions{justify-content:center}.hero-stats{gap:1.5rem;flex-wrap:wrap;justify-content:center}
  .hero-review-badge{justify-content:center}.hero-content{max-width:calc(100vw - 3rem);max-width:100%;overflow:hidden}
  .hero-drawer-hint{white-space:normal;max-width:100%;box-sizing:border-box}
  .why-grid{grid-template-columns:1fr}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .gold-divider{width:100%}
  .about-visual{overflow:hidden;position:relative;top:auto}.about-box-accent{right:0}
  .portfolio-grid,.portfolio-grid.few-items{grid-template-columns:repeat(2,1fr)}
  footer{padding:2rem 1.5rem;flex-direction:column;align-items:flex-start}
  .fab-wa span:last-child{display:none}.fab-wa{padding:.85rem;border-radius:50%}
  .lb-prev{left:.5rem}.lb-next{right:.5rem}
  .contact-grid{gap:2.5rem}
  .contact-left,.contact-right{display:flex;flex-direction:column;height:100%}
  .section-sub{max-width:100%}
  /* process — vertical stack on mobile */
  .process-grid{grid-template-columns:1fr;gap:12px;position:relative}
  .process-line-track{display:none}
  /* vertical background line */
  .process-grid::before{content:'';position:absolute;left:calc(1.4rem + 15px);top:2.2rem;bottom:2.2rem;width:1px;background:rgba(26,127,160,0.15);z-index:0;border-radius:1px}
  /* vertical animated fill line — triggered by same .line-animated class as desktop */
  .process-grid::after{content:'';position:absolute;left:calc(1.4rem + 15px);top:2.2rem;width:1px;height:0;background:linear-gradient(180deg,var(--gold),var(--blue-light));box-shadow:0 0 8px rgba(42,168,208,0.45);transition:height 1.4s cubic-bezier(.4,0,.2,1);z-index:0;border-radius:1px}
  .process-grid.line-animated::after{height:calc(100% - 4.4rem)}
  /* mobile card layout */
  .pd-card{text-align:left;display:flex;flex-direction:row;align-items:flex-start;gap:1rem;padding:1.2rem 1.4rem;position:relative;z-index:1}
  .pd-card.awaiting-animation{opacity:0;transform:translateX(20px)}
  .pd-card.card-visible{opacity:1;transform:translateX(0)}
  .pd-dot-wrap{margin-bottom:0;flex-shrink:0;margin-top:.2rem}
  .pd-num{font-size:1.6rem;margin-bottom:.2rem}
  .pd-card-body{flex:1}
  .coverage-inner{grid-template-columns:1fr;gap:2.5rem}.coverage-left{position:static}.coverage-desc{max-width:100%}
  .coverage-cities-row{flex-direction:column}.coverage-city-card{padding:1rem 0!important;border-left:none!important}
  .cc-pipe-dot{display:none}.cc-name{font-size:1.2rem}
  .drawer-panel{width:100%!important;border-left:none}
  .drawer-body{overflow-y:auto!important}
  .drawer-tile-grid{grid-template-columns:repeat(3,1fr)}
  .dt-layout{grid-template-columns:1fr;height:auto;overflow:visible}
  .dt-left{position:sticky;top:0;z-index:20;height:auto;overflow:hidden;border-right:none;border-bottom:.5px solid var(--border-blue);max-height:55vw;flex-direction:row;align-items:stretch}
  .dt-left .drawer-pool-visual{min-height:0;flex:1;height:100%;min-height:36vw}
  .dt-left-info{display:none}
  .dt-enquiry{width:40%;flex-shrink:0;border-top:none;border-left:.5px solid var(--border-blue);display:flex;flex-direction:column;justify-content:center}
  .dt-right{height:auto;overflow:visible}
  .dt-tiles-scroll{overflow-y:visible;flex:none}
  .dt-filters-sticky{position:static}
  .drawer-filters{display:flex!important}
  .dt-filters-bar{display:none}
  .dt-tiles-scroll .drawer-tile-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  .services-grid,.testimonials-grid,.services-grid-restore{grid-template-columns:1fr}
  .portfolio-grid,.portfolio-grid.few-items{grid-template-columns:1fr}
  .hero-watermark{font-size:5rem;overflow:hidden}
  .why-card{padding:1.2rem 1.2rem 1.2rem 1rem}
  .why-num{font-size:2rem}
  .why-stat{min-width:64px}
  .why-divider{height:40px}
  .pd-num{font-size:1.5rem}
  .footer-links{flex-wrap:wrap;gap:.8rem}
  footer{padding:1.5rem}
  .bilingual-badge{display:block;text-align:center}
  .contact-btn-row{flex-direction:column;gap:.6rem}
  .contact-btn-row a{width:100%;justify-content:center}
  .wa-btn-inline,.review-btn-inline{width:100%;justify-content:center;box-sizing:border-box}
  .about-box-accent{position:relative;bottom:auto;right:auto;width:100%;margin-top:1rem}
  section{overflow-x:hidden}
  .sc-includes span{white-space:normal}
  .svc-track-label{flex-wrap:wrap;align-items:flex-start}
  .pdh-cta{display:none}
  .ws-sep{display:none}
  .warranty-strip{flex-direction:column;align-items:flex-start;gap:0;padding:.5rem .75rem}
  .ws-item{padding:.45rem 0;width:100%;border-bottom:.5px solid rgba(201,168,76,.1)}
  .ws-item:last-child{border-bottom:none}
  .services-grid-build{grid-template-columns:1fr}
  .svc-more{grid-template-columns:1fr}
  .drawer-tile-grid{grid-template-columns:repeat(3,1fr);gap:5px}
  .drawer-cat-grid{grid-template-columns:1fr}
  .drawer-compare-grid{grid-template-columns:1fr}
  .drawer-head{padding:.85rem 1rem}
  .drawer-body-inner{padding:1rem}
  .drawer-filters{padding:.65rem 1rem}
  .drawer-foot{padding:.75rem 1rem}
  .dt-left{flex-direction:column;max-height:none;position:sticky;top:0;z-index:20}
  .dt-left .drawer-pool-visual{min-height:44vw;flex:none}
  .dt-left-info{display:none}
  .dt-enquiry{width:100%;border-left:none;border-top:.5px solid var(--border-blue);padding:.6rem 1rem}
  .dt-enq-label{display:none}
  .dt-tiles-scroll .drawer-tile-grid{grid-template-columns:repeat(3,1fr)}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .trust-track{animation:none}
  .fade-section.will-animate{opacity:1;transform:none}
}
 
/* ═══════════════════════════════════════════════════════
   NEW FEATURES — 6 changes
   ═══════════════════════════════════════════════════════ */

/* ── 1. Desktop nav shimmer crown line ── */
nav.desktop-nav::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1.5px;
  background:linear-gradient(90deg,transparent 5%,rgba(201,168,76,.5) 35%,rgba(42,168,208,.35) 65%,transparent 95%);
  pointer-events:none;z-index:1
}

/* ── 2. Mobile nav expanded logo — span styles ── */
.mnb-logo-main{
  font-family:var(--font-display);font-size:.92rem;font-weight:600;
  color:var(--gold);letter-spacing:.04em;white-space:nowrap
}
.mnb-logo-sub{
  font-family:var(--font-body);font-size:.46rem;font-weight:300;
  color:rgba(255,255,255,.35);letter-spacing:.04em; /* was .16em — much tighter so it fits */
  text-transform:uppercase;white-space:nowrap
}

/* ── 4. Portfolio mobile carousels — hidden by default, shown inside media query ── */
.portfolio-mobile{display:none}

/* ═══════════════════════════════════════════
   UNIFIED PORTFOLIO CAROUSEL — mobile
   ═══════════════════════════════════════════ */
@keyframes shimmerSweep{
  0%{transform:translateX(-120%) skewX(-20deg);opacity:.55}
  100%{transform:translateX(220%) skewX(-20deg);opacity:0}
}
@keyframes cardReveal{
  from{opacity:0;transform:scale(.94) translateY(12px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}

@media(max-width:900px){
  /* Hide old grid, filter bar, count, expand button on mobile */
  #portfolioGrid{display:none}
  .filter-bar{display:none}
  .portfolio-count{display:none}
  .portfolio-expand-wrap{display:none}

  /* Portfolio mobile block */
  .portfolio-mobile{display:block}

  /* reduce gap between section subtitle and portfolio controls */
  #portfolio .section-sub{margin-bottom:.75rem}

  /* ── Filter pill tabs — BIGGER & more prominent ── */
  .pmc-filters{
    display:flex;gap:8px;margin-bottom:1rem;
    overflow-x:auto;scrollbar-width:none;
    padding-bottom:3px;-webkit-overflow-scrolling:touch
  }
  .pmc-filters::-webkit-scrollbar{display:none}
  .pmc-filter{
    -webkit-appearance:none;appearance:none;
    flex-shrink:0;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.16);
    color:rgba(255,255,255,.55);
    font-family:var(--font-body);font-size:.76rem; /* was .68 */
    letter-spacing:.12em;text-transform:uppercase;
    padding:.58rem 1.3rem; /* was .42rem 1rem — taller + wider */
    border-radius:6px; /* sharp-ish corners, more architectural */
    cursor:pointer;
    transition:background .28s ease,border-color .28s ease,color .28s ease,box-shadow .28s ease;
    white-space:nowrap;line-height:1;
    /* subtle inner relief */
    box-shadow:inset 0 1px 0 rgba(255,255,255,.04)
  }
  .pmc-filter:hover{border-color:rgba(201,168,76,.45);color:rgba(255,255,255,.9)}
  .pmc-filter.active{
    background:rgba(201,168,76,.1);
    border-color:rgba(201,168,76,.75);
    color:var(--gold);
    box-shadow:0 0 18px rgba(201,168,76,.15),inset 0 0 12px rgba(201,168,76,.05)
  }
  /* Tap ripple on filter buttons */
  .pmc-filter:active{transform:scale(.96)}

  /* ── Meta row: count + swipe hint on SAME line ── */
  .pmc-meta-row{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:.7rem;min-height:22px
  }
  .pmc-count-label{
    font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
    color:rgba(138,155,170,.5);font-family:var(--font-body);font-weight:300
  }
  .pmc-swipe-hint{
    display:flex;align-items:center;gap:.35rem;
    font-size:.62rem;color:rgba(138,155,170,.45);
    letter-spacing:.05em;font-family:var(--font-body);
    transition:opacity .6s ease;flex-shrink:0
  }
  .pmc-swipe-hint.hidden{opacity:0;pointer-events:none}
  .pmc-swipe-arrow{
    display:inline-flex;align-items:center;justify-content:center;
    width:15px;height:15px;border-radius:50%;
    border:1px solid rgba(138,155,170,.28);font-size:9px;
    animation:pulse-arrow 1.4s ease-in-out 1s 3 both
  }
  @keyframes pulse-arrow{
    0%,100%{transform:translateX(0);opacity:.4}
    50%{transform:translateX(3px);opacity:1}
  }

  /* ── Water flow-in animation for cards after filter change ── */
  @keyframes waterFlowIn{
    0%  {opacity:0;transform:scale(.88) translateX(-14px)}
    60% {opacity:1;transform:scale(1.01) translateX(2px)}
    100%{opacity:1;transform:scale(1) translateX(0)}
  }
  .pmc-card.flow-in{
    animation:waterFlowIn .55s cubic-bezier(.22,1,.36,1) both
  }

  /* ── "View All Projects" button ── */
  .pmc-view-all{
    display:flex;align-items:center;justify-content:center;gap:.65rem;
    margin-top:1.35rem;
    width:100%;
    -webkit-appearance:none;appearance:none;
    background:transparent;
    border:.5px solid rgba(201,168,76,.3);
    color:rgba(201,168,76,.8);
    font-family:var(--font-body);font-size:.72rem;
    letter-spacing:.16em;text-transform:uppercase;
    padding:.75rem 1.5rem;border-radius:6px;
    cursor:pointer;
    transition:border-color .3s,color .3s,background .3s,box-shadow .3s
  }
  .pmc-view-all:hover{
    border-color:rgba(201,168,76,.7);
    color:var(--gold);
    background:rgba(201,168,76,.05);
    box-shadow:0 0 20px rgba(201,168,76,.1)
  }
  .pmc-view-all svg{flex-shrink:0;opacity:.7;transition:transform .35s,opacity .3s}
  .pmc-view-all:hover svg{transform:rotate(-45deg) scale(1.1);opacity:1}
}

  /* ── Carousel track wrapper ── */
  .pmc-track-wrap{
    position:relative;overflow:hidden;
    /* soft fade on the right edge — teases next card */
    mask-image:linear-gradient(90deg,black 0%,black 82%,transparent 100%);
    -webkit-mask-image:linear-gradient(90deg,black 0%,black 82%,transparent 100%)
  }
  .pmc-track{
    display:flex;gap:12px;
    overflow-x:auto;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding-right:18vw; /* ghost space: shows peek of next card */
    /* Fix 5: CSS scroll-behavior:smooth removed — JS already calls scrollTo({behavior:'smooth'}).
       Having it in CSS too makes the browser attempt two smooth-scroll passes → stutter. */
  }
  .pmc-track::-webkit-scrollbar{display:none}

  /* ── Individual cards ── */
  .pmc-card{
    flex:0 0 78vw;max-width:310px;
    scroll-snap-align:center;
    aspect-ratio:3/4;
    border-radius:var(--rl);overflow:hidden;
    position:relative;cursor:pointer;
    border:.5px solid rgba(255,255,255,.06);
    box-shadow:0 12px 40px rgba(0,0,0,.55);
    /* Premium scale + fade when card enters viewport (via JS class) */
    transition:transform .55s cubic-bezier(.22,1,.36,1),
               box-shadow .55s cubic-bezier(.22,1,.36,1),
               border-color .4s ease,
               opacity .4s ease;
    /* Cards not in the active-adjacent zone appear slightly smaller */
    transform:scale(.92);opacity:.6
  }
  .pmc-card.pmc-active{
    transform:scale(1);opacity:1;
    border-color:rgba(201,168,76,.22);
    box-shadow:0 16px 56px rgba(0,0,0,.7),0 0 0 .5px rgba(201,168,76,.15)
  }
  .pmc-card.pmc-near{
    transform:scale(.96);opacity:.82
  }

  /* Parallax inner image — moves slightly slower than card on scroll */
  .pmc-img-wrap{
    position:absolute;inset:0;overflow:hidden
  }
  .pmc-img-wrap img{
    width:100%;height:110%;object-fit:cover;display:block;
    margin-top:-5%;
    transition:transform .6s cubic-bezier(.22,1,.36,1)
  }
  .pmc-card.pmc-active .pmc-img-wrap img{
    transform:scale(1.04)
  }

  /* Category chip */
  .pmc-cat-chip{
    display:inline-block;
    font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;
    color:var(--blue-light);
    border:.5px solid rgba(42,168,208,.3);
    /* Fix 4: was backdrop-filter:blur(4px) — 9 chips = 9 compositor layers in a scroll-heavy
       section. Bumped opacity slightly so it's visually identical without the blur cost. */
    background:rgba(8,18,28,0.88);
    padding:.22rem .65rem;border-radius:20px;
    margin-bottom:.45rem
  }

  /* Card info overlay — gradient from bottom */
  .pmc-overlay{
    position:absolute;inset:0;
    background:linear-gradient(
      0deg,
      rgba(8,10,14,.95) 0%,
      rgba(8,10,14,.55) 40%,
      transparent 70%
    );
    display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;
    padding:1rem 1.1rem
  }
  .pmc-name{
    font-family:var(--font-display);font-size:1.05rem;
    font-weight:300;color:#eef2f5;line-height:1.2;margin-bottom:.25rem;
    text-shadow:0 1px 8px rgba(0,0,0,.6)
  }
  .pmc-loc{
    font-size:.62rem;color:var(--blue-light);
    letter-spacing:.12em;text-transform:uppercase
  }

  /* Gold shimmer sweep — fires once when card becomes active */
  .pmc-shimmer{
    position:absolute;inset:0;pointer-events:none;
    overflow:hidden;border-radius:inherit;
    z-index:5
  }
  .pmc-shimmer::after{
    content:'';
    position:absolute;top:0;left:0;width:50%;height:100%;
    background:linear-gradient(
      90deg,
      transparent 0%,
      rgba(201,168,76,.18) 50%,
      transparent 100%
    );
    transform:translateX(-120%) skewX(-20deg);
  }
  .pmc-card.pmc-active .pmc-shimmer::after{
    animation:shimmerSweep .8s cubic-bezier(.22,1,.36,1) .05s both
  }

  /* Hidden cards (when filter active) */
  .pmc-card.pmc-hidden{
    display:none
  }

  /* ── Dots — centered, water-drop ripple circles ── */
  .pmc-dots{
    display:flex;gap:8px;
    justify-content:center;
    align-items:center;
    margin-top:1.1rem;
    min-height:20px
  }
  .pmc-dot{
    width:6px;height:6px;border-radius:50%;
    background:rgba(255,255,255,.2);
    border:none;padding:0;cursor:pointer;
    transition:background .35s,transform .35s,box-shadow .35s;
    position:relative
  }
  .pmc-dot.active{
    background:var(--blue-light);
    transform:scale(1.2);
    /* Fix 2b: box-shadow keyframe removed — caused paint 60×/s. Ripple now lives on
       ::after pseudo-element and animates only transform+opacity (compositor only). */
  }
  /* Ripple ring — purely composited, zero paint */
  .pmc-dot.active::after{
    content:'';
    position:absolute;
    inset:-5px;
    border-radius:50%;
    background:rgba(0,170,255,0.5);
    transform:scale(0);
    opacity:0;
    animation:water-ripple-dot 2.2s ease-out infinite;
    pointer-events:none
  }
  @keyframes water-ripple-dot{
    0%  {transform:scale(0);opacity:.5}
    70% {transform:scale(2.8);opacity:0}
    100%{transform:scale(2.8);opacity:0}
  }
/* ── 5. Testimonials — grid on desktop, carousel on mobile ── */
.tcarousel{display:none}
.tcarousel-track-wrap{overflow:hidden;position:relative}
.tcarousel-track{display:flex;transition:transform .45s cubic-bezier(.22,1,.36,1)}
.tcarousel-slide{flex:0 0 100%;min-width:0;padding:0 2px}
.tcarousel-slide .tcard{width:100%;box-sizing:border-box;display:flex;flex-direction:column}
.tcarousel-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.25rem}
.tcarousel-dots{display:flex;gap:6px}
.tcarousel-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.15);transition:background .3s,transform .3s;cursor:pointer;border:none;padding:0}
.tcarousel-dot.active{background:var(--blue-light);transform:scale(1.3)}
.tcarousel-btn{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.05);border:.5px solid rgba(255,255,255,.1);color:rgba(255,255,255,.45);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:.8rem}
.tcarousel-btn:hover{border-color:var(--blue-light);color:var(--blue-light)}
@media(max-width:900px){
  .testimonials-grid{display:none!important}
  .tcarousel{display:block}
}

/* ═══════════════════════════════════════════════
   MASONRY PORTFOLIO OVERLAY — mobile full-screen
   ═══════════════════════════════════════════════ */
.masonry-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(4,6,10,0);
  opacity:0;visibility:hidden;pointer-events:none;
  contain:layout style; /* Fix 10: self-contained — no page layout thrash on open/close */
  transition:opacity .4s ease,background .4s,visibility 0s linear .4s
}
.masonry-overlay.open{
  opacity:1;visibility:visible;pointer-events:all;
  background:rgba(4,6,10,.96);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:opacity .4s ease,background .4s,visibility 0s linear 0s
}
.masonry-panel{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  transform:translateY(30px);opacity:0;
  transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .4s ease
}
.masonry-overlay.open .masonry-panel{transform:translateY(0);opacity:1}

/* ── Header ── */
.masonry-head{
  display:flex;flex-direction:column;
  padding:.9rem 1.25rem .75rem;
  flex-shrink:0;
  border-bottom:.5px solid rgba(201,168,76,.15);
  background:rgba(8,10,14,.6);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)
}
.masonry-head-top{
  display:flex;align-items:center;justify-content:center;
  position:relative;margin-bottom:.75rem
}
.masonry-head-title{
  font-family:var(--font-display);font-size:1.35rem;font-weight:300;
  color:var(--gold);letter-spacing:.04em;text-align:center
}
.masonry-head-sub{
  font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(138,155,170,.5);margin-right:1rem;display:none
}
/* Filter pills row inside masonry header */
.masonry-filters{
  display:flex;gap:8px;justify-content:flex-start;
  overflow-x:auto;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  padding-bottom:2px;flex-wrap:nowrap
}
.masonry-filters::-webkit-scrollbar{display:none}

/* Signature gold fading line below filter pills */
.masonry-gold-line{
  height:1px;margin-top:.65rem;
  background:linear-gradient(90deg,transparent 0%,rgba(201,168,76,.55) 25%,rgba(201,168,76,.55) 75%,transparent 100%)
}
.mf-btn{
  -webkit-appearance:none;appearance:none;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.5);
  font-family:var(--font-body);font-size:.68rem;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.42rem 1.1rem;border-radius:6px;
  cursor:pointer;white-space:nowrap;line-height:1;
  transition:background .25s,border-color .25s,color .25s,box-shadow .25s
}
.mf-btn:active{transform:scale(.96)}
.mf-btn.active{
  background:rgba(201,168,76,.1);
  border-color:rgba(201,168,76,.7);
  color:var(--gold);
  box-shadow:0 0 14px rgba(201,168,76,.12)
}
.masonry-close{
  -webkit-appearance:none;appearance:none;
  background:rgba(255,255,255,.06);
  border:.5px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.55);
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;
  position:absolute;right:0;top:50%;transform:translateY(-50%);
  transition:background .25s,border-color .25s,color .25s
}
.masonry-close:hover{background:rgba(201,168,76,.12);border-color:var(--gold);color:var(--gold)}

/* ── Scrollable grid area ── */
.masonry-scroll{flex:1;overflow-y:auto;padding:8px 8px 100px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.masonry-scroll::-webkit-scrollbar{display:none}

/* ── 2-col asymmetric grid ── */
.masonry-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-auto-rows:130px;
  gap:6px
}
/* Asymmetric spans */
.masonry-grid .mi-tall{grid-row:span 2}
.masonry-grid .mi-wide{grid-column:span 2;grid-row:span 1}

/* ── Grid items ── */
.masonry-item{
  position:relative;overflow:hidden;
  border-radius:8px;cursor:pointer;
  border:.5px solid rgba(255,255,255,.06);
  /* staggered fade-in via JS --mi-i */
  opacity:0;transform:translateY(16px);
  transition:opacity .5s ease var(--mi-delay,0s),
             transform .5s cubic-bezier(.22,1,.36,1) var(--mi-delay,0s),
             box-shadow .3s ease
}
.masonry-overlay.open .masonry-item{opacity:1;transform:translateY(0)}
.masonry-item:active{transform:scale(.97)}
.masonry-item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s cubic-bezier(.22,1,.36,1)
}
.masonry-item:hover img,.masonry-item:active img{transform:scale(1.06)}

/* Label on each item */
.mi-label{
  position:absolute;bottom:0;left:0;right:0;
  padding:.55rem .7rem .6rem;
  background:linear-gradient(0deg,rgba(6,8,12,.92) 0%,transparent 100%);
  display:flex;flex-direction:column;gap:1px
}
.mi-label span{
  font-size:.52rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--blue-light);display:block
}
.mi-label div{
  font-family:var(--font-display);font-size:.82rem;font-weight:300;
  color:#eef2f5;line-height:1.2
}
.mi-label small{
  font-size:.55rem;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(138,155,170,.55)
}

/* ── Water-wave entry for masonry items ── */
@keyframes masonryWave{
  0%{opacity:0;transform:translateY(22px) scale(.95)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
