/* ============================================
   DWARAKA V2 — Premium Design System
   Clean, cinematic, luxury
   ============================================ */

:root {
  --black: #080808;
  --charcoal: #141414;
  --dark: #1a1a1a;
  --mid: #333;
  --grey: #777;
  --light: #aaa;
  --muted: #ccc;
  --off-white: #f3f2ef;
  --cream: #f8f7f4;
  --white: #fff;
  --gold: #c4a265;
  --gold-light: #d9c08c;
  --gold-dark: #a8883f;
  --gold-glow: rgba(196,162,101,.12);
  --gold-glow2: rgba(196,162,101,.06);
  --font-d: 'Playfair Display', Georgia, serif;
  --font-b: 'Inter', -apple-system, sans-serif;
  --ease: cubic-bezier(.16,1,.3,1);
  --ease2: cubic-bezier(.77,0,.175,1);
  --max: 1440px;
  --pad: clamp(24px,5vw,56px);
  --space: clamp(120px,14vw,200px);
  --r: 6px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-b);color:var(--charcoal);background:var(--white);overflow-x:hidden;line-height:1.65}
body.no-scroll{overflow:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{border:none;background:none;cursor:pointer;font-family:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}
::selection{background:var(--gold);color:var(--white)}

.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* ========== PRELOADER ========== */
#preloader{position:fixed;inset:0;background:var(--black);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .8s ease .3s,visibility .8s ease .3s}
#preloader.done{opacity:0;visibility:hidden}
.preloader-logo{width:60px;margin:0 auto 20px;opacity:.7;animation:prePulse 1.4s ease-in-out infinite}
@keyframes prePulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.06);opacity:1}}
.preloader-bar{width:100px;height:1px;background:var(--mid);margin:0 auto;position:relative;overflow:hidden}
.preloader-bar::after{content:'';position:absolute;left:0;top:0;height:100%;width:28%;background:var(--gold);animation:preSlide 1s ease-in-out infinite}
@keyframes preSlide{0%{transform:translateX(-100%)}100%{transform:translateX(500%)}}

/* ========== NAV ========== */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;padding:28px 0;transition:all .4s ease}
.nav--solid{background:rgba(6,6,6,.97);backdrop-filter:blur(30px);padding:14px 0}
.nav__wrap{display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.nav__brand{display:flex;align-items:center;gap:14px}
.nav__logo{width:36px;height:36px;object-fit:contain}
.nav__brand-text{line-height:1}
.nav__brand-name{font-family:var(--font-d);font-size:1.15rem;font-weight:700;letter-spacing:.3em;color:var(--white);display:block}
.nav__brand-sub{font-size:.44rem;font-weight:600;letter-spacing:.45em;color:var(--gold);text-transform:uppercase;display:block;margin-top:2px}
.nav__links{display:flex;align-items:center;gap:36px}
.nav__link{font-size:.76rem;font-weight:500;letter-spacing:.08em;color:rgba(255,255,255,.45);transition:color .3s;position:relative}
.nav__link::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .4s var(--ease)}
.nav__link:hover,.nav__link--active{color:var(--white)}
.nav__link:hover::after,.nav__link--active::after{width:100%}
.nav__cta{font-size:.65rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(196,162,101,.35);padding:10px 24px;border-radius:50px;transition:all .3s}
.nav__cta:hover{background:var(--gold);color:var(--white);border-color:var(--gold)}
.nav__burger{display:none;width:26px;height:18px;flex-direction:column;justify-content:space-between;z-index:101}
.nav__burger span{display:block;height:1.5px;background:var(--white);border-radius:2px;transition:all .3s}
.nav__burger--open span:nth-child(1){transform:rotate(45deg) translate(6px,5px)}
.nav__burger--open span:nth-child(2){opacity:0}
.nav__burger--open span:nth-child(3){transform:rotate(-45deg) translate(6px,-5px)}
.nav__mobile{position:fixed;inset:0;background:var(--black);z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;opacity:0;visibility:hidden;transition:all .5s var(--ease)}
.nav__mobile--open{opacity:1;visibility:visible}
.nav__mobile a{font-family:var(--font-d);font-size:1.8rem;color:rgba(255,255,255,.6);transition:color .3s}
.nav__mobile a:hover{color:var(--gold)}

/* ========== TYPOGRAPHY ========== */
.tag{display:inline-flex;align-items:center;gap:14px;font-size:.62rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.tag::before{content:'';width:50px;height:1px;background:var(--gold)}
.tag--light{color:var(--gold-light)}.tag--light::before{background:var(--gold-light)}
.tag--center{justify-content:center}.tag--center::before{display:none}
.tag--white{color:rgba(255,255,255,.35)}.tag--white::before{background:rgba(255,255,255,.15)}

.heading{font-family:var(--font-d);font-weight:700;line-height:1.05;color:var(--black);letter-spacing:-.02em}
.heading--hero{font-size:clamp(3.5rem,9vw,8rem)}
.heading--xxl{font-size:clamp(2.8rem,6vw,5rem)}
.heading--xl{font-size:clamp(2.2rem,4.5vw,3.8rem)}
.heading--lg{font-size:clamp(1.8rem,3.5vw,2.8rem)}
.heading--white{color:var(--white)}
.heading em{font-style:italic;color:var(--gold)}

.body-text{font-size:1rem;line-height:1.9;color:var(--grey);max-width:540px}
.body-text--light{color:rgba(255,255,255,.4)}
.body-text--wide{max-width:640px}

/* ========== BUTTONS ========== */
.btn{display:inline-flex;align-items:center;gap:12px;padding:18px 44px;font-size:.76rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;border-radius:50px;transition:all .4s var(--ease);position:relative}
.btn--gold{background:var(--gold);color:var(--white)}
.btn--gold:hover{background:var(--gold-dark);box-shadow:0 20px 50px rgba(196,162,101,.3);transform:translateY(-3px)}
.btn--outline{border:1.5px solid rgba(255,255,255,.25);color:var(--white)}
.btn--outline:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.btn--dark{background:var(--charcoal);color:var(--white)}
.btn--dark:hover{background:var(--black);transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.2)}
.btn--full{width:100%;justify-content:center}
.btn svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;transition:transform .3s}
.btn:hover svg{transform:translateX(5px)}

/* ========== HERO ========== */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:80px}
.hero__bg{position:absolute;inset:0}
.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity 2s ease}
.hero__slide--active{opacity:1}
.hero__slide img{width:100%;height:100%;object-fit:cover;animation:kenBurns 25s ease-in-out infinite alternate}
@keyframes kenBurns{0%{transform:scale(1)}100%{transform:scale(1.12)}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,6,6,.35) 0%,rgba(6,6,6,.1) 35%,rgba(6,6,6,.8) 100%)}

.hero__content{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:0 var(--pad);width:100%}
.hero__tag{font-size:.58rem;font-weight:700;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:32px}
.hero__title{font-family:var(--font-d);font-size:clamp(3.2rem,8.5vw,7.5rem);font-weight:700;line-height:1;color:var(--white);margin-bottom:32px;letter-spacing:-.03em}
.hero__title em{font-style:italic;color:var(--gold)}
.hero__sub{font-size:clamp(.9rem,1.2vw,1.05rem);line-height:1.9;color:rgba(255,255,255,.4);max-width:480px;margin-bottom:48px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:80px}
.hero__stats{display:flex;gap:56px;padding-top:40px;border-top:1px solid rgba(255,255,255,.06)}
.hero__stat-num{font-family:var(--font-d);font-size:3rem;font-weight:700;color:var(--white);line-height:1}
.hero__stat-num span{color:var(--gold);font-size:2rem}
.hero__stat-label{font-size:.65rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-top:8px}

.hero__dots{position:absolute;right:var(--pad);top:50%;transform:translateY(-50%);z-index:3;display:flex;flex-direction:column;gap:14px}
.hero__dot{width:6px;height:6px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:transparent;transition:all .4s;cursor:none}
.hero__dot--active{background:var(--gold);border-color:var(--gold);height:32px;border-radius:3px}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px}
.hero__scroll span{font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.2);writing-mode:vertical-rl}
.hero__scroll-line{width:1px;height:50px;background:rgba(255,255,255,.08);position:relative;overflow:hidden}
.hero__scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:40%;background:var(--gold);animation:scrollAnim 2.4s ease-in-out infinite}
@keyframes scrollAnim{0%{top:-40%}100%{top:120%}}

/* ========== BRAND STRIP ========== */
.brand-strip{background:var(--black);padding:28px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.brand-strip__inner{display:flex;align-items:center;justify-content:center;gap:24px}
.brand-strip__line{width:60px;height:1px;background:rgba(255,255,255,.1)}
.brand-strip__text{font-size:.68rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.2)}

/* ========== INTRO ========== */
.intro{padding:var(--space) 0}
.intro__grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.intro__img-wrap{position:relative;border-radius:var(--r);overflow:hidden}
.intro__img-wrap img{width:100%;height:580px;object-fit:cover;object-position:top;transition:transform 1.2s var(--ease)}
.intro__img-wrap:hover img{transform:scale(1.03)}
.intro__badge{position:absolute;bottom:-20px;right:-20px;background:var(--gold);color:var(--white);padding:30px;border-radius:var(--r);text-align:center;box-shadow:0 20px 50px rgba(196,162,101,.25)}
.intro__badge-num{font-family:var(--font-d);font-size:3rem;font-weight:700;line-height:1;display:block}
.intro__badge-text{font-size:.55rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-top:4px;display:block}
.intro__content .body{margin-bottom:18px}
.intro__features{display:flex;flex-direction:column;gap:18px;margin:36px 0 44px}
.intro__feat{display:flex;align-items:center;gap:14px}
.intro__feat-icon{width:42px;height:42px;border-radius:50%;background:var(--gold-glow);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.intro__feat-icon svg{width:18px;height:18px;color:var(--gold);fill:none;stroke:currentColor;stroke-width:1.5}
.intro__feat h4{font-size:.85rem;font-weight:600;color:var(--charcoal)}
.intro__feat p{font-size:.78rem;color:var(--grey)}

/* ========== FLAGSHIP ========== */
.flagship{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.flagship__bg{position:absolute;inset:0}
.flagship__bg img{width:100%;height:100%;object-fit:cover}
.flagship__overlay{position:absolute;inset:0;background:rgba(6,6,6,.88)}
.flagship__content{position:relative;z-index:1;text-align:center;max-width:800px;margin:0 auto;padding:var(--space) var(--pad)}
.flagship__logo{width:100px;margin:0 auto 28px;filter:drop-shadow(0 8px 30px rgba(196,162,101,.2))}
.flagship__title{font-family:var(--font-d);font-size:clamp(3rem,7.5vw,6rem);font-weight:700;color:var(--white);letter-spacing:-.02em;margin-bottom:10px}
.flagship__title em{font-style:italic;color:var(--gold)}
.flagship__tagline{font-size:.8rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-light);margin-bottom:24px}
.flagship__desc{font-size:1rem;line-height:1.9;color:rgba(255,255,255,.35);max-width:520px;margin:0 auto 44px}
.flagship__pills{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:48px}
.flagship__pill{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:50px;padding:10px 20px;font-size:.75rem;font-weight:500;color:rgba(255,255,255,.5);transition:all .3s}
.flagship__pill:hover{border-color:var(--gold);background:var(--gold-glow)}
.flagship__pill svg{width:16px;height:16px;color:var(--gold);fill:none;stroke:currentColor;stroke-width:1.5}

/* ========== SERVICES ========== */
.services{padding:var(--space) 0;background:var(--cream)}
.services__header{text-align:center;margin-bottom:80px}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.service{background:var(--white);padding:52px 40px;position:relative;overflow:hidden;transition:all .6s var(--ease);border:1px solid transparent}
.service::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.service:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(0,0,0,.06);z-index:1;border-color:rgba(0,0,0,.03)}
.service:hover::after{transform:scaleX(1)}
.service__num{font-family:var(--font-d);font-size:4.5rem;font-weight:700;color:rgba(0,0,0,.02);position:absolute;top:8px;right:16px;line-height:1}
.service__icon{width:44px;height:44px;margin-bottom:28px}
.service__icon svg{width:100%;height:100%;color:var(--gold);fill:none;stroke:currentColor;stroke-width:1}
.service h3{font-family:var(--font-d);font-size:1.2rem;font-weight:600;color:var(--charcoal);margin-bottom:14px}
.service p{font-size:.85rem;line-height:1.8;color:var(--grey);margin-bottom:24px}
.service__link{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:8px;transition:gap .3s}
.service__link:hover{gap:16px}
.service__link svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2}

/* ========== LIFESTYLE SCROLL ========== */
.lifestyle{padding:var(--space) 0;background:var(--white);overflow:hidden}
.lifestyle__header{text-align:center;margin-bottom:60px}
.lifestyle__scroll{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 var(--pad) 20px;scrollbar-width:none;cursor:grab}
.lifestyle__scroll::-webkit-scrollbar{display:none}
.lifestyle__scroll.dragging{cursor:grabbing}
.lifestyle__card{flex:0 0 auto;width:400px;scroll-snap-align:start;position:relative;border-radius:var(--r);overflow:hidden}
.lifestyle__card--wide{width:600px}
.lifestyle__card img{width:100%;height:480px;object-fit:cover;transition:transform .8s var(--ease)}
.lifestyle__card:hover img{transform:scale(1.05)}
.lifestyle__card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,6,6,.85) 0%,transparent 45%);display:flex;flex-direction:column;justify-content:flex-end;padding:36px;opacity:0;transition:opacity .5s}
.lifestyle__card:hover .lifestyle__card-overlay{opacity:1}
.lifestyle__card-overlay h3{font-family:var(--font-d);font-size:1.2rem;color:var(--white);margin-bottom:4px}
.lifestyle__card-overlay p{font-size:.75rem;color:rgba(255,255,255,.45)}
.lifestyle__hint{text-align:center;margin-top:28px;font-size:.68rem;color:var(--light);letter-spacing:.15em}

/* ========== WHY US ========== */
.why{padding:var(--space) 0}
.why__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:100px;align-items:start}
.why__sticky{position:sticky;top:120px}
.why__list{display:flex;flex-direction:column}
.why__item{display:flex;gap:28px;padding:36px 0;border-bottom:1px solid var(--off-white);transition:all .3s;cursor:default}
.why__item:first-child{padding-top:0}
.why__item:hover{padding-left:16px}
.why__item-num{font-family:var(--font-d);font-size:1.3rem;font-weight:700;color:var(--gold);flex-shrink:0;line-height:1.4}
.why__item h4{font-size:1rem;font-weight:600;color:var(--charcoal);margin-bottom:8px}
.why__item p{font-size:.86rem;line-height:1.8;color:var(--grey)}

/* ========== TESTIMONIALS ========== */
.testimonials{padding:var(--space) 0;background:var(--charcoal)}
.testimonials__header{text-align:center;margin-bottom:70px}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testi{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.04);border-radius:var(--r);padding:48px;transition:all .5s var(--ease)}
.testi:hover{background:rgba(255,255,255,.05);transform:translateY(-6px);border-color:rgba(196,162,101,.12)}
.testi__stars{display:flex;gap:3px;margin-bottom:28px}
.testi__stars svg{width:13px;height:13px;fill:var(--gold)}
.testi__quote{font-size:.9rem;line-height:1.9;color:rgba(255,255,255,.5);margin-bottom:32px;font-style:italic}
.testi__author{display:flex;align-items:center;gap:14px}
.testi__avatar{width:40px;height:40px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--white)}
.testi__author strong{display:block;font-size:.82rem;color:var(--white)}
.testi__author span{font-size:.68rem;color:rgba(255,255,255,.25)}

/* ========== CTA ========== */
.cta-section{position:relative;padding:var(--space) 0;overflow:hidden}
.cta-section__bg{position:absolute;inset:0}
.cta-section__bg img{width:100%;height:100%;object-fit:cover}
.cta-section__overlay{position:absolute;inset:0;background:rgba(6,6,6,.9)}
.cta-section__inner{position:relative;z-index:1;text-align:center;max-width:680px;margin:0 auto}
.cta-section__title{font-family:var(--font-d);font-size:clamp(2rem,4.5vw,3.5rem);font-weight:600;line-height:1.15;color:var(--white);margin-bottom:20px}
.cta-section__title em{font-style:italic;color:var(--gold)}
.cta-section__desc{font-size:1rem;line-height:1.9;color:rgba(255,255,255,.35);margin-bottom:40px}
.cta-section__actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

/* ========== PAGE HERO ========== */
.page-hero{position:relative;min-height:55vh;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:60px}
.page-hero--short{min-height:45vh}
.page-hero__bg{position:absolute;inset:0}
.page-hero__bg img{width:100%;height:100%;object-fit:cover}
.page-hero__content{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:0 var(--pad);width:100%}
.page-hero__title{font-family:var(--font-d);font-size:clamp(2.4rem,5.5vw,4rem);font-weight:700;color:var(--white);margin-bottom:12px}
.page-hero__title em{font-style:italic;color:var(--gold)}
.page-hero__sub{font-size:.95rem;color:rgba(255,255,255,.4);max-width:500px}

/* ========== STORY (About) ========== */
.story{padding:var(--space) 0}
.story__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:100px;align-items:center}
.story__img-wrap{position:relative;border-radius:var(--r);overflow:hidden}
.story__img-wrap img{width:100%;height:540px;object-fit:cover}
.story__year{position:absolute;bottom:20px;right:20px;background:var(--gold);color:var(--white);padding:18px 22px;border-radius:var(--r);text-align:center}
.story__year span{font-size:.55rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;display:block}
.story__year strong{font-family:var(--font-d);font-size:2rem;display:block;line-height:1}
.story__stats{display:flex;gap:48px;margin-top:40px;padding-top:36px;border-top:1px solid var(--off-white)}
.story__stat-num{font-family:var(--font-d);font-size:2.2rem;font-weight:700;color:var(--gold);line-height:1;display:block}
.story__stat-label{font-size:.68rem;font-weight:500;letter-spacing:.06em;color:var(--grey);margin-top:6px;display:block}

/* ========== FOUNDERS ========== */
.founders{padding:var(--space) 0;background:var(--off-white)}
.founders__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.founders__img-wrap{border-radius:var(--r);overflow:hidden}
.founders__img{width:100%;height:540px;object-fit:cover;object-position:top}
.founder{padding:36px 0}.founder:first-child{padding-top:0}
.founder__name{font-family:var(--font-d);font-size:1.5rem;font-weight:600;color:var(--charcoal);margin-bottom:4px}
.founder__role{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:18px}
.founder__bio{font-size:.9rem;line-height:1.85;color:var(--grey)}
.founder__divider{height:1px;background:var(--muted)}

/* ========== MISSION ========== */
.mission{padding:var(--space) 0;background:var(--black)}
.mission__header{text-align:center;margin-bottom:60px}
.mission__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.mission__card{background:rgba(255,255,255,.02);padding:56px 40px;text-align:center;transition:all .5s var(--ease);border:1px solid rgba(255,255,255,.03)}
.mission__card:hover{background:rgba(255,255,255,.04);transform:translateY(-4px);border-color:rgba(196,162,101,.08)}
.mission__icon{width:52px;height:52px;margin:0 auto 28px;border-radius:50%;background:var(--gold-glow);display:flex;align-items:center;justify-content:center}
.mission__icon svg{width:24px;height:24px;color:var(--gold);fill:none;stroke:currentColor;stroke-width:1.5}
.mission__card h3{font-family:var(--font-d);font-size:1.2rem;font-weight:600;color:var(--white);margin-bottom:16px}
.mission__card p{font-size:.86rem;line-height:1.85;color:rgba(255,255,255,.3)}

/* ========== PROCESS ========== */
.process{padding:var(--space) 0;background:var(--cream)}
.process__header{text-align:center;margin-bottom:70px}
.process__timeline{max-width:700px;margin:0 auto;position:relative}
.process__line{position:absolute;left:28px;top:0;bottom:0;width:1px;background:var(--muted)}
.process__step{display:flex;gap:36px;padding:36px 0;position:relative}
.process__marker{flex-shrink:0;width:56px;height:56px;border-radius:50%;background:var(--white);border:2px solid var(--muted);display:flex;align-items:center;justify-content:center;position:relative;z-index:1;transition:all .4s var(--ease);font-family:var(--font-d);font-size:.85rem;font-weight:600;color:var(--grey)}
.process__step:hover .process__marker{border-color:var(--gold);background:var(--gold);box-shadow:0 8px 24px rgba(196,162,101,.3);color:var(--white)}
.process__step h3{font-family:var(--font-d);font-size:1.15rem;font-weight:600;color:var(--charcoal);margin-bottom:8px}
.process__step p{font-size:.86rem;line-height:1.8;color:var(--grey)}

/* ========== PROJECT HERO ========== */
.project-hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.project-hero__bg{position:absolute;inset:0}
.project-hero__slide{position:absolute;inset:0;opacity:0;transition:opacity 2s ease}
.project-hero__slide--active{opacity:1}
.project-hero__slide img{width:100%;height:100%;object-fit:cover}
.project-hero__content{position:relative;z-index:2;text-align:center;padding:0 var(--pad)}
.project-hero__logo{width:110px;margin:0 auto 20px;filter:drop-shadow(0 6px 30px rgba(0,0,0,.5))}
.project-hero__name{font-family:var(--font-d);font-size:clamp(4rem,10vw,8rem);font-weight:700;color:var(--white);letter-spacing:-.03em;margin-bottom:6px}
.project-hero__name em{font-style:italic;color:var(--gold)}
.project-hero__tagline{font-size:.82rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-light);margin-bottom:8px}
.project-hero__by{font-size:.78rem;color:rgba(255,255,255,.3);margin-bottom:40px}
.project-hero__dots{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:12px}

/* ========== UNVEILING ========== */
.unveiling{padding:var(--space) 0;background:var(--off-white);overflow:hidden}
.unveiling__header{text-align:center;margin-bottom:60px}
.unveiling__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:14px}
.unveiling__main{grid-row:span 2;border-radius:var(--r);overflow:hidden}
.unveiling__main img{width:100%;height:100%;object-fit:cover;min-height:500px;transition:transform 1s var(--ease)}
.unveiling__main:hover img{transform:scale(1.03)}
.unveiling__side{border-radius:var(--r);overflow:hidden}
.unveiling__side img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.unveiling__side:hover img{transform:scale(1.03)}

/* ========== PROJECT GALLERY ========== */
.proj-gallery{padding:var(--space) 0}
.proj-gallery__header{text-align:center;margin-bottom:60px}
.proj-gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:320px;gap:12px}
.proj-gallery__item{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer}
.proj-gallery__item--wide{grid-column:span 2}
.proj-gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.proj-gallery__item:hover img{transform:scale(1.06)}
.proj-gallery__label{position:absolute;inset:0;background:rgba(6,6,6,.4);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s}
.proj-gallery__item:hover .proj-gallery__label{opacity:1}
.proj-gallery__label span{font-family:var(--font-d);font-size:1rem;color:var(--white);letter-spacing:.06em}

/* ========== AMENITIES ========== */
.amenities{position:relative;padding:var(--space) 0;overflow:hidden}
.amenities__bg{position:absolute;inset:0}.amenities__bg img{width:100%;height:100%;object-fit:cover}
.amenities__overlay{position:absolute;inset:0;background:rgba(6,6,6,.93)}
.amenities .container{position:relative;z-index:1}
.amenities__header{text-align:center;margin-bottom:60px}
.amenities__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.amenity{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.05);border-radius:var(--r);padding:28px 16px;text-align:center;transition:all .3s}
.amenity:hover{background:var(--gold-glow);border-color:rgba(196,162,101,.2);transform:translateY(-4px)}
.amenity svg{width:26px;height:26px;color:var(--gold);margin-bottom:12px;fill:none;stroke:currentColor;stroke-width:1.5}
.amenity span{font-size:.76rem;font-weight:500;color:rgba(255,255,255,.55);display:block}

/* ========== CONTACT ========== */
.contact{padding:var(--space) 0}
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}
.contact__desc{font-size:.92rem;line-height:1.9;color:var(--grey);margin-bottom:40px}
.contact__details{display:flex;flex-direction:column;gap:28px;margin-bottom:36px}
.contact__item{display:flex;gap:16px}
.contact__icon{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:var(--gold-glow);display:flex;align-items:center;justify-content:center}
.contact__icon svg{width:18px;height:18px;color:var(--gold);fill:none;stroke:currentColor;stroke-width:1.5}
.contact__item h4{font-size:.82rem;font-weight:600;color:var(--charcoal);margin-bottom:4px}
.contact__item p{font-size:.82rem;line-height:1.6;color:var(--grey)}
.contact__map{border-radius:var(--r);overflow:hidden}
.contact__form-wrap{background:var(--off-white);border-radius:var(--r);padding:52px}
.contact__form-wrap h3{font-family:var(--font-d);font-size:1.35rem;font-weight:600;color:var(--charcoal);margin-bottom:6px}
.form-sub{font-size:.82rem;color:var(--grey);margin-bottom:36px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{position:relative;margin-bottom:18px}
.form-group input,.form-group textarea{width:100%;padding:15px 18px;background:var(--white);border:1px solid rgba(0,0,0,.06);border-radius:var(--r);font-size:.86rem;color:var(--charcoal);outline:none;transition:border .3s,box-shadow .3s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}
.form-group label{position:absolute;left:18px;top:15px;font-size:.86rem;color:var(--grey);pointer-events:none;transition:all .3s;background:var(--white);padding:0 4px}
.form-group input:focus+label,.form-group input:not(:placeholder-shown)+label,.form-group textarea:focus+label,.form-group textarea:not(:placeholder-shown)+label{top:-8px;font-size:.66rem;font-weight:600;color:var(--gold)}
.form-group select{width:100%;padding:15px 18px;background:var(--white);border:1px solid rgba(0,0,0,.06);border-radius:var(--r);font-size:.86rem;color:var(--grey);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;outline:none;cursor:pointer;transition:border .3s}
.form-group select:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}
.form-group textarea{resize:vertical;min-height:110px}

/* ========== FOOTER ========== */
.footer{background:var(--black);padding:80px 0 0}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.04)}
.footer__brand-link{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.footer__brand-link img{width:36px;height:36px;object-fit:contain}
.footer__tagline{font-size:.82rem;line-height:1.7;color:rgba(255,255,255,.25);margin-bottom:24px}
.footer__social{display:flex;gap:10px}
.footer__social a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;transition:all .3s}
.footer__social a:hover{background:var(--gold);border-color:var(--gold)}
.footer__social svg{width:13px;height:13px;fill:rgba(255,255,255,.35);transition:fill .3s}
.footer__social a:hover svg{fill:var(--white)}
.footer__col h4{font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--white);margin-bottom:22px}
.footer__col a{display:block;font-size:.82rem;color:rgba(255,255,255,.25);padding:5px 0;transition:color .3s,padding-left .3s}
.footer__col a:hover{color:var(--gold);padding-left:6px}
.footer__col p{font-size:.82rem;line-height:1.7;color:rgba(255,255,255,.25);margin-bottom:8px}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;padding:22px 0}
.footer__bottom p{font-size:.72rem;color:rgba(255,255,255,.15)}
.footer__bottom-links{display:flex;gap:20px}
.footer__bottom-links a{font-size:.72rem;color:rgba(255,255,255,.15);transition:color .3s}
.footer__bottom-links a:hover{color:var(--gold)}

/* ========== BACK TO TOP ========== */
.btt{position:fixed;bottom:28px;right:28px;width:44px;height:44px;border-radius:50%;background:var(--gold);color:var(--white);display:flex;align-items:center;justify-content:center;z-index:90;opacity:0;visibility:hidden;transform:translateY(16px);transition:all .3s;box-shadow:0 6px 20px rgba(196,162,101,.3)}
.btt--show{opacity:1;visibility:visible;transform:translateY(0)}
.btt:hover{background:var(--gold-dark);transform:translateY(-3px)}
.btt svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.5}

/* ========== REVEAL SYSTEM ========== */
.r{opacity:0;transform:translateY(60px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.r--left{transform:translateX(-60px)}
.r--right{transform:translateX(60px)}
.r--scale{transform:scale(.92)}
.r.is-visible{opacity:1;transform:translate(0) scale(1)}

/* Image reveal with clip */
.img-reveal{clip-path:inset(100% 0 0 0);transition:clip-path 1.2s var(--ease2)}
.img-reveal.is-visible{clip-path:inset(0)}

/* Stagger delays */
.services__grid .r:nth-child(2){transition-delay:.08s}
.services__grid .r:nth-child(3){transition-delay:.16s}
.services__grid .r:nth-child(4){transition-delay:.24s}
.services__grid .r:nth-child(5){transition-delay:.32s}
.services__grid .r:nth-child(6){transition-delay:.40s}
.testimonials__grid .r:nth-child(2){transition-delay:.1s}
.testimonials__grid .r:nth-child(3){transition-delay:.2s}
.amenities__grid .r{transition-delay:calc(.04s * var(--i,0))}

/* ========== RESPONSIVE ========== */
@media(max-width:1024px){
  .intro__grid,.story__grid,.why__grid,.contact__grid,.founders__grid{grid-template-columns:1fr;gap:50px}
  .why__sticky{position:static}
  .services__grid,.testimonials__grid{grid-template-columns:repeat(2,1fr)}
  .mission__grid{grid-template-columns:1fr}
  .amenities__grid{grid-template-columns:repeat(3,1fr)}
  .footer__top{grid-template-columns:1fr 1fr}
  .proj-gallery__grid{grid-template-columns:repeat(2,1fr)}
  .proj-gallery__item--wide{grid-column:span 2}
  .unveiling__grid{grid-template-columns:1fr}
  .unveiling__main{grid-row:auto}.unveiling__main img{min-height:350px}
  .lifestyle__card{width:340px}.lifestyle__card--wide{width:480px}
  .hero__stats{gap:40px}
  .signature__text{font-size:clamp(2.5rem,8vw,6rem)}
}

@media(max-width:768px){
  .nav__links{display:none}.nav__burger{display:flex}
  .hero{align-items:center;padding-bottom:40px}.hero__content{text-align:center}
  .hero__actions{justify-content:center}.hero__stats{flex-direction:column;gap:20px;align-items:center;border:none;padding:0}
  .hero__dots,.hero__scroll{display:none}
  .services__grid,.testimonials__grid,.mission__grid{grid-template-columns:1fr}
  .amenities__grid{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr}.footer__bottom{flex-direction:column;gap:10px;text-align:center}
  .lifestyle__card{width:280px}.lifestyle__card--wide{width:380px}.lifestyle__card img{height:360px}
  .proj-gallery__grid{grid-template-columns:1fr;grid-auto-rows:240px}.proj-gallery__item--wide{grid-column:auto}.proj-gallery__label{opacity:1}
  .intro__img-wrap img,.story__img-wrap img,.founders__img{height:350px}
  .intro__badge{bottom:-16px;right:0}
  .contact__form-wrap{padding:32px 24px}.form-row{grid-template-columns:1fr}
  .cta-section__actions,.hero__actions{flex-direction:column;align-items:center}
  .page-hero{min-height:45vh}.page-hero--short{min-height:35vh}
  .flagship__pills{flex-direction:column;align-items:center}
  .story__stats{flex-direction:column;gap:16px}
  .signature__text{font-size:clamp(2rem,7vw,4rem)}
}

@media(max-width:480px){
  .service{padding:36px 24px}.testi{padding:32px 24px}
  .amenities__grid{gap:8px}.amenity{padding:20px 10px}
}
