/* ============================================================
   KALYAN ELEVATORS — Design System
   Dark-mode-first, architectural, brass-accented luxury system
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Outfit:wght@200;300;400;500;600&display=swap');

:root{
  --bg-dark:#141414;
  --bg-darker:#101010;
  --bg-bone:#F9F6F0;
  --bg-linen:#F4F4F4;
  --ink:#EDEAE3;
  --ink-dark:#1F1F1F;
  --muted:#8E8E93;
  --muted-light:#C7C7CC;
  --line-d:rgba(255,255,255,.08);
  --line-l:rgba(0,0,0,.09);
  --brass:#C8922C;
  --gold:#D4AF37;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Outfit',-apple-system,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --radius:10px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg-dark)}
body{font-family:var(--sans);font-weight:300;font-size:15px;line-height:1.6;background:var(--bg-dark);color:var(--ink);-webkit-font-smoothing:antialiased;opacity:0;transform:translateY(15px);transition:opacity 0.8s var(--ease),transform 0.8s var(--ease)}
body.loaded{opacity:1;transform:translateY(0)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--brass);color:#111}

.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}
section{position:relative}

/* ---- architectural grid overlay ---- */
.grid-overlay::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(to right,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:calc(100%/6) 100%;
}
.light.grid-overlay::before{background-image:linear-gradient(to right,rgba(0,0,0,.045) 1px,transparent 1px)}
section>.wrap{position:relative;z-index:1}

/* ---- section skins ---- */
.dark{background:var(--bg-dark);color:var(--ink)}
.darker{background:var(--bg-darker);color:var(--ink)}
.light{background:var(--bg-bone);color:var(--ink-dark)}
.linen{background:var(--bg-linen);color:var(--ink-dark)}
.pad{padding:clamp(80px,10vw,150px) 0}
.pad-sm{padding:clamp(56px,7vw,96px) 0}

/* ---- typography ---- */
.kicker{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);font-weight:500;display:inline-flex;align-items:center;gap:12px;margin-bottom:22px}
.kicker::before{content:"";width:34px;height:1px;background:var(--brass)}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.15}
.display{font-size:clamp(42px,6.5vw,92px);letter-spacing:-.01em;line-height:1.1}
.h2{font-size:clamp(32px,4.4vw,58px);line-height:1.15}
.h3{font-size:clamp(22px,2.4vw,30px);line-height:1.2}
.em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--gold);letter-spacing:0.02em;padding-right:0.05em}
.lead{font-size:clamp(15px,1.3vw,17px);color:var(--muted);max-width:56ch}
.light .lead,.linen .lead{color:#5c5c5c}
.mono-label{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:500}

/* ---- buttons ---- */
.btn{position:relative;display:inline-flex;align-items:center;gap:12px;padding:16px 34px;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;border-radius:var(--radius);cursor:pointer;overflow:hidden;transition:color .5s var(--ease),border-color .5s var(--ease),transform 0.3s;border:1px solid transparent;background:none;z-index:1}
.btn span{position:relative;z-index:2}
.btn .arr{transition:transform .5s var(--ease);position:relative;z-index:2}
.btn:hover .arr{transform:translateX(6px)}
.btn:active{transform:scale(0.97)}

.btn-gold{border:1px solid var(--gold);color:var(--gold)}
.btn-gold::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--brass),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease);z-index:0}
.btn-gold:hover::before{transform:scaleX(1)}
.btn-gold:hover{color:#141414;border-color:transparent}

.btn-outline{border-color:rgba(200,146,44,.55);color:var(--ink)}
.btn-outline::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--brass),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease);z-index:0}
.btn-outline:hover::before{transform:scaleX(1)}
.btn-outline:hover{color:#141414;border-color:transparent}
.light .btn-outline,.linen .btn-outline{color:var(--ink-dark)}

/* ---- header ---- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;transition:background .5s var(--ease),border-color .5s var(--ease),backdrop-filter .5s;border-bottom:1px solid transparent;background:transparent}
.site-header.scrolled{background:rgba(20,20,20,0.75);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,0.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px clamp(20px,4vw,56px);gap:20px}
.brand{display:flex;align-items:center;color:#fff}
.brand img{height:36px;width:auto;display:block;transition:height .3s var(--ease)}
.brand-mark{width:34px;height:34px;border:1px solid var(--brass);border-radius:8px;display:grid;place-items:center;color:var(--gold);font-family:var(--sans);font-weight:600;font-size:13px;background:linear-gradient(160deg,rgba(212,175,55,.16),transparent)}
.brand small{display:block;font-family:var(--sans);font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted-light)}
.header-actions{display:flex;align-items:center;gap:14px}
.phone-pill{font-size:12px;letter-spacing:.08em;padding:11px 20px;border:1px solid rgba(200,146,44,.5);border-radius:var(--radius);color:var(--ink);transition:border-color .4s,color .4s}
.phone-pill:hover{border-color:var(--gold);color:var(--gold)}
.phone-pill-2{margin-left:-4px}
.btn-quote{padding:12px 24px;font-size:11px}
.burger{width:46px;height:46px;border:1px solid var(--line-d);border-radius:var(--radius);background:rgba(255,255,255,.02);display:grid;place-items:center;cursor:pointer;gap:0;transition:border-color .4s}
.burger:hover{border-color:var(--brass)}
.burger i{display:block;width:18px;height:1.5px;background:var(--ink);margin:3px 0;transition:transform .45s var(--ease),opacity .3s}
.menu-open .burger i:nth-child(1){transform:translateY(4.5px) rotate(45deg)}
.menu-open .burger i:nth-child(2){transform:translateY(-4.5px) rotate(-45deg)}

/* ---- menu overlay ---- */
.menu-overlay{position:fixed;inset:0;z-index:80;background:rgba(14,14,14,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);opacity:0;visibility:hidden;transition:opacity .55s var(--ease),visibility .55s;overflow-y:auto}
.menu-open .menu-overlay{opacity:1;visibility:visible}
.menu-inner{max-width:1280px;margin:0 auto;padding:140px clamp(20px,4vw,56px) 80px;display:grid;grid-template-columns:1.2fr 1fr;gap:60px}
.menu-col .mono-label{margin-bottom:24px;display:block}
.menu-main a{display:block;font-family:var(--serif);font-size:clamp(30px,4vw,52px);line-height:1.25;color:var(--ink);transition:color .35s,transform .45s var(--ease)}
.menu-main a:hover{color:var(--gold);transform:translateX(10px)}
.menu-products{columns:2;column-gap:40px}
.menu-products a{display:block;padding:9px 0;font-size:14px;color:var(--muted-light);border-bottom:1px solid var(--line-d);transition:color .3s,padding-left .4s var(--ease)}
.menu-products a:hover{color:var(--gold);padding-left:8px}

/* ---- hero ---- */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;z-index:1}
.hero-bg{position:absolute;inset:0;transform:scale(1.05);animation:heroScale 2.4s var(--ease) forwards;z-index:1;background-size:cover;background-position:center}
.hero-fallback{position:absolute;inset:0;background-size:cover;background-position:center;z-index:1}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;display:none;opacity:0;transition:opacity 1.2s ease-in-out}
.hero-video-desktop{display:block}
.hero-video.active{opacity:1}
@media(max-width:900px){
  .hero-video-desktop{display:none}
  .hero-video-mobile{display:block}
}
@keyframes heroScale{to{transform:scale(1)}}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(12,12,12,.70) 0%,rgba(12,12,12,.34) 45%,rgba(12,12,12,.26) 100%);z-index:2;transform:translateZ(0);pointer-events:none}
.hero .wrap{position:relative;z-index:3;padding-bottom:40px;padding-top:160px}
.hero-sub{margin-top:28px;display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.hero .display, .p-hero .display {
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.hero .lead, .p-hero .lead {
  color: rgba(255,255,255,0.85);
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}

/* ---- lead capture bar ---- */
.lead-bar{position:relative;z-index:3;margin-top:56px;background:rgba(22,22,22,.6);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--line-d);border-radius:14px;display:grid;grid-template-columns:1fr 1fr auto;gap:0;overflow:hidden}
.lead-bar>div{padding:22px 26px;border-right:1px solid var(--line-d)}
.lead-bar select{width:100%;background:transparent;border:none;color:var(--ink);font-family:var(--sans);font-size:14px;margin-top:6px;outline:none;cursor:pointer}
.lead-bar select option{background:#1a1a1a}
.lead-bar .lead-cta{display:flex;align-items:stretch;border-right:none;padding:0}
.lead-bar .btn{border-radius:0;height:100%;padding:0 40px}

/* ---- metrics ---- */
.metrics{background:var(--bg-darker) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="120" height="120"><path d="M30 0v120M60 0v120M90 0v120" stroke="rgba(255,255,255,0.04)" stroke-width="1"/></svg>')}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:left}
.metric .num{font-family:var(--serif);font-size:clamp(48px,5.6vw,84px);line-height:1;color:#fff}
.metric .num b{color:var(--gold);font-weight:500}
.metric .mono-label{margin-top:14px;display:block}

/* ---- cards ---- */
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{border:1px solid var(--line-l);border-radius:var(--radius);padding:36px 28px;background:rgba(255,255,255,.55);backdrop-filter:blur(12px);transition:transform .6s var(--ease),border-color .5s,box-shadow .6s}
.dark .card,.darker .card{border-color:var(--line-d);background:rgba(255,255,255,.03)}
.card:hover{transform:translateY(-6px);border-color:rgba(200,146,44,.5);box-shadow:0 30px 60px -30px rgba(0,0,0,.25)}
.card .plus{width:40px;height:40px;border:1px solid rgba(200,146,44,.55);border-radius:9px;display:grid;place-items:center;color:var(--brass);font-size:19px;font-weight:400;margin-bottom:24px;transition:transform .55s var(--ease),background .4s}
.card:hover .plus{transform:rotate(45deg);background:rgba(212,175,55,.1)}
.card h3{font-size:19px;font-family:var(--sans);font-weight:500;letter-spacing:.02em;margin-bottom:10px}
.card p{font-size:13.5px;color:#6a6a6a;line-height:1.65}
.dark .card p,.darker .card p{color:var(--muted)}

/* ---- showcase banner ---- */
.banner{min-height:72vh;display:flex;align-items:flex-end;position:relative;overflow:hidden}
.banner .banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.88),rgba(10,10,10,.15) 60%)}
.banner .wrap{position:relative;z-index:2;padding-bottom:70px;padding-top:120px}
.banner .display{color:#fff}

/* ---- category slider ---- */
.cats{display:flex;gap:16px;min-height:540px}
.cat{position:relative;flex:1;border-radius:14px;overflow:hidden;cursor:pointer;transition:flex .8s var(--ease);border:1px solid var(--line-d);display:flex;align-items:flex-end}
.cat:hover{flex:2.2}
.cat .cat-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1s var(--ease)}
.cat:hover .cat-bg{transform:scale(1.04)}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.92),rgba(10,10,10,.1) 65%)}
.cat-body{position:relative;z-index:2;padding:34px}
.cat-body h3{font-size:clamp(22px,2.2vw,30px);color:#fff;margin:10px 0 8px}
.cat-body p{font-size:13.5px;color:var(--muted-light);max-width:42ch;opacity:0;transform:translateY(12px);transition:opacity .6s var(--ease) .15s,transform .6s var(--ease) .15s}
.cat:hover .cat-body p{opacity:1;transform:translateY(0)}

/* ---- trust strip ---- */
.trust-strip{display:flex;flex-wrap:wrap;gap:14px 44px;align-items:center;justify-content:center;padding:34px 0;border-top:1px solid var(--line-l);border-bottom:1px solid var(--line-l)}
.dark .trust-strip,.darker .trust-strip{border-color:var(--line-d)}
.trust-strip span{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:#9a9a9a;font-weight:500;filter:grayscale(1);transition:color .35s,filter .35s}
.trust-strip span:hover{color:var(--brass);filter:none}
.trust-badge{display:flex;flex-direction:column;align-items:center;gap:8px;color:#9a9a9a;transition:color .35s var(--ease);filter:none}
.trust-badge svg{opacity:.55;transition:opacity .35s var(--ease),color .35s var(--ease);color:inherit}
.trust-badge:hover{color:var(--gold)}
.trust-badge:hover svg{opacity:1;color:var(--gold)}
.trust-badge small{font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;color:inherit}

/* ---- testimonials ---- */
.proof-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:26px}
.video-card{position:relative;border-radius:14px;overflow:hidden;min-height:420px;border:1px solid rgba(200,146,44,.4);background-size:cover;background-position:center;display:flex;align-items:flex-end}
.video-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.85),transparent 60%)}
.video-card .vc-body{position:relative;z-index:2;padding:30px;color:#fff}
.play{width:64px;height:64px;border-radius:50%;border:1px solid var(--gold);display:grid;place-items:center;color:var(--gold);background:rgba(16,16,16,.4);backdrop-filter:blur(8px);margin-bottom:18px;font-size:18px;transition:transform .5s var(--ease),background .4s}
.video-card:hover .play{transform:scale(1.08);background:rgba(212,175,55,.18)}
.reviews{display:grid;gap:18px}
.review{border:1px solid var(--line-l);border-radius:var(--radius);background:#fff;padding:26px 28px}
.review .stars{color:var(--gold);letter-spacing:3px;font-size:13px;margin-bottom:12px}
.review p{font-size:14px;color:#4d4d4d;font-style:italic;line-height:1.7}
.review .who{margin-top:14px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#9a9a9a;font-weight:500}

/* ---- FAQ ---- */
.faq-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
.faq-item{border-bottom:1px solid var(--line-l)}
.dark .faq-item,.darker .faq-item{border-color:var(--line-d)}
.faq-q{width:100%;background:none;border:none;font-family:var(--sans);text-align:left;display:flex;justify-content:space-between;align-items:center;gap:24px;padding:26px 4px;font-size:16px;font-weight:400;color:inherit;cursor:pointer}
.faq-q .chev{flex:none;width:34px;height:34px;border:1px solid rgba(200,146,44,.5);border-radius:8px;display:grid;place-items:center;color:var(--brass);transition:transform .5s var(--ease),background .4s;font-size:13px}
.faq-item.open .faq-q .chev{transform:rotate(180deg);background:rgba(212,175,55,.12)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .6s var(--ease)}
.faq-a p{padding:0 4px 26px;font-size:14px;color:#6a6a6a;max-width:64ch;line-height:1.7}
.dark .faq-a p,.darker .faq-a p{color:var(--muted)}

/* ---- forms ---- */
.field{position:relative;margin-bottom:34px}
.field input,.field select,.field textarea{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(140,140,140,.4);padding:12px 2px;font-family:var(--sans);font-size:15px;color:inherit;outline:none;transition:border-color .4s;resize:vertical}
.field select option{background:#1a1a1a;color:#eee}
.light .field select option,.linen .field select option{background:#fff;color:#222}
.field label{position:absolute;left:2px;top:12px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);pointer-events:none;transition:top .4s var(--ease),font-size .4s,color .4s}
.field input:focus,.field textarea:focus,.field select:focus{border-bottom-color:var(--gold)}
.field input:focus+label,.field input:not(:placeholder-shown)+label,.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{top:-14px;font-size:10px;color:var(--brass)}
.field.has-value label,.field select:focus+label{top:-14px;font-size:10px;color:var(--brass)}

/* ---- consult CTA ---- */
.consult{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:16px;overflow:hidden;border:1px solid var(--line-d)}
.consult-img{background-size:cover;background-position:center;min-height:520px}
.consult-form{background:rgba(255,255,255,.04);backdrop-filter:blur(12px);padding:clamp(44px, 5.5vw, 80px)}

/* ---- split / overview ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.split .img-reveal{border-radius:14px;overflow:hidden;border:1px solid var(--line-l)}
.dark .split .img-reveal,.darker .split .img-reveal{border-color:var(--line-d)}

/* ---- gallery ---- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.g-item{border-radius:12px;overflow:hidden;position:relative;border:1px solid var(--line-l)}
.g-item img{height:340px;width:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.g-item:hover img{transform:scale(1.03)}
.g-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 20px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:linear-gradient(to top,rgba(10,10,10,.8),transparent)}

/* ---- image reveal / motion ---- */
.img-reveal {
  position: relative;
  overflow: hidden;
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  transition: clip-path 1.4s var(--ease);
}
.img-reveal.in {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
.img-reveal img {
  transform: scale(1.15);
  transition: transform 1.6s var(--ease);
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.img-reveal.in img {
  transform: scale(1);
}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.12s}.reveal-d2{transition-delay:.24s}.reveal-d3{transition-delay:.36s}
.split-lines .line{display:block;overflow:hidden;padding-top:4px;margin-top:-4px}
.split-lines .line>span{display:block;transform:translateY(110%);transition:transform 1s var(--ease);padding-bottom:2px}
.split-lines.in .line>span{transform:none}
.split-lines .line:nth-child(2)>span{transition-delay:.1s}
.split-lines .line:nth-child(3)>span{transition-delay:.2s}

/* ---- product hero ---- */
.p-hero{min-height:78vh;display:flex;align-items:flex-end;position:relative;overflow:hidden;z-index:1}
.p-hero .hero-bg{animation:none;transform:scale(1);z-index:1}
.p-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.7) 50%, rgba(12,12,12,0.98) 100%);z-index:2;transform:translateZ(0);pointer-events:none}
.p-hero .wrap{position:relative;z-index:3;padding-top:150px;padding-bottom:64px;text-align:left;width:100%}
.hero .btn-gold, .p-hero .btn-gold {
  background: rgba(16, 16, 16, 0.5) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-color: var(--gold);
}

/* ---- offices / contact ---- */
.office-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.office{border:1px solid var(--line-l);border-radius:var(--radius);padding:28px 24px;background:#fff;color:var(--ink-dark)}
.office h3{font-family:var(--sans);font-size:15px;font-weight:500;margin:14px 0 8px}
.office p{font-size:13px;color:#6a6a6a;line-height:1.7}
.office a{color:var(--brass)}
.region-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.india-visual{font-family:var(--serif);font-size:clamp(40px,5.4vw,76px);line-height:1.05}

/* ---- footer ---- */
.site-footer{background:#fff;color:var(--ink-dark);border-top:1px solid var(--line-l)}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1.3fr 1fr;gap:44px;padding:clamp(56px,7vw,90px) 0 48px}
.site-footer h4{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);font-weight:600;margin-bottom:20px}
.site-footer li{list-style:none;margin-bottom:10px}
.site-footer li a{font-size:14px;color:#555;transition:color .3s,padding-left .35s var(--ease)}
.site-footer li a:hover{color:var(--brass);padding-left:6px}
.footer-map{border:1px solid var(--line-l);border-radius:var(--radius);overflow:hidden;filter:grayscale(1);height:180px}
.footer-map iframe{width:100%;height:100%;border:0}
.footer-bottom{border-top:1px solid var(--line-l);padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:12px;color:#8a8a8a}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;border:1px solid var(--line-l);border-radius:9px;display:grid;place-items:center;color:#555;transition:border-color .35s,color .35s,transform .45s var(--ease)}
.socials a:hover{border-color:var(--brass);color:var(--brass);transform:translateY(-3px)}
.whatsapp-fab{position:fixed;right:24px;bottom:24px;z-index:70;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:0 18px 40px -12px rgba(37,211,102,.55);transition:transform .5s var(--ease)}
.whatsapp-fab:hover{transform:translateY(-4px) scale(1.05)}
.whatsapp-fab svg{width:22px;height:22px}

/* ---- gold banner ---- */
.gold-banner{background:linear-gradient(120deg,var(--brass),var(--gold));color:#191308}
.gold-banner .h2,.gold-banner p{color:#191308}

/* ---- carousel ---- */
.carousel{position:relative}
.carousel-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding-bottom:8px}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-track>*{scroll-snap-align:start;flex:0 0 min(420px,82vw)}
.carousel-nav{display:flex;gap:12px;margin-top:26px}
.carousel-nav button{width:48px;height:48px;border-radius:10px;border:1px solid rgba(200,146,44,.55);background:transparent;color:var(--brass);font-size:16px;cursor:pointer;transition:background .35s,color .35s}
.carousel-nav button:hover{background:var(--brass);color:#141414}
.quote-card{border:1px solid var(--line-l);border-radius:12px;background:#fff;padding:34px 30px}
.quote-card .qq{font-family:var(--serif);font-size:64px;line-height:.6;color:var(--gold)}
.quote-card p{font-size:14.5px;color:#4d4d4d;font-style:italic;margin:18px 0;line-height:1.75}

/* ---- responsive ---- */
@media(min-width:1024px){
  .light.pad, .linen.pad {
    padding: 120px 0;
  }
}
@media(max-width:1080px){
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .office-grid{grid-template-columns:repeat(3,1fr)}
  .metrics-grid{grid-template-columns:repeat(2,1fr);gap:52px 32px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px) {
  .header-inner {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    padding: 12px clamp(20px, 4vw, 56px);
  }
  .burger {
    grid-column: 1;
    justify-self: start;
  }
  .brand {
    grid-column: 2;
    justify-self: center;
    margin: 0 auto;
  }
  .brand img{height:28px}
  .header-actions {
    grid-column: 3;
    justify-self: end;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .phone-pill-2 {
    display: none !important;
  }
  .phone-pill {
    display: inline-flex !important;
    padding: 8px 14px;
    font-size: 11px;
  }
  .btn-quote {
    display: none !important;
  }
  .split,.proof-grid,.faq-layout,.consult{grid-template-columns:1fr}
  .cats{flex-direction:column;min-height:0}
  .cat{min-height:260px}
  .cat:hover{flex:1.6}
  .cat-body p{opacity:1;transform:none}
  .lead-bar{grid-template-columns:1fr}
  .lead-bar>div{border-right:none;border-bottom:1px solid var(--line-d)}
  .lead-bar .btn{width:100%;padding:20px;justify-content:center}
  .menu-inner{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .region-grid{grid-template-columns:repeat(2,1fr)}
  .consult-img{min-height:320px}
  .p-hero .wrap{padding-top:120px;padding-bottom:40px}
}
@media(max-width:767px) {
  .display { font-size: clamp(32px, 5.5vw, 68px) !important; }
  .h2 { font-size: clamp(26px, 4vw, 42px) !important; }
  .h3 { font-size: clamp(18px, 2.5vw, 24px) !important; }
}
@media(max-width:640px) {
  .card-grid,.office-grid{grid-template-columns:1fr !important; gap: 24px !important;}
  .metrics-grid{grid-template-columns:1fr 1fr;gap:40px 24px}
  .footer-grid{grid-template-columns:1fr}
  .menu-products{columns:1}
  .region-grid{grid-template-columns:1fr !important; gap: 24px !important;}
  .g-item img{height:260px}
}

/* ============================================================
   GALLERY PAGE & DYNAMIC LIGHTBOX
   ============================================================ */
.gallery-filter {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-top: 40px;
  margin-bottom: 50px;
  flex-wrap: wrap;
}
.gallery-tab {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--line-d);
  color: var(--muted-light);
  padding: 11px 26px;
  font-family: var(--sans);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: 30px;
  cursor: pointer;
  transition: all 0.4s var(--ease);
}
.gallery-tab:hover {
  border-color: rgba(200, 146, 44, 0.5);
  color: var(--gold);
}
.gallery-tab.active {
  background: linear-gradient(135deg, var(--brass), var(--gold));
  color: #141414;
  border-color: transparent;
  box-shadow: 0 8px 20px -6px rgba(200, 146, 44, 0.4);
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 120px;
}
.gallery-card {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line-d);
  background: rgba(255, 255, 255, 0.02);
  cursor: pointer;
  aspect-ratio: 4/3;
  transition: transform 0.6s var(--ease), border-color 0.5s, box-shadow 0.6s;
}
.gallery-card:hover {
  transform: translateY(-6px);
  border-color: rgba(200, 146, 44, 0.5);
  box-shadow: 0 20px 40px -20px rgba(0,0,0,0.6);
}
.gallery-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.gallery-card img, .gallery-card video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease);
}
.gallery-card:hover img, .gallery-card:hover video {
  transform: scale(1.05);
}

/* Video indicators */
.video-badge {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(20, 20, 20, 0.7);
  border: 1px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  font-size: 16px;
  z-index: 2;
  transition: transform 0.4s var(--ease), background 0.4s, color 0.4s;
  pointer-events: none;
}
.gallery-card:hover .video-badge {
  transform: translate(-50%, -50%) scale(1.1);
  background: var(--gold);
  color: #141414;
}

.gallery-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 30px 24px 20px;
  z-index: 2;
  background: linear-gradient(to top, rgba(16, 16, 16, 0.95) 0%, rgba(16, 16, 16, 0.4) 60%, transparent 100%);
  transform: translateY(10px);
  opacity: 0;
  transition: transform 0.5s var(--ease), opacity 0.5s var(--ease);
}
.gallery-card:hover .gallery-caption {
  transform: translateY(0);
  opacity: 1;
}
.gallery-caption h4 {
  font-size: 14px;
  font-family: var(--sans);
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #fff;
  margin-bottom: 4px;
}
.gallery-caption span {
  font-size: 10px;
  font-family: var(--sans);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 500;
}

/* ---- Lightbox Modal ---- */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 10, 0.96);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s var(--ease), visibility 0.5s var(--ease);
  display: flex;
  align-items: center;
  justify-content: center;
}
.lightbox.active {
  opacity: 1;
  visibility: visible;
}
.lightbox-content {
  position: relative;
  max-width: 80vw;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transform: scale(0.95);
  transition: transform 0.5s var(--ease);
}
.lightbox.active .lightbox-content {
  transform: scale(1);
}
.lightbox-media {
  max-width: 100%;
  max-height: 70vh;
  border-radius: 12px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.85);
  border: 1px solid var(--line-d);
  display: block;
}
.lightbox-caption {
  margin-top: 24px;
  color: #fff;
  font-family: var(--sans);
  font-size: 14.5px;
  letter-spacing: 0.04em;
  text-align: center;
  max-width: 60ch;
  line-height: 1.5;
}
.lightbox-close {
  position: absolute;
  top: 30px;
  right: 30px;
  background: transparent;
  border: none;
  color: var(--muted-light);
  font-size: 24px;
  cursor: pointer;
  transition: all 0.3s;
  z-index: 1010;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--line-d);
}
.lightbox-close:hover {
  color: var(--gold);
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(200,146,44,0.4);
}
.lightbox-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--line-d);
  color: var(--muted-light);
  width: 60px;
  height: 60px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  cursor: pointer;
  transition: all 0.4s var(--ease);
  z-index: 1010;
}
.lightbox-arrow:hover {
  background: var(--gold);
  color: #141414;
  border-color: transparent;
  box-shadow: 0 8px 24px rgba(200, 146, 44, 0.35);
}
.lightbox-arrow.prev {
  left: 40px;
}
.lightbox-arrow.next {
  right: 40px;
}

@media(max-width:1024px) {
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}
@media(max-width:900px) {
  .gallery-grid {
    margin-bottom: 80px;
  }
  .lightbox-arrow {
    bottom: 24px;
    top: auto;
    transform: none;
    width: 50px;
    height: 50px;
    border-radius: 10px;
  }
  .lightbox-arrow.prev {
    left: calc(50% - 60px);
  }
  .lightbox-arrow.next {
    right: calc(50% - 60px);
  }
  .lightbox-content {
    max-width: 90vw;
    max-height: 60vh;
  }
}
@media(max-width:640px) {
  .gallery-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .gallery-filter {
    margin-bottom: 30px;
    gap: 10px;
  }
  .gallery-tab {
    padding: 8px 18px;
    font-size: 10.5px;
  }
}

