/* ===== IZONEX PRODUCTION — Shared Premium Styles ===== */
:root{
  --ink:#0C0907;
  --ink-2:#15100A;
  --panel:#1A130C;
  --gold:#C6A24E;
  --gold-bright:#E9D3A0;
  --champagne:#F0E4C9;
  --cream:#F3EAD8;
  --muted:#A4937A;
  --line:rgba(198,162,78,.22);
  --line-soft:rgba(198,162,78,.12);
  --wa:#25D366;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--ink);color:var(--cream);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 26px}
.section{padding:clamp(64px,9vw,110px) 0;position:relative}
.center{text-align:center}
.display{font-family:'Cormorant Garamond',serif}
.eyebrow{font-size:12.5px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);font-weight:500;display:inline-block;margin-bottom:18px}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:.5px;line-height:1.08;color:var(--cream)}
.title{font-size:clamp(32px,5.2vw,56px)}
.title em,h1 em,h2 em{font-style:italic;color:var(--gold-bright)}
.lead{color:#D6CBB6;font-weight:300;font-size:clamp(15px,1.7vw,17px);max-width:600px}
.center .lead{margin-left:auto;margin-right:auto}
p{color:#D2C7B2;font-weight:300}

.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:2px;font-family:'Jost',sans-serif;font-size:14px;letter-spacing:.06em;text-transform:uppercase;font-weight:500;cursor:pointer;border:1px solid transparent;transition:.28s ease}
.btn-gold{background:var(--gold);color:#1a1206}
.btn-gold:hover{background:var(--gold-bright);transform:translateY(-2px)}
.btn-line{background:transparent;border-color:var(--line);color:var(--cream)}
.btn-line:hover{border-color:var(--gold);color:var(--gold-bright);transform:translateY(-2px)}
.btn svg{width:17px;height:17px}

/* NAV */
header.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 0;transition:.35s ease;border-bottom:1px solid transparent}
header.nav.scrolled{background:rgba(10,7,5,.9);backdrop-filter:blur(12px);padding:11px 0;border-bottom:1px solid var(--line-soft)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-logo{height:62px;width:auto;transition:transform .35s ease, height .35s ease;animation:logoGlow 3.8s ease-in-out infinite;transform-origin:center}
.nav-logo:hover{transform:scale(1.07)}
@keyframes logoGlow{0%,100%{filter:drop-shadow(0 0 0 rgba(233,211,160,0))}50%{filter:drop-shadow(0 0 9px rgba(233,211,160,.6))}}
header.nav.scrolled .nav-logo{height:52px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links>li{list-style:none;position:relative}
.nav-links a{font-size:14px;letter-spacing:.03em;color:#D8CDB9;transition:.2s;display:inline-flex;align-items:center;gap:5px}
.nav-links a:hover{color:var(--gold-bright)}
.has-drop>a::after{content:'';width:5px;height:5px;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg);margin-left:3px;margin-top:-2px}
.drop{position:absolute;top:130%;left:50%;transform:translateX(-50%);background:rgba(14,10,7,.98);border:1px solid var(--line-soft);min-width:230px;padding:10px 0;opacity:0;visibility:hidden;transition:.25s;backdrop-filter:blur(10px)}
.nav-links>li:hover .drop{opacity:1;visibility:visible;top:120%}
.drop a{display:block;padding:9px 22px;font-size:13.5px;color:#C9BEAA}
.drop a:hover{background:rgba(198,162,78,.1);color:var(--gold-bright)}
.nav-cta{padding:11px 22px!important;font-size:13px;border-radius:2px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--cream);transition:.3s}
.mobile-menu{position:fixed;inset:0;background:rgba(8,6,4,.98);z-index:99;padding:90px 28px 40px;overflow-y:auto;opacity:0;visibility:hidden;transition:.35s}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{display:block;font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--cream);padding:12px 0;border-bottom:1px solid var(--line-soft)}
.mobile-menu .sub{font-size:16px;color:var(--muted);padding-left:18px;font-family:'Jost'}

/* PAGE HERO (inner pages) */
.page-hero{min-height:62vh;display:flex;align-items:center;position:relative;text-align:center;background-size:cover;background-position:center}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.7),rgba(8,6,4,.88))}
.page-hero .container{position:relative;z-index:2;padding:120px 26px 60px}
.page-hero h1{font-size:clamp(40px,7vw,76px);margin-bottom:16px}
.page-hero .lead{margin:0 auto}
.crumb{font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:22px}
.crumb a{color:var(--gold)}

/* HOME HERO */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;background:linear-gradient(180deg,rgba(8,6,4,.55),rgba(8,6,4,.72) 55%,rgba(8,6,4,.95)),url('https://www.izonexproduction.com/images/hero-bg.jpg') center/cover no-repeat}
.hero::before{content:'';position:absolute;inset:26px;border:1px solid var(--line);pointer-events:none}
.hero-inner{position:relative;z-index:3;max-width:820px;padding:120px 0 60px}
.hero h1{font-size:clamp(46px,8.5vw,90px);margin:14px 0 22px}
.hero p{font-size:clamp(16px,2vw,19px);color:#E0D6C2;font-weight:300;max-width:560px;margin-bottom:36px}
.hero-btns{display:flex;flex-wrap:wrap;gap:14px}

/* GRIDS / CARDS */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:54px;background:var(--line-soft);border:1px solid var(--line-soft)}
.svc{background:var(--ink-2);padding:36px 26px;transition:.3s;display:block}
.svc:hover{background:var(--panel)}
.svc .ic{width:34px;height:34px;color:var(--gold);margin-bottom:18px}
.svc h3{font-size:23px;font-weight:600;margin-bottom:9px}
.svc p{font-size:14px;color:var(--muted)}
.svc .more{display:inline-block;margin-top:14px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}

.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.card{background:var(--ink-2);border:1px solid var(--line-soft);overflow:hidden;transition:.3s}
.card:hover{border-color:var(--line);transform:translateY(-4px)}
.card .ph{aspect-ratio:4/3;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.6s}
.card:hover .ph img{transform:scale(1.07)}
.card .bd{padding:28px 26px}
.card h3{font-size:25px;font-weight:600;margin-bottom:10px}
.card p{font-size:14.5px;color:var(--muted);margin-bottom:16px}
.card .more{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}

/* function/list pills */
.list-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:50px}
.list-item{background:var(--ink-2);border:1px solid var(--line-soft);padding:26px 24px;transition:.3s;display:flex;flex-direction:column;gap:8px}
.list-item:hover{border-color:var(--gold);background:var(--panel)}
.list-item h3{font-size:22px;font-weight:600}
.list-item p{font-size:13.5px;color:var(--muted)}
.list-item .more{margin-top:auto;padding-top:8px;font-size:11.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}

/* STATS */
.stats{background:var(--panel);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat .num{font-family:'Cormorant Garamond',serif;font-size:clamp(38px,6vw,60px);font-weight:600;color:var(--gold-bright);line-height:1}
.stat .lab{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:12px}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;margin-top:50px;background:var(--line-soft);border:1px solid var(--line-soft)}
.why-item{background:var(--ink);padding:38px 34px;display:flex;gap:20px;align-items:flex-start}
.why-item .n{font-family:'Cormorant Garamond',serif;font-size:30px;color:var(--gold);font-style:italic;line-height:1;min-width:40px}
.why-item h3{font-size:22px;font-weight:600;margin-bottom:7px}
.why-item p{font-size:14px;color:var(--muted)}

/* SPLIT content */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split .img{aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line-soft)}
.split .img img{width:100%;height:100%;object-fit:cover}
.split.rev .txt{order:2}
.prose p{margin-bottom:16px;font-size:15.5px;line-height:1.75}
.prose h2{margin:8px 0 18px}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery .g{aspect-ratio:1/1;overflow:hidden}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gallery .g:hover img{transform:scale(1.08)}

/* TESTIMONIALS */
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.t-card{background:var(--panel);border:1px solid var(--line-soft);padding:36px 30px}
.t-card .qm{font-family:'Cormorant Garamond',serif;font-size:64px;color:var(--gold);opacity:.35;line-height:.6;height:32px}
.t-card p{font-size:15px;color:#D6CBB6;font-style:italic;font-weight:300;font-family:'Cormorant Garamond',serif;line-height:1.6}
.t-who{display:flex;align-items:center;gap:14px;margin-top:22px;padding-top:20px;border-top:1px solid var(--line-soft)}
.t-who img{width:46px;height:46px;border-radius:50%;object-fit:cover}
.t-who .nm{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--cream)}
.t-who .rl{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px}
.member{text-align:center}
.member .ph{aspect-ratio:1/1;overflow:hidden;border:1px solid var(--line-soft);margin-bottom:16px}
.member .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(.4);transition:.5s}
.member:hover .ph img{filter:grayscale(0);transform:scale(1.05)}
.member h3{font-size:22px;font-weight:600}
.member p{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}

/* FAQ */
.faq-wrap{max-width:820px;margin:46px auto 0}
.faq{border-bottom:1px solid var(--line-soft)}
.faq-q{width:100%;background:none;border:0;color:var(--cream);font-family:'Cormorant Garamond',serif;font-size:clamp(19px,2.2vw,23px);text-align:left;padding:22px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q .pm{color:var(--gold);font-size:24px;font-family:'Jost';font-weight:300;transition:.3s;flex-shrink:0}
.faq.active .pm{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{color:var(--muted);font-size:15px;padding:0 0 22px}

/* CITIES */
.city-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:46px}
.city{background:var(--ink-2);border:1px solid var(--line-soft);padding:22px;text-align:center;transition:.3s}
.city:hover{border-color:var(--gold);background:var(--panel)}
.city .cn{font-family:'Cormorant Garamond',serif;font-size:21px;color:var(--cream)}
.city .cs{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-top:4px}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:54px;align-items:start}
.c-row{display:flex;gap:16px;align-items:center;padding:18px 0;border-top:1px solid var(--line-soft)}
.c-row .ic{width:40px;height:40px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.c-row .ic svg{width:18px;height:18px}
.c-row .lab{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.c-row .val{font-size:15.5px;color:var(--cream)}
.form{background:var(--ink-2);border:1px solid var(--line-soft);padding:36px 32px}
.form .fr{margin-bottom:18px}
.form label{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.form input,.form select,.form textarea{width:100%;background:var(--ink);border:1px solid var(--line-soft);color:var(--cream);padding:13px 15px;font-family:'Jost';font-size:15px;border-radius:2px;transition:.25s}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--gold)}
.form textarea{resize:vertical;min-height:110px}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .btn{width:100%;justify-content:center;margin-top:6px}
.form-note{font-size:12px;color:var(--muted);text-align:center;margin-top:14px}

/* CTA BANNER */
.cta-band{text-align:center;background:linear-gradient(rgba(8,6,4,.84),rgba(8,6,4,.92)),url('https://www.izonexproduction.com/images/events-bg.jpg') center/cover no-repeat}
.cta-band h2{font-size:clamp(34px,6vw,60px)}
.cta-band p{color:#D6CBB6;margin:16px auto 30px;max-width:480px}

/* FOOTER */
footer{background:var(--ink);border-top:1px solid var(--line-soft);padding:60px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:42px}
.foot-logo{height:76px;margin-bottom:18px}
.foot-about{color:var(--muted);font-size:14px;max-width:300px}
.foot-soc{display:flex;gap:10px;margin-top:20px}
.foot-soc a{width:36px;height:36px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold);transition:.25s}
.foot-soc a:hover{background:var(--gold);color:#1a1206}
.foot-soc svg{width:16px;height:16px}
.foot-col h4{font-size:19px;color:var(--cream);margin-bottom:16px}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:13.5px;padding:5px 0;transition:.2s}
.foot-col a:hover{color:var(--gold-bright)}
.foot-bottom{border-top:1px solid var(--line-soft);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:var(--muted)}

/* FLOAT WA */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:90;width:56px;height:56px;border-radius:50%;background:var(--wa);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.4);transition:.3s;animation:wapulse 2.6s infinite}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:29px;height:29px;color:#fff}
@keyframes wapulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* REVEAL */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1024px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .cards3,.t-grid,.list-grid{grid-template-columns:repeat(2,1fr)}
  .gallery,.team-grid,.city-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .nav-links{display:none}
  .burger{display:flex}
  .why-grid,.split,.cards3,.t-grid,.list-grid,.contact-grid{grid-template-columns:1fr}
  .split.rev .txt{order:0}
  .stats-grid,.gallery,.team-grid,.city-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero::before{inset:14px}
  .form .row2{grid-template-columns:1fr}
}
@media(max-width:480px){
  .svc-grid,.cards3{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion: reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ============ PREMIUM UPGRADE LAYER ============ */

/* page loader */
#loader{position:fixed;inset:0;z-index:9999;background:var(--ink);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:22px;transition:opacity .6s ease,visibility .6s ease}
#loader.hide{opacity:0;visibility:hidden}
#loader .ld-logo{font-family:'Cormorant Garamond',serif;font-size:34px;letter-spacing:.3em;color:var(--gold-bright);text-transform:uppercase}
#loader .ld-bar{width:160px;height:2px;background:var(--line-soft);overflow:hidden;border-radius:2px}
#loader .ld-bar span{display:block;height:100%;width:40%;background:var(--gold);animation:ldslide 1s ease-in-out infinite}
@keyframes ldslide{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}

/* scroll progress */
#progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-bright));z-index:200;transition:width .1s linear}

/* custom cursor (desktop fine pointer only) */
#cursor,#cursor-dot{display:none}
@media (hover:hover) and (pointer:fine){
  body.has-cursor{cursor:none}
  body.has-cursor a,body.has-cursor button,body.has-cursor .filter,body.has-cursor .faq-q,body.has-cursor input,body.has-cursor select,body.has-cursor textarea,body.has-cursor .g,body.has-cursor .work{cursor:none}
  #cursor{display:block;position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid var(--gold);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,border-color .25s;mix-blend-mode:difference}
  #cursor.grow{width:58px;height:58px;background:rgba(198,162,78,.18);border-color:var(--gold-bright)}
  #cursor-dot{display:block;position:fixed;top:0;left:0;width:5px;height:5px;background:var(--gold-bright);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
}

/* back to top */
#toTop{position:fixed;left:20px;bottom:20px;z-index:90;width:48px;height:48px;border-radius:50%;background:rgba(20,15,9,.9);border:1px solid var(--line);color:var(--gold);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s;backdrop-filter:blur(8px)}
#toTop.show{opacity:1;visibility:visible;transform:none}
#toTop:hover{border-color:var(--gold);background:var(--panel)}
#toTop svg{width:18px;height:18px}

/* trusted by marquee */
.marquee-sec{padding:50px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--ink-2);overflow:hidden}
.marquee-sec .ttl{text-align:center;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:30px}
.marquee{display:flex;gap:60px;width:max-content;animation:scrollx 26s linear infinite}
.marquee:hover{animation-play-state:paused}
.marquee .logo{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--muted);opacity:.65;white-space:nowrap;transition:.3s;letter-spacing:.03em}
.marquee .logo:hover{color:var(--gold-bright);opacity:1}
@keyframes scrollx{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* counters keep style; add subtle */
.stat .num{transition:.3s}

/* lightbox */
#lightbox{position:fixed;inset:0;z-index:9997;background:rgba(6,4,3,.95);display:none;align-items:center;justify-content:center;padding:30px;backdrop-filter:blur(6px)}
#lightbox.open{display:flex}
#lightbox img{max-width:90vw;max-height:86vh;border:1px solid var(--line);box-shadow:0 30px 80px rgba(0,0,0,.6)}
#lightbox .lb-close{position:absolute;top:24px;right:30px;color:var(--cream);font-size:34px;font-weight:300;cursor:pointer;line-height:1}
.work,.g{cursor:pointer}

/* portrait work tiles for real images */
.work-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:50px}
.work-tile{position:relative;overflow:hidden;aspect-ratio:3/4;border:1px solid var(--line-soft)}
.work-tile img{width:100%;height:100%;object-fit:cover;transition:.7s ease}
.work-tile:hover img{transform:scale(1.07)}
.work-tile::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(8,6,4,.85));opacity:.7;transition:.3s}
.work-tile:hover::after{opacity:.95}
.work-tile .cap{position:absolute;left:18px;bottom:16px;z-index:2;font-family:'Cormorant Garamond',serif;font-size:19px;color:var(--cream);transform:translateY(8px);opacity:0;transition:.35s}
.work-tile:hover .cap{transform:none;opacity:1}
@media(max-width:1024px){.work-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.work-grid{grid-template-columns:repeat(2,1fr)}}

/* ============ FLOATING CONTACT STACK ============ */
.fab-stack{position:fixed;right:20px;bottom:20px;z-index:95;display:flex;flex-direction:column;gap:14px;align-items:center}
.fab{position:relative;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px rgba(0,0,0,.42);color:#fff;transition:transform .25s ease}
.fab svg{width:26px;height:26px}
.fab:hover{transform:scale(1.12)}
.fab-call{background:var(--gold);color:#1a1206;animation:pulseGold 2.6s infinite}
.fab-msg{background:#2f7de1;color:#fff;animation:pulseBlue 2.6s infinite .35s}
.fab-wa{background:var(--wa);color:#fff;animation:pulseGreen 2.6s infinite .7s}
/* hover label */
.fab .fab-lbl{position:absolute;right:64px;top:50%;transform:translateY(-50%) translateX(6px);background:rgba(14,10,7,.95);border:1px solid var(--line);color:var(--cream);font-family:'Jost';font-size:12px;letter-spacing:.04em;padding:6px 12px;border-radius:3px;white-space:nowrap;opacity:0;pointer-events:none;transition:.25s}
.fab:hover .fab-lbl{opacity:1;transform:translateY(-50%) translateX(0)}
@keyframes pulseGold{0%{box-shadow:0 0 0 0 rgba(198,162,78,.55),0 10px 26px rgba(0,0,0,.42)}70%{box-shadow:0 0 0 14px rgba(198,162,78,0),0 10px 26px rgba(0,0,0,.42)}100%{box-shadow:0 0 0 0 rgba(198,162,78,0),0 10px 26px rgba(0,0,0,.42)}}
@keyframes pulseBlue{0%{box-shadow:0 0 0 0 rgba(47,125,225,.55),0 10px 26px rgba(0,0,0,.42)}70%{box-shadow:0 0 0 14px rgba(47,125,225,0),0 10px 26px rgba(0,0,0,.42)}100%{box-shadow:0 0 0 0 rgba(47,125,225,0),0 10px 26px rgba(0,0,0,.42)}}
@keyframes pulseGreen{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5),0 10px 26px rgba(0,0,0,.42)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0),0 10px 26px rgba(0,0,0,.42)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0),0 10px 26px rgba(0,0,0,.42)}}
@media (prefers-reduced-motion: reduce){.fab{animation:none!important}}

/* ============ AYESHA CHAT ASSISTANT ============ */
.fab-stack{bottom:96px}            /* raise contact buttons above chat launcher */
body.chat-open .fab-stack{opacity:0;visibility:hidden;pointer-events:none}
.chat-launch{position:fixed;right:20px;bottom:20px;z-index:96;display:flex;align-items:center;gap:0;cursor:pointer}
.chat-launch .cl-btn{width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#a9842f);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px rgba(0,0,0,.45);animation:pulseGold 2.8s infinite;transition:transform .25s}
.chat-launch:hover .cl-btn{transform:scale(1.08)}
.chat-launch .cl-btn svg{width:30px;height:30px;color:#1a1206}
.chat-launch .cl-dot{position:absolute;top:6px;right:6px;width:13px;height:13px;background:#25D366;border:2px solid var(--ink);border-radius:50%}
.chat-greet{position:fixed;right:92px;bottom:30px;z-index:96;max-width:230px;background:#fff;color:#1a1206;padding:12px 15px;border-radius:14px 14px 2px 14px;box-shadow:0 12px 30px rgba(0,0,0,.35);font-family:'Jost';font-size:13.5px;line-height:1.5;opacity:0;transform:translateY(8px) scale(.96);transition:.4s;pointer-events:none}
.chat-greet.show{opacity:1;transform:none;pointer-events:auto}
.chat-greet b{color:#000}
.chat-greet .gx{position:absolute;top:-8px;right:-8px;width:22px;height:22px;background:#1a1206;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer}
body.chat-open .chat-launch,body.chat-open .chat-greet{opacity:0;visibility:hidden;pointer-events:none}

.chat-win{position:fixed;right:20px;bottom:20px;z-index:97;width:370px;max-width:calc(100vw - 32px);height:540px;max-height:calc(100vh - 90px);background:var(--ink-2);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 70px rgba(0,0,0,.6);opacity:0;visibility:hidden;transform:translateY(20px) scale(.98);transition:.32s ease;transform-origin:bottom right}
.chat-win.open{opacity:1;visibility:visible;transform:none}
.cw-head{background:linear-gradient(135deg,#1c140c,#241a0e);border-bottom:1px solid var(--line);padding:15px 16px;display:flex;align-items:center;gap:12px}
.cw-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#a9842f);display:flex;align-items:center;justify-content:center;color:#1a1206;font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;flex-shrink:0;position:relative}
.cw-av .on{position:absolute;bottom:1px;right:1px;width:11px;height:11px;background:#25D366;border:2px solid #1c140c;border-radius:50%}
.cw-hi{flex:1;min-width:0}
.cw-hi .nm{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--cream);line-height:1}
.cw-hi .st{font-size:11.5px;color:#9bdcb1;letter-spacing:.03em;margin-top:3px}
.cw-x{background:none;border:0;color:var(--muted);font-size:24px;cursor:pointer;line-height:1;padding:4px;transition:.2s}
.cw-x:hover{color:var(--cream)}
.cw-body{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:10px;background:var(--ink)}
.cw-body::-webkit-scrollbar{width:6px}.cw-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}
.msg{max-width:82%;padding:10px 14px;font-size:14px;line-height:1.5;border-radius:14px;animation:msgIn .3s ease}
.msg.bot{background:var(--panel);border:1px solid var(--line-soft);color:#e7dcc8;align-self:flex-start;border-bottom-left-radius:3px}
.msg.user{background:var(--gold);color:#1a1206;align-self:flex-end;border-bottom-right-radius:3px}
.msg a.inline{color:var(--gold-bright);text-decoration:underline}
@keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.typing{align-self:flex-start;background:var(--panel);border:1px solid var(--line-soft);padding:12px 14px;border-radius:14px;border-bottom-left-radius:3px;display:flex;gap:4px}
.typing span{width:7px;height:7px;background:var(--muted);border-radius:50%;animation:tdot 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes tdot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.cw-chips{display:flex;flex-wrap:wrap;gap:7px;padding:6px 0 2px}
.cw-chip{background:transparent;border:1px solid var(--line);color:var(--gold-bright);font-family:'Jost';font-size:12.5px;padding:7px 13px;border-radius:20px;cursor:pointer;transition:.2s}
.cw-chip:hover{background:var(--gold);color:#1a1206;border-color:var(--gold)}
.cw-cta{display:inline-flex;align-items:center;gap:8px;background:var(--wa);color:#fff;padding:10px 16px;border-radius:8px;font-size:13.5px;font-family:'Jost';font-weight:500;align-self:flex-start;margin-top:2px;text-decoration:none}
.cw-cta.gold{background:var(--gold);color:#1a1206}
.cw-cta svg{width:16px;height:16px}
.cw-foot{border-top:1px solid var(--line-soft);padding:10px;display:flex;gap:8px;align-items:center;background:var(--ink-2)}
.cw-foot input{flex:1;background:var(--ink);border:1px solid var(--line-soft);color:var(--cream);padding:11px 13px;border-radius:22px;font-family:'Jost';font-size:14px;outline:none}
.cw-foot input:focus{border-color:var(--gold)}
.cw-send{width:42px;height:42px;border-radius:50%;background:var(--gold);border:0;color:#1a1206;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:.2s}
.cw-send:hover{background:var(--gold-bright)}
.cw-send svg{width:19px;height:19px}
.cw-note{text-align:center;font-size:10.5px;color:var(--muted);padding:0 0 8px;background:var(--ink-2)}
@media(max-width:480px){
  .chat-win{right:10px;bottom:10px;height:calc(100vh - 80px)}
  .chat-greet{display:none}
}
@media (prefers-reduced-motion: reduce){.chat-launch .cl-btn{animation:none}}

/* ============ PREMIUM CITY CARDS ============ */
.city-cards{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:14px;margin-top:48px}
.ccard{position:relative;border-radius:8px;overflow:hidden;display:block;border:1px solid var(--line-soft);isolation:isolate}
.ccard.feat{grid-row:span 2}
.ccard .grad{position:absolute;inset:0;z-index:0;transition:transform .7s ease}
.ccard:hover .grad{transform:scale(1.08)}
.ccard::after{content:'';position:absolute;left:0;right:0;bottom:0;height:55%;z-index:1;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='120' viewBox='0 0 400 120'%3E%3Cg fill='%23000' opacity='0.42'%3E%3Crect x='0' y='80' width='26' height='40'/%3E%3Crect x='28' y='60' width='20' height='60'/%3E%3Crect x='50' y='72' width='16' height='48'/%3E%3Crect x='68' y='48' width='10' height='72'/%3E%3Crect x='80' y='66' width='22' height='54'/%3E%3Crect x='104' y='80' width='18' height='40'/%3E%3Cpath d='M128 120 V70 l10 -14 l10 14 V120 Z'/%3E%3Crect x='150' y='58' width='18' height='62'/%3E%3Crect x='170' y='74' width='24' height='46'/%3E%3Crect x='196' y='52' width='8' height='68'/%3E%3Crect x='206' y='68' width='20' height='52'/%3E%3Crect x='228' y='80' width='16' height='40'/%3E%3Ccircle cx='262' cy='62' r='14'/%3E%3Crect x='258' y='62' width='8' height='58'/%3E%3Crect x='276' y='56' width='18' height='64'/%3E%3Crect x='296' y='72' width='22' height='48'/%3E%3Crect x='320' y='60' width='10' height='60'/%3E%3Crect x='332' y='76' width='24' height='44'/%3E%3Crect x='358' y='66' width='18' height='54'/%3E%3Crect x='378' y='82' width='22' height='38'/%3E%3C/g%3E%3C/svg%3E") repeat-x bottom/auto 100%;
  pointer-events:none;transition:transform .7s ease}
.ccard:hover::after{transform:translateY(4px) scale(1.03)}
.ccard::after{display:none}
.ccard .veil{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(8,6,4,.05) 0%,rgba(8,6,4,.15) 45%,rgba(8,6,4,.92) 100%)}
.ccard .tx{position:absolute;left:20px;right:16px;bottom:18px;z-index:3}
.ccard .cn{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:27px;color:#fff;line-height:1;letter-spacing:.5px;text-shadow:0 2px 10px rgba(0,0,0,.4)}
.ccard.feat .cn{font-size:36px}
.ccard .cr{font-size:12.5px;color:#f3e7cf;letter-spacing:.05em;margin-top:7px;opacity:.92}
.ccard .go{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);opacity:0;transform:translateY(6px);transition:.3s}
.ccard:hover .go{opacity:1;transform:none}
.ccard .badge{position:absolute;top:14px;left:14px;z-index:3;background:var(--gold);color:#1a1206;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;padding:5px 11px;border-radius:3px;font-family:'Jost'}
@media(max-width:1024px){.city-cards{grid-template-columns:repeat(3,1fr)}.ccard.feat{grid-row:span 2}}
@media(max-width:768px){.city-cards{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}.ccard.feat{grid-row:span 1}.ccard.feat .cn{font-size:27px}}
@media(max-width:480px){.city-cards{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}}

/* ============ TESTIMONIALS MARQUEE ============ */
.tm-wrap{margin-top:48px;display:flex;flex-direction:column;gap:20px}
.tm-row{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.tm-track{display:flex;gap:18px;width:max-content;animation:tmScroll 64s linear infinite}
.tm-track.rev{animation-duration:78s;animation-direction:reverse}
.tm-row:hover .tm-track{animation-play-state:paused}
.tm-card{width:330px;flex-shrink:0;background:var(--panel);border:1px solid var(--line-soft);border-radius:10px;padding:24px 24px 20px;display:flex;flex-direction:column}
.tm-card:hover{border-color:var(--line)}
.tm-stars{color:var(--gold);font-size:13px;letter-spacing:3px;margin-bottom:12px}
.tm-card .rv{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:16px;line-height:1.55;color:#ddd2bd;flex:1}
.tm-who{display:flex;align-items:center;gap:12px;margin-top:18px;padding-top:15px;border-top:1px solid var(--line-soft)}
.tm-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#a9842f);color:#1a1206;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-weight:700;font-size:19px;flex-shrink:0}
.tm-nm{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--cream);line-height:1.1}
.tm-rl{font-size:11px;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-top:3px}
@keyframes tmScroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 9px))}}
@media(max-width:480px){.tm-card{width:280px}}
@media (prefers-reduced-motion: reduce){.tm-track{animation:none}.tm-row{overflow-x:auto}}

/* ============ INDUSTRIES WE SERVE ============ */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:50px;background:var(--line-soft);border:1px solid var(--line-soft)}
.ind{background:var(--ink-2);padding:26px 24px;display:flex;gap:16px;align-items:flex-start;position:relative;overflow:hidden;opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease,background .3s ease}
.ind-grid.in .ind{opacity:1;transform:none}
.ind::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(var(--gold),var(--gold-bright));transform:scaleY(0);transform-origin:top;transition:transform .35s ease}
.ind:hover::before{transform:scaleY(1)}
.ind:hover{background:var(--panel)}
.ind .ic{width:48px;height:48px;border:1px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0;transition:.35s ease;background:rgba(198,162,78,.04)}
.ind:hover .ic{background:linear-gradient(135deg,var(--gold),#a9842f);color:#1a1206;transform:rotate(-6deg) scale(1.06);box-shadow:0 8px 20px rgba(198,162,78,.25)}
.ind .ic svg{width:24px;height:24px}
.ind .tx h3{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;color:var(--cream);margin-bottom:5px;line-height:1.15;transition:.3s}
.ind:hover .tx h3{color:var(--gold-bright)}
.ind .tx p{font-size:12.7px;color:var(--muted);line-height:1.5}
@media(max-width:900px){.ind-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.ind-grid{grid-template-columns:1fr}}
@media (prefers-reduced-motion: reduce){.ind{opacity:1;transform:none}}

/* ============ REVEAL FAILSAFE (content always visible if JS is stale) ============ */
body:not(.reveal-ready) .reveal,
body:not(.reveal-ready) .ind,
body:not(.reveal-ready) .ptier{opacity:1 !important;transform:none !important}

/* ============ CLIENT LOGO MARQUEE ============ */
.logos-sec{padding:64px 0;background:var(--ink-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.logos-sec .ttl{text-align:center;font-family:'Jost';font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:36px}
.logos-row{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logos-track{display:flex;align-items:center;gap:20px;width:max-content;animation:logoScroll 70s linear infinite}
.logos-row:hover .logos-track{animation-play-state:paused}
.brand-chip{height:84px;min-width:180px;padding:0 26px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#f3efe6;border:1px solid rgba(255,255,255,.06);flex-shrink:0;transition:transform .3s ease,box-shadow .3s ease,filter .3s ease;filter:saturate(.92)}
.brand-chip.dark{background:#1b1510;border:1px solid var(--line)}
.brand-chip img{max-height:46px;max-width:170px;width:auto;object-fit:contain;display:block}
.brand-chip:hover{transform:translateY(-5px);box-shadow:0 16px 34px rgba(0,0,0,.4);filter:saturate(1.05)}
@keyframes logoScroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 10px))}}
@media (prefers-reduced-motion: reduce){.logos-track{animation:none}.logos-row{overflow-x:auto}}
@media(max-width:560px){.brand-chip{height:70px;min-width:150px;padding:0 20px}.brand-chip img{max-height:38px;max-width:140px}}

/* ============ CORE SERVICES CARDS ============ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.svc-card{position:relative;height:440px;border-radius:14px;overflow:hidden;display:block;border:1px solid var(--line-soft);isolation:isolate}
.svc-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;transition:transform .9s ease}
.svc-card:hover .svc-bg{transform:scale(1.08)}
.svc-ico{position:absolute;top:34px;left:0;right:0;z-index:1;display:flex;justify-content:center;color:rgba(233,211,160,.14);transition:.5s}
.svc-card:hover .svc-ico{color:rgba(233,211,160,.22);transform:translateY(-4px)}
.svc-ico svg{width:96px;height:96px}
.svc-veil{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(8,6,4,.12),rgba(8,6,4,.4) 50%,rgba(8,6,4,.93));transition:.45s}
.svc-card:hover .svc-veil{background:linear-gradient(180deg,rgba(8,6,4,.28),rgba(8,6,4,.55) 45%,rgba(8,6,4,.97))}
.svc-tx{position:absolute;left:28px;right:28px;bottom:28px;z-index:3}
.svc-tx h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:27px;color:#fff;line-height:1.12;text-shadow:0 2px 12px rgba(0,0,0,.45)}
.svc-desc{font-size:13.5px;color:#dbd0bb;line-height:1.55;margin-top:11px;max-height:0;opacity:0;overflow:hidden;transition:max-height .5s ease,opacity .5s ease,margin .5s ease}
.svc-card:hover .svc-desc{max-height:90px;opacity:1}
.svc-more{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-family:'Jost';font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:#1a1206;background:linear-gradient(135deg,var(--gold),#a9842f);padding:10px 20px;border-radius:30px;opacity:0;transform:translateY(12px);transition:.45s ease}
.svc-card:hover .svc-more{opacity:1;transform:none}
.svc-card::after{content:'';position:absolute;inset:0;z-index:4;border:1.5px solid transparent;border-radius:14px;transition:.45s;pointer-events:none}
.svc-card:hover::after{border-color:rgba(198,162,78,.55);box-shadow:0 24px 50px rgba(0,0,0,.45)}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}.svc-card{height:360px}
  .svc-desc{max-height:90px;opacity:1}.svc-more{opacity:1;transform:none}}

/* ============ PRICING PACKAGES ============ */
.price-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:50px}
.ptier{position:relative;background:var(--ink-2);border:1px solid var(--line-soft);border-radius:13px;padding:22px 16px;display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .45s ease,box-shadow .4s ease,border-color .4s ease}
.price-grid.in .ptier{opacity:1;transform:none}
.price-grid.in .ptier.popular{transform:scale(1.04)}
.ptier::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--acc),transparent);opacity:0;transition:.4s}
.ptier:hover{border-color:var(--acc);box-shadow:0 22px 50px rgba(0,0,0,.5);transform:translateY(-6px);z-index:2}
.price-grid.in .ptier.popular:hover{transform:scale(1.04) translateY(-6px)}
.ptier:hover::before{opacity:1}
.ptier.popular{border-color:var(--gold);box-shadow:0 20px 50px rgba(0,0,0,.4)}
background:linear-gradient(135deg,var(--gold),#a9842f);color:#1a1206;font-family:'Jost';font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:5px 42px;transform:rotate(45deg);box-shadow:0 4px 12px rgba(0,0,0,.3)}

.pico{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.03);border:1px solid var(--acc);color:var(--acc);transition:.4s}
.ptier:hover .pico{background:var(--acc);color:#0c0907;transform:rotate(-6deg) scale(1.06)}
.pico svg{width:25px;height:25px}

.pname{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:22px;color:var(--cream);margin-top:18px;line-height:1}
.ptag{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.35;min-height:30px}
.pquote-l{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13.5px;color:var(--acc);margin-top:12px;padding-bottom:14px;border-bottom:1px solid var(--line-soft)}
.pfeat{list-style:none;margin:16px 0 20px;display:flex;flex-direction:column;gap:9px;flex:1}
.pfeat li{display:flex;gap:8px;font-size:11.8px;color:#d3c8b4;line-height:1.4}

.pfeat li svg{width:15px;height:15px;color:var(--acc);flex-shrink:0;margin-top:2px}
.ptier .btn{width:100%;justify-content:center;padding:11px 10px;font-size:12px}
@media(max-width:1100px){.price-grid{grid-template-columns:repeat(3,1fr);gap:16px}.price-grid.in .ptier.popular{transform:none}}
@media(max-width:620px){.price-grid{grid-template-columns:1fr 1fr;gap:12px}}@media(max-width:400px){.price-grid{grid-template-columns:1fr}}
@media (prefers-reduced-motion: reduce){.ptier{opacity:1;transform:none}}

/* ============ VENUE PRICING ============ */
.vprice-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px}
.vcard{position:relative;background:var(--ink-2);border:1px solid var(--line-soft);border-radius:14px;padding:30px 26px;display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .45s ease,border-color .4s ease,box-shadow .4s ease}
.vprice-grid.in .vcard{opacity:1;transform:none}
.vcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:.4s}
.vcard:hover{border-color:var(--gold);transform:translateY(-7px);box-shadow:0 24px 54px rgba(0,0,0,.5)}
.vcard:hover::before{opacity:1}
.vico{width:54px;height:54px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:rgba(198,162,78,.05);border:1px solid var(--line);color:var(--gold);transition:.4s}
.vcard:hover .vico{background:linear-gradient(135deg,var(--gold),#a9842f);color:#0c0907;transform:rotate(-6deg)}
.vico svg{width:27px;height:27px}
.vname{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:23px;color:var(--cream);margin-top:16px;line-height:1.1}
.vdesc{font-size:12.5px;color:var(--muted);margin-top:6px;line-height:1.45}
.vprice{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;color:var(--gold);margin-top:14px;padding-bottom:16px;border-bottom:1px solid var(--line-soft)}
.vfeat{list-style:none;margin:16px 0 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.vfeat li{display:flex;gap:9px;font-size:12.8px;color:#d3c8b4;line-height:1.4}
.vfeat li svg{width:16px;height:16px;color:var(--gold);flex-shrink:0;margin-top:1px}
.vcard .btn{width:100%;justify-content:center}
@media(max-width:900px){.vprice-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.vprice-grid{grid-template-columns:1fr}}
body:not(.reveal-ready) .vcard{opacity:1 !important;transform:none !important}

/* ============ HOW WE WORK ============ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:54px;position:relative}
.step{position:relative;padding:0 22px;text-align:center;opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .5s ease}
.steps.in .step{opacity:1;transform:none}
.step:not(:last-child)::after{content:'';position:absolute;top:34px;left:60%;right:-40%;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
.step .snum{width:68px;height:68px;margin:0 auto;border-radius:50%;border:1px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;background:var(--ink);position:relative;z-index:1;transition:.4s}
.step .snum svg{width:30px;height:30px}
.step:hover .snum{background:linear-gradient(135deg,var(--gold),#a9842f);color:#0c0907;transform:translateY(-5px)}
.step .sk{position:absolute;top:24px;left:50%;transform:translateX(-50%);font-family:'Cormorant Garamond',serif;font-size:13px;color:var(--gold);font-weight:600;z-index:2;background:var(--ink);padding:0 4px}
.step h3{font-family:'Cormorant Garamond',serif;font-size:21px;color:var(--cream);margin:20px 0 8px}
.step p{font-size:13px;color:var(--muted);line-height:1.55}
@media(max-width:760px){.steps{grid-template-columns:1fr 1fr;gap:36px 0}.step:not(:last-child)::after{display:none}}
@media(max-width:430px){.steps{grid-template-columns:1fr}}
body:not(.reveal-ready) .step{opacity:1 !important;transform:none !important}

/* ============ SHOWREEL ============ */
.reel{position:relative;margin-top:46px;border-radius:18px;overflow:hidden;border:1px solid var(--line)}
.reel-poster{position:relative;aspect-ratio:16/9;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;cursor:pointer}
.reel-poster::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,4,.35),rgba(8,6,4,.65))}
.reel-play{position:relative;z-index:2;width:92px;height:92px;border-radius:50%;border:0;background:linear-gradient(135deg,var(--gold),#a9842f);color:#0c0907;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 14px 40px rgba(0,0,0,.5);transition:transform .3s ease}
.reel-play::before{content:'';position:absolute;inset:-10px;border-radius:50%;border:2px solid rgba(198,162,78,.5);animation:reelPulse 2.4s infinite}
.reel-play:hover{transform:scale(1.1)}
.reel-play svg{width:34px;height:34px;margin-left:5px}
.reel-cap{position:absolute;z-index:2;bottom:26px;left:28px;right:28px;text-align:center;color:#fff;font-family:'Cormorant Garamond',serif;font-size:22px;letter-spacing:.5px;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.reel iframe{width:100%;aspect-ratio:16/9;display:block;border:0}
@keyframes reelPulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.5);opacity:0}}
@media (prefers-reduced-motion: reduce){.reel-play::before{animation:none}}

/* ============ FAQ ============ */
.faq{max-width:820px;margin:46px auto 0;display:flex;flex-direction:column;gap:14px}
.faq details{background:var(--ink-2);border:1px solid var(--line-soft);border-radius:10px;overflow:hidden;transition:border-color .3s}
.faq details[open]{border-color:var(--gold)}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:'Cormorant Garamond',serif;font-size:19px;color:var(--cream);transition:color .3s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--gold-bright)}
.faq summary .qplus{flex-shrink:0;width:26px;height:26px;position:relative;transition:transform .3s}
.faq details[open] summary .qplus{transform:rotate(135deg)}
.faq summary .qplus::before,.faq summary .qplus::after{content:'';position:absolute;background:var(--gold);border-radius:2px}
.faq summary .qplus::before{top:12px;left:4px;right:4px;height:2px}
.faq summary .qplus::after{left:12px;top:4px;bottom:4px;width:2px}
.faq .ans{padding:0 24px 22px;font-size:14px;color:var(--muted);line-height:1.65}

/* ============ EVENT REELS (vertical) ============ */
.reels{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;margin-top:46px}
.reel-v{position:relative;width:300px;max-width:78vw;aspect-ratio:9/16;border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:0 22px 54px rgba(0,0,0,.55);background:#000;transition:transform .4s ease}
.reel-v:hover{transform:translateY(-6px)}
.reel-v video{width:100%;height:100%;object-fit:cover;display:block}
.reel-v::before{content:'';position:absolute;inset:0;border-radius:22px;border:1px solid rgba(198,162,78,.25);pointer-events:none;z-index:2}
.rv-tag{position:absolute;top:14px;left:14px;z-index:3;font-family:'Cormorant Garamond',serif;font-size:14px;letter-spacing:.06em;color:#fff;background:rgba(8,6,4,.45);backdrop-filter:blur(4px);padding:4px 12px;border-radius:20px;border:1px solid rgba(255,255,255,.12)}
@media(max-width:680px){.reel-v{width:46vw}}
@media(max-width:430px){.reels{gap:14px}.reel-v{width:47vw}}

/* ============ MASONRY GALLERY ============ */
.mgal{column-count:3;column-gap:16px;margin-top:46px}
.mgal .gi{break-inside:avoid;margin:0 0 16px;border-radius:12px;overflow:hidden;position:relative;display:block;border:1px solid var(--line-soft)}
.mgal .gi img{width:100%;display:block;transition:transform .7s ease}
.mgal .gi:hover img{transform:scale(1.07)}
.mgal .gi::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(8,6,4,.82));opacity:0;transition:.4s}
.mgal .gi:hover::after{opacity:1}
.mgal .gi .glbl{position:absolute;left:16px;bottom:14px;z-index:2;color:#fff;font-family:'Cormorant Garamond',serif;font-size:18px;letter-spacing:.04em;opacity:0;transform:translateY(8px);transition:.4s}
.mgal .gi:hover .glbl{opacity:1;transform:none}
@media(max-width:900px){.mgal{column-count:2}}
@media(max-width:480px){.mgal{column-count:1}}

/* ===== MOBILE GPU-GLITCH HARDENING (fix Android rainbow/static rendering) ===== */
@media (max-width:768px){
  /* backdrop-filter blur is buggy on many Android GPUs -> use solid backgrounds */
  header.nav.scrolled,.drop,#toTop,#lightbox,.rv-tag{-webkit-backdrop-filter:none!important;backdrop-filter:none!important}
  header.nav.scrolled{background:rgba(10,7,5,.97)!important}
  .drop{background:rgba(14,10,7,.99)!important}
  #toTop{background:rgba(20,15,9,.96)!important}
  .rv-tag{background:rgba(8,6,4,.7)!important}
  /* render dense card grids statically -> removes the mass-animation GPU spike that corrupts the layer */
  .ind,.ind-grid .ind,.ind-grid.in .ind,.svc,.ptier,.vcard,.step,.city,.gi,.reveal{opacity:1!important;transform:none!important;animation:none!important;filter:none!important}
  .ind::before{display:none!important}
  /* stop sections being promoted to oversized glitchy compositing layers */
  section,.section{filter:none!important}
}
