/* DREAM DESTINATION DUBAI — shared theme (all sites) */
:root{
  --bg:#0A0A0A; --gold:#C9A84C; --gold2:#e7cd7e; --text:#F8F5EF; --muted:#8a836f;
  --line:rgba(201,168,76,.16); --glass:rgba(248,245,239,.03);
  --fd:'Bebas Neue',sans-serif; --fs:'Cormorant Garamond',serif; --fb:'Montserrat',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{background:var(--bg);color:var(--text);font-family:var(--fb);-webkit-font-smoothing:antialiased;overflow-x:clip}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#1a1407}

/* Loader */
#loader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px}
#loader .ll{font-family:var(--fd);font-size:clamp(24px,6vw,52px);letter-spacing:.08em;overflow:hidden}
#loader .ll span{display:inline-block;transform:translateY(110%)}
#loader .lbar{width:min(240px,60vw);height:1px;background:rgba(201,168,76,.22);position:relative;overflow:hidden}
#loader .lbar i{position:absolute;left:0;top:0;height:100%;width:0;background:var(--gold)}

/* Ambient glow + cursor */
#glow{position:fixed;width:520px;height:520px;left:0;top:0;border-radius:50%;pointer-events:none;z-index:0;background:radial-gradient(circle,rgba(201,168,76,.12),transparent 60%);transform:translate(-50%,-50%);filter:blur(20px)}
.cd,.cr{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9000;mix-blend-mode:difference}
.cd{width:6px;height:6px;background:var(--gold);transform:translate(-50%,-50%)}
.cr{width:38px;height:38px;border:1px solid rgba(201,168,76,.7);transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s}
.cr.grow{width:66px;height:66px;background:rgba(201,168,76,.08)}
@media(hover:none),(max-width:768px){.cd,.cr,#glow{display:none}}

/* Header */
header{position:fixed;top:0;left:0;width:100%;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:22px 5vw;transition:background .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent}
header.scrolled{background:rgba(10,10,10,.82);backdrop-filter:blur(12px);padding:14px 5vw;border-bottom:1px solid var(--line)}
.logo{font-family:var(--fd);font-size:22px;letter-spacing:.12em}
.logo b{color:var(--gold);font-weight:400}
nav{display:flex;gap:28px;align-items:center}
nav a.nl{font-size:12px;letter-spacing:.06em;color:var(--muted);transition:color .3s;position:relative}
nav a.nl::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--gold);transition:width .3s}
nav a.nl:hover{color:var(--text)}nav a.nl:hover::after{width:100%}
.btn{display:inline-block;font-family:var(--fb);font-size:11px;letter-spacing:.14em;padding:12px 22px;border-radius:6px;border:1px solid var(--gold);color:var(--gold);background:transparent;cursor:pointer;transition:background .3s,color .3s;will-change:transform}
.btn.solid{background:var(--gold);color:#1a1407;font-weight:500}
.btn:hover{background:var(--gold);color:#1a1407}
.menu-toggle{display:none;font-size:26px;color:var(--gold);background:none;border:none;cursor:pointer}
@media(max-width:768px){nav .nl{display:none}.menu-toggle{display:block}.logo{font-size:14px;letter-spacing:.04em}header nav .btn.solid{display:none}}

/* generic */
.wrap{max-width:1200px;margin:0 auto;padding:0 5vw}
.eyebrow{font-size:10px;letter-spacing:.34em;color:var(--gold);margin-bottom:14px}
.sec-title{font-family:var(--fd);font-size:clamp(34px,6vw,76px);line-height:.95;letter-spacing:.02em}
.sec-title .gold{color:var(--gold)}
section{position:relative;z-index:1}
.section-pad{padding:13vh 0}
.shade{background:#0b0906;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* Hero */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:center}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero-static{position:absolute;inset:0;display:none;align-items:center;justify-content:flex-end}
.hero-static .gem{width:min(46vw,420px);height:min(46vw,420px);border:1px solid rgba(201,168,76,.5);transform:rotate(45deg) translateX(-12vw)}
.hero-vign{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,var(--bg) 14%,rgba(10,10,10,.4) 46%,transparent 70%)}
.hero-inner{position:relative;z-index:2;padding:0 5vw;max-width:700px}
.badge{display:inline-block;font-size:10px;letter-spacing:.3em;color:var(--gold);border:1px solid rgba(201,168,76,.4);border-radius:40px;padding:7px 16px;margin-bottom:26px}
.hero h1{font-family:var(--fd);font-size:clamp(46px,9vw,108px);line-height:.88;letter-spacing:.02em}
.hero h1 .gold{color:var(--gold)}
.mask{overflow:hidden;display:block}
.mask>span{display:block;transform:translateY(110%)}
.hero .lead{font-family:var(--fs);font-style:italic;font-size:clamp(17px,2.4vw,23px);color:#cfc8b8;margin:22px 0 0;max-width:520px}
.hero .cta-row{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;color:var(--gold);font-size:10px;letter-spacing:.3em;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue .ln{width:1px;height:40px;background:linear-gradient(var(--gold),transparent);animation:cuepulse 2s ease-in-out infinite}
@keyframes cuepulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* Velocity marquee */
.vmarquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;overflow:hidden;white-space:nowrap;background:#0c0a07}
.vtrack{display:inline-flex;will-change:transform;font-family:var(--fd);font-size:clamp(38px,6vw,74px);letter-spacing:.04em;color:rgba(248,245,239,.16)}
.vtrack .it{display:inline-flex;align-items:center;gap:30px;margin:0 30px}
.vtrack .dot{color:var(--gold);font-size:.5em}
.vtrack .out{color:transparent;-webkit-text-stroke:1px rgba(201,168,76,.5)}

/* Manifesto */
.manifesto{height:230vh;position:relative}
.manifesto .stick{position:sticky;top:0;height:100vh;display:flex;align-items:center}
.manifesto .mtext{font-family:var(--fd);font-size:clamp(28px,5.4vw,74px);line-height:1.04;letter-spacing:.01em;max-width:1100px}
.manifesto .w{color:#2e2a20;transition:color .15s;display:inline-block;margin-right:.22em}
.manifesto .w.lit{color:var(--text)} .manifesto .w.gold{color:var(--gold)}

/* Horizontal sticky scroll (brands / packages / etc.) */
.hscroll{height:340vh;position:relative}
.hscroll .hstick{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.hscroll .hhead{position:absolute;top:9vh;left:5vw;right:5vw;display:flex;justify-content:space-between;align-items:flex-end;gap:20px}
.hscroll .hprog{position:absolute;bottom:8vh;left:5vw;right:5vw;height:2px;background:rgba(201,168,76,.14)}
.hscroll .hprog i{position:absolute;left:0;top:0;height:100%;width:0;background:var(--gold)}
.htrack{display:flex;gap:30px;padding:0 5vw;will-change:transform}
.hcard{flex:none;width:min(80vw,440px);height:62vh;min-height:430px;border:1px solid var(--line);border-radius:20px;background:var(--glass);padding:40px;display:flex;flex-direction:column;justify-content:space-between;position:relative;transform-style:preserve-3d;transition:border-color .4s,background .4s;will-change:transform}
.hcard:hover{border-color:rgba(201,168,76,.5);background:rgba(201,168,76,.05)}
.hcard .bnum{position:absolute;top:26px;right:34px;font-family:var(--fd);font-size:72px;color:rgba(201,168,76,.12);line-height:1}
.hcard .ico{width:62px;height:62px;border:1px solid rgba(201,168,76,.4);border-radius:16px;display:flex;align-items:center;justify-content:center}
.hcard .ico svg{width:30px;height:30px;stroke:var(--gold)}
.hcard h3{font-family:var(--fd);font-size:clamp(34px,4vw,50px);letter-spacing:.03em;margin:14px 0 12px}
.hcard p{color:var(--muted);font-size:14px;line-height:1.7;max-width:320px}
.hcard .price{font-family:var(--fd);color:var(--gold);font-size:30px;letter-spacing:.03em;margin-top:14px}
.hcard .go{margin-top:auto;font-size:11px;letter-spacing:.16em;color:var(--gold);display:flex;align-items:center;gap:8px}
@media(max-width:768px){
  .hscroll{height:auto}.hscroll .hstick{position:static;height:auto;padding:14vh 0 9vh}
  .hscroll .hhead{position:static;padding:0 5vw 5vh;flex-direction:column;align-items:flex-start}
  .hscroll .hprog{display:none}
  .htrack{overflow-x:auto;scroll-snap-type:x mandatory;transform:none!important}
  .htrack::-webkit-scrollbar{display:none}.hcard{scroll-snap-align:center;height:auto;min-height:380px}
}

/* Card grid (services / types / structures / categories / products) */
.grid{display:grid;gap:24px;margin-top:6vh}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c4{grid-template-columns:repeat(4,1fr)}
.gcard{border:1px solid var(--line);border-radius:16px;background:var(--glass);padding:32px;position:relative;transition:border-color .4s,background .4s,transform .4s}
.gcard:hover{border-color:rgba(201,168,76,.5);background:rgba(201,168,76,.05)}
.gcard .ico{width:54px;height:54px;border:1px solid rgba(201,168,76,.4);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.gcard .ico svg{width:26px;height:26px;stroke:var(--gold)}
.gcard h3{font-family:var(--fd);font-size:26px;letter-spacing:.03em;margin-bottom:10px}
.gcard p{color:var(--muted);font-size:13.5px;line-height:1.65}
.gcard .price{font-family:var(--fd);color:var(--gold);font-size:26px;margin-top:14px}
.gcard .tag{position:absolute;top:18px;right:18px;font-size:9px;letter-spacing:.2em;color:var(--gold);border:1px solid var(--line);border-radius:30px;padding:4px 10px}
@media(max-width:980px){.grid.c4{grid-template-columns:repeat(2,1fr)}.grid.c3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid.c4,.grid.c3,.grid.c2{grid-template-columns:1fr}}

/* Process steps */
.process{margin-top:6vh;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.pstep{background:var(--bg);padding:38px 30px;transition:background .4s}
.pstep:hover{background:#0e0c08}
.pstep .pn{font-family:var(--fd);font-size:50px;color:rgba(201,168,76,.25);line-height:1}
.pstep h4{font-family:var(--fd);font-size:22px;letter-spacing:.03em;margin:12px 0 8px}
.pstep p{color:var(--muted);font-size:13px;line-height:1.6}
@media(max-width:880px){.process{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.process{grid-template-columns:1fr}}

/* Checklist */
.checklist{margin-top:6vh;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 40px}
.chk{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
.chk .tick{flex:none;width:22px;height:22px;border-radius:50%;border:1px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:12px}
.chk span{color:#d8d2c4;font-size:14px;line-height:1.5}
@media(max-width:640px){.checklist{grid-template-columns:1fr}}

/* Stats */
.stats{padding:18vh 0;text-align:center;overflow:hidden}
.ghost{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--fd);font-size:clamp(120px,28vw,420px);color:rgba(201,168,76,.035);white-space:nowrap;pointer-events:none;letter-spacing:.04em;will-change:transform}
.stat-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.stat .n{font-family:var(--fd);font-size:clamp(46px,8vw,100px);color:var(--gold);line-height:1;letter-spacing:.02em}
.stat .l{font-size:11px;letter-spacing:.22em;color:var(--muted);margin-top:8px}
@media(max-width:768px){.stat-grid{grid-template-columns:repeat(2,1fr);gap:46px 20px}}

/* Why sticky swap */
.why{position:relative;padding:0 0 4vh}
.why-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:5vw;align-items:start}
.why-left{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;justify-content:center}
.why-left .wbig{font-family:var(--fd);font-size:clamp(56px,9vw,150px);line-height:.86;letter-spacing:.02em}
.why-left .wbig .gold{color:var(--gold)}
.why-left .widx{font-family:var(--fd);font-size:20px;color:var(--gold);letter-spacing:.2em;margin-top:24px}
.why-right{padding:30vh 0}
.feat{min-height:64vh;display:flex;flex-direction:column;justify-content:center;border-top:1px solid var(--line);padding:40px 0}
.feat:first-child{border-top:none}
.feat .fi{width:48px;height:48px;border:1px solid rgba(201,168,76,.4);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.feat .fi svg{width:24px;height:24px;stroke:var(--gold)}
.feat h4{font-family:var(--fd);font-size:clamp(26px,3.4vw,44px);letter-spacing:.03em;margin-bottom:14px;color:#5a5443;transition:color .5s}
.feat.active h4{color:var(--text)}
.feat p{color:var(--muted);font-size:15px;line-height:1.75;max-width:440px}
@media(max-width:768px){.why-grid{grid-template-columns:1fr;gap:0}.why-left{position:relative;height:auto;padding:14vh 0 4vh}.why-right{padding:0 0 6vh}.feat{min-height:auto;padding:34px 0}.feat h4{color:var(--text)}}

/* Testimonials marquee */
.testi{padding:14vh 0;overflow:hidden}
.testi .thead{padding:0 5vw 6vh}
.trow{display:flex;gap:24px;width:max-content;will-change:transform;padding:0 24px}
.tcard{width:380px;border:1px solid var(--line);border-radius:16px;padding:34px;background:var(--glass)}
.tcard .stars{color:var(--gold);letter-spacing:3px;font-size:13px;margin-bottom:16px}
.tcard q{font-family:var(--fs);font-style:italic;font-size:20px;line-height:1.5;color:#e3ddcf;display:block;margin-bottom:20px}
.tcard .who{font-size:13px} .tcard .role{font-size:12px;color:var(--muted)}

/* CTA */
.cta{padding:22vh 0;text-align:center;position:relative;overflow:hidden}
.cta .cglow{position:absolute;width:600px;height:600px;border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(201,168,76,.16),transparent 60%);pointer-events:none;transition:transform .2s}
.cta h2{position:relative;font-family:var(--fd);font-size:clamp(40px,9vw,124px);line-height:.9;letter-spacing:.02em}
.cta h2 .gold{color:var(--gold)}
.cta p{position:relative;color:var(--muted);max-width:480px;margin:22px auto 38px;line-height:1.7;font-size:15px}

/* Footer */
footer{border-top:1px solid var(--line);padding:8vh 5vw 4vh;background:#0b0906;position:relative;z-index:1}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:6vh}
.foot-brand .logo{font-size:28px;margin-bottom:14px}
.foot-brand p{color:var(--muted);font-size:13px;line-height:1.7;max-width:280px}
.foot-col h5{font-size:11px;letter-spacing:.2em;color:var(--gold);margin-bottom:18px}
.foot-col a{display:block;color:var(--muted);font-size:13px;margin-bottom:11px;transition:color .3s}
.foot-col a:hover{color:var(--text)}
.socials{display:flex;gap:14px;margin-top:18px}
.socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:border-color .3s,background .3s}
.socials a:hover{border-color:var(--gold);background:rgba(201,168,76,.08)}
.socials svg{width:16px;height:16px;stroke:var(--gold)}
.foot-bot{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:26px;color:var(--muted);font-size:12px;flex-wrap:wrap;gap:10px}

.reveal{opacity:0;transform:translateY(40px)}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  .mask>span,#loader .ll span{transform:none!important}
  .manifesto .w{color:var(--text)} .feat h4{color:var(--text)} .scroll-cue .ln{animation:none}
}
