/* ============================================================
   DUPLEX DYNASTY — Premium Design System v3
   Philosophy: Cinematic · Editorial · Intentional
   Colors: #0a0a0a (black) · #ffde59 (gold) · #f5f0e8 (cream)
   ============================================================ */

/* ── Tokens ── */
:root {
  --gold:          #ffde59;
  --gold-dim:      #c9a227;
  --gold-xfade:    rgba(255,222,89,0.10);
  --gold-border:   rgba(255,222,89,0.20);
  --black:         #0a0a0a;
  --black-warm:    #0e0d0b;
  --surface:       #131310;
  --surface-2:     #1a1916;
  --cream:         #f5f0e8;
  --cream-dim:     #c8bfb0;
  --white:         #ffffff;

  --airbnb:  #ff5a5f;
  --vrbo:    #3d6eff;
  --peer:    #00c48c;
  --dew:     #8b6fff;

  --font-display: 'Work Sans', sans-serif;
  --font-body:    'DM Sans', sans-serif;

  --r:      16px;
  --r-sm:   8px;
  --r-xs:   4px;
  --t:      0.3s cubic-bezier(0.4,0,0.2,1);
  --t-slow: 0.6s cubic-bezier(0.4,0,0.2,1);

  --shadow-deep:  0 24px 64px rgba(0,0,0,0.6);
  --shadow-gold:  0 0 48px rgba(255,222,89,0.10);
  --glow-gold:    0 0 32px rgba(255,222,89,0.20);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:17px;text-rendering:optimizeLegibility;}
body{background:var(--black);color:var(--cream-dim);font-family:var(--font-body);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{display:block;max-width:100%;height:auto;}
a{color:var(--gold);text-decoration:none;transition:opacity var(--t);}
a:hover{opacity:.8;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--white);line-height:1.08;letter-spacing:-0.01em;}

/* ── Layout ── */
.container{max-width:1240px;margin-inline:auto;padding-inline:clamp(1.25rem,4vw,3rem);}
.section{padding-block:clamp(4rem,10vw,8rem);}

/* ── Type utilities ── */
.overline{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-dim);margin-bottom:1rem;}
.overline::before{content:'';display:inline-block;width:24px;height:1px;background:var(--gold-dim);}

.display{font-size:clamp(3.5rem,10vw,8rem);font-weight:800;line-height:.95;letter-spacing:-.03em;color:var(--white);}
.h2{font-size:clamp(2rem,5vw,4rem);font-weight:700;letter-spacing:-.02em;}
.h3{font-size:clamp(1.25rem,2.5vw,2rem);font-weight:600;}

.gold-text{background:linear-gradient(120deg,#ffde59 0%,#ffe985 50%,#c9a227 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.cream-text{color:var(--cream);}
.muted{color:var(--cream-dim);}

.lead{font-size:clamp(1rem,1.8vw,1.15rem);line-height:1.75;color:var(--cream-dim);max-width:560px;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.85rem 2rem;border-radius:var(--r-sm);font-family:var(--font-display);font-size:.85rem;font-weight:700;letter-spacing:.03em;cursor:pointer;border:none;transition:all var(--t);white-space:nowrap;text-decoration:none;position:relative;overflow:hidden;}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0);transition:background var(--t);}
.btn:hover::after{background:rgba(255,255,255,.06);}

.btn-gold{background:var(--gold);color:var(--black);}
.btn-gold:hover{background:#ffe880;color:var(--black);opacity:1;transform:translateY(-2px);box-shadow:0 8px 32px rgba(255,222,89,.35);}

.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.2);}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);opacity:1;background:rgba(255,222,89,.05);}

.btn-ghost-gold{background:transparent;color:var(--gold);border:1px solid var(--gold-border);}
.btn-ghost-gold:hover{background:var(--gold-xfade);opacity:1;border-color:var(--gold);}

.btn-airbnb{background:var(--airbnb);color:#fff;}
.btn-airbnb:hover{background:#ff3b41;color:#fff;opacity:1;transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,90,95,.38);}
.btn-vrbo{background:var(--vrbo);color:#fff;}
.btn-vrbo:hover{background:#2554e8;color:#fff;opacity:1;transform:translateY(-2px);box-shadow:0 8px 28px rgba(61,110,255,.38);}
.btn-peerspace{background:var(--peer);color:#fff;}
.btn-peerspace:hover{background:#00a876;color:#fff;opacity:1;transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,196,140,.38);}

/* Arrow icon that slides on hover */
.btn-arrow svg{transition:transform var(--t);}
.btn-arrow:hover svg{transform:translateX(4px);}

/* ─────────────────────────────────────
   NAVIGATION
───────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.5rem 0;transition:all var(--t);}
.nav.scrolled{padding:.85rem 0;background:rgba(10,10,10,.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.06);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;}
.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;}
.nav-logo-img{width:36px;height:36px;border-radius:8px;object-fit:contain;}
.nav-wordmark{font-family:var(--font-display);font-size:.9rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--white);}
.nav-links{display:flex;align-items:center;gap:2.5rem;list-style:none;}
.nav-links a{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,240,232,.6);text-decoration:none;transition:color var(--t);}
.nav-links a:hover{color:var(--white);opacity:1;}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;}
.nav-toggle span{display:block;width:22px;height:1.5px;background:rgba(255,255,255,.7);border-radius:2px;transition:all var(--t);}

/* ─────────────────────────────────────
   HERO — Cinematic
───────────────────────────────────── */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform-origin:center;animation:kenBurns 22s ease-in-out infinite alternate;}
@keyframes kenBurns{from{transform:scale(1.0) translateY(0)}to{transform:scale(1.08) translateY(-1%)}}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.5) 55%,rgba(10,8,0,.72) 100%);}
.hero-content{position:relative;z-index:2;padding-top:8rem;padding-bottom:6rem;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;background:rgba(255,222,89,.08);border:1px solid rgba(255,222,89,.2);border-radius:50px;padding:.45rem 1.1rem;font-family:var(--font-display);font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:2rem;}
.hero-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2.5s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.hero h1{font-size:clamp(3.5rem,11vw,8.5rem);font-weight:800;line-height:.92;letter-spacing:-.03em;color:var(--white);margin-bottom:1.75rem;}
.hero h1 em{font-style:normal;}
.hero-sub{font-size:clamp(.95rem,1.8vw,1.1rem);color:rgba(245,240,232,.65);max-width:520px;margin-bottom:2.5rem;line-height:1.8;}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;}
/* Stat row */
.hero-stats{display:flex;gap:2.5rem;margin-top:4.5rem;padding-top:3rem;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap;}
.hero-stat{display:flex;flex-direction:column;}
.hero-stat-n{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--gold);line-height:1;}
.hero-stat-l{font-size:.72rem;color:rgba(245,240,232,.45);letter-spacing:.08em;text-transform:uppercase;margin-top:.3rem;}
/* Scroll cue */
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:2;cursor:pointer;}
.hero-scroll-bar{width:1px;height:52px;background:linear-gradient(180deg,transparent,rgba(255,222,89,.5));animation:scrollDrop 2.2s ease-in-out infinite;}
@keyframes scrollDrop{0%{opacity:0;transform:scaleY(0);transform-origin:top}50%{opacity:1;transform:scaleY(1)}100%{opacity:0;transform:scaleY(1) translateY(12px)}}
.hero-scroll-label{font-family:var(--font-display);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,222,89,.35);}

/* ─────────────────────────────────────
   MARQUEE
───────────────────────────────────── */
.marquee-strip{background:linear-gradient(90deg,var(--gold-dim) 0%,var(--gold) 50%,var(--gold-dim) 100%);padding:1rem 0;overflow:hidden;}
.marquee-track{display:flex;gap:3rem;white-space:nowrap;animation:marquee 24s linear infinite;}
.marquee-track span{font-family:var(--font-display);font-size:.68rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--black);display:flex;align-items:center;gap:.8rem;}
.marquee-track span::before{content:'✦';opacity:.3;}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─────────────────────────────────────
   PROPERTY CARDS — Full-bleed editorial
───────────────────────────────────── */
.props-section{background:var(--black-warm);}

/* Featured layout: 1 large + 2 stacked */
.props-editorial{display:grid;grid-template-columns:1.1fr 1fr;grid-template-rows:auto auto;gap:1.5rem;margin-top:3rem;}
.props-editorial .prop-card:first-child{grid-row:span 2;min-height:680px;}
.props-editorial .prop-card:not(:first-child){min-height:320px;}

.prop-card{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;display:flex;flex-direction:column;background:var(--surface);}
.prop-card-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow);}
.prop-card:hover .prop-card-bg{transform:scale(1.05);}
.prop-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.96) 0%,rgba(0,0,0,.55) 45%,rgba(0,0,0,.1) 100%);transition:background var(--t);}
.prop-card:hover .prop-card-overlay{background:linear-gradient(to top,rgba(0,0,0,.98) 0%,rgba(0,0,0,.65) 50%,rgba(0,0,0,.2) 100%);}
.prop-card-body{position:relative;z-index:1;margin-top:auto;padding:2rem;}
.prop-tag{display:inline-block;font-family:var(--font-display);font-size:.62rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;background:var(--gold);color:var(--black);padding:.25rem .7rem;border-radius:var(--r-xs);margin-bottom:.85rem;}
.prop-tag.both{background:linear-gradient(90deg,var(--airbnb),var(--vrbo));}
.prop-city{font-family:var(--font-display);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(245,240,232,.45);margin-bottom:.4rem;}
.prop-name{font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:700;color:var(--white);margin-bottom:.5rem;line-height:1.15;}
.prop-desc{font-size:.85rem;color:rgba(245,240,232,.55);line-height:1.6;margin-bottom:1.25rem;max-height:0;overflow:hidden;transition:max-height var(--t-slow),opacity var(--t);}
.prop-card:hover .prop-desc{max-height:100px;opacity:1;}
.prop-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;}
.prop-platforms{display:flex;gap:.4rem;}
.plat-chip{font-family:var(--font-display);font-size:.62rem;font-weight:700;letter-spacing:.06em;padding:.28rem .65rem;border-radius:var(--r-xs);text-decoration:none;transition:all var(--t);}
.plat-chip.airbnb{background:rgba(255,90,95,.15);color:#ff8c8f;border:1px solid rgba(255,90,95,.25);}
.plat-chip.vrbo{background:rgba(61,110,255,.15);color:#7fa3ff;border:1px solid rgba(61,110,255,.25);}
.plat-chip:hover{opacity:.8;}

/* Tab bar */
.city-tabs{display:flex;gap:.25rem;margin-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.06);}
.tab-btn{font-family:var(--font-display);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,240,232,.4);background:none;border:none;cursor:pointer;padding:.65rem 1.5rem .9rem;position:relative;transition:color var(--t);}
.tab-btn::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transition:transform var(--t);}
.tab-btn.active,.tab-btn:hover{color:var(--white);}
.tab-btn.active::after{transform:scaleX(1);}
.tab-panel{display:none;}.tab-panel.active{display:block;}

/* ─────────────────────────────────────
   CITY SECTIONS — Magazine layout
───────────────────────────────────── */
.city-section{padding-block:clamp(4rem,10vw,8rem);}
.city-section.htx{background:radial-gradient(ellipse 65% 70% at 90% 50%,rgba(255,222,89,.05) 0%,transparent 65%),var(--black);}
.city-section.rr{background:radial-gradient(ellipse 65% 70% at 10% 50%,rgba(255,222,89,.04) 0%,transparent 65%),var(--black-warm);}

.city-grid{display:grid;grid-template-columns:5fr 6fr;gap:clamp(2.5rem,6vw,6rem);align-items:center;}
.city-grid.flip{grid-template-columns:6fr 5fr;}
.city-grid.flip .city-visuals{order:2;}
.city-grid.flip .city-copy{order:1;}

/* Visuals: stacked photos */
.city-visuals{position:relative;}
.city-photo-main{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3.2;border:1px solid rgba(255,222,89,.12);}
.city-photo-main img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow);}
.city-photo-main:hover img{transform:scale(1.03);}
.city-photo-thumb{position:absolute;bottom:-1.5rem;right:-1.5rem;width:46%;aspect-ratio:4/3;border-radius:var(--r-sm);overflow:hidden;border:3px solid var(--black);box-shadow:var(--shadow-deep);}
.city-grid.flip .city-photo-thumb{right:auto;left:-1.5rem;}
.city-photo-thumb img{width:100%;height:100%;object-fit:cover;}

/* Gold accent corner */
.city-photo-main::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,222,89,.18) 0%,transparent 30%);pointer-events:none;z-index:1;border-radius:var(--r);}

/* Copy */
.city-copy{padding:.5rem 0 3rem;}
.city-h2{font-size:clamp(2rem,4.5vw,3.5rem);font-weight:800;letter-spacing:-.025em;margin-bottom:1.1rem;}
.city-h2 span{display:block;}
.city-lead{font-size:1rem;color:rgba(245,240,232,.6);line-height:1.75;margin-bottom:2rem;}

/* Stats row */
.city-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:2rem;}
.city-stat{padding:1rem;border:1px solid rgba(255,255,255,.07);border-radius:var(--r-sm);background:rgba(255,255,255,.02);transition:border-color var(--t);}
.city-stat:hover{border-color:rgba(255,222,89,.2);}
.city-stat-n{font-family:var(--font-display);font-size:1.4rem;font-weight:800;color:var(--gold);line-height:1;margin-bottom:.25rem;}
.city-stat-l{font-size:.7rem;color:rgba(245,240,232,.4);line-height:1.3;}

/* Nearby tags */
.nearby-label{font-family:var(--font-display);font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(245,240,232,.3);margin-bottom:.65rem;}
.nearby-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:2rem;}
.nearby-tag{font-size:.75rem;color:rgba(245,240,232,.55);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:50px;padding:.28rem .8rem;transition:all var(--t);}
.nearby-tag:hover{border-color:rgba(255,222,89,.2);color:var(--cream);}

.city-ctas{display:flex;gap:.75rem;flex-wrap:wrap;}

/* Gallery */
.gallery-wrap{margin-top:2.5rem;border-top:1px solid rgba(255,255,255,.06);padding-top:2rem;}
.gallery-label{font-family:var(--font-display);font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(245,240,232,.3);margin-bottom:1rem;}
.gallery-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;border-radius:var(--r);overflow:hidden;}
.gallery-grid .g-item{aspect-ratio:1/1;overflow:hidden;cursor:pointer;position:relative;}
.gallery-grid .g-item:first-child{grid-column:span 2;grid-row:span 2;aspect-ratio:auto;}
.gallery-grid .g-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow);}
.gallery-grid .g-item:hover img{transform:scale(1.07);}
.gallery-grid .g-item::after{content:'';position:absolute;inset:0;background:rgba(255,222,89,0);transition:background var(--t);}
.gallery-grid .g-item:hover::after{background:rgba(255,222,89,.06);}
.gallery-see-all{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.55);color:var(--white);
  font-family:var(--font-display);font-size:.75rem;font-weight:700;letter-spacing:.08em;
  opacity:0;transition:opacity var(--t);cursor:pointer;
  border:none; text-decoration:none;
}
.gallery-grid .g-item:last-child .gallery-see-all{opacity:1;background:rgba(0,0,0,.65);}
.gallery-grid .g-item:hover .gallery-see-all{opacity:1;}
.gallery-see-all:hover{opacity:1;background:rgba(0,0,0,.78);color:var(--gold);}

/* ─────────────────────────────────────
   BOOKING PLATFORMS
───────────────────────────────────── */
.booking-section{background:var(--surface);}
.platform-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3rem;}
.plat-card{background:var(--surface-2);border:1px solid rgba(255,255,255,.07);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--t),border-color var(--t),box-shadow var(--t);}
.plat-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-deep);}
.plat-card.airbnb:hover{border-color:rgba(255,90,95,.25);box-shadow:0 24px 48px rgba(255,90,95,.1);}
.plat-card.vrbo:hover{border-color:rgba(61,110,255,.25);box-shadow:0 24px 48px rgba(61,110,255,.1);}
.plat-card.peerspace:hover{border-color:rgba(0,196,140,.25);box-shadow:0 24px 48px rgba(0,196,140,.1);}

.plat-card-head{padding:1.5rem 1.5rem 1.25rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid rgba(255,255,255,.05);}
.plat-card.airbnb   .plat-card-head{background:linear-gradient(135deg,rgba(255,90,95,.08) 0%,transparent 100%);}
.plat-card.vrbo     .plat-card-head{background:linear-gradient(135deg,rgba(61,110,255,.08) 0%,transparent 100%);}
.plat-card.peerspace .plat-card-head{background:linear-gradient(135deg,rgba(0,196,140,.08) 0%,transparent 100%);}

.plat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.plat-card.airbnb   .plat-icon{background:rgba(255,90,95,.15);}
.plat-card.vrbo     .plat-icon{background:rgba(61,110,255,.15);}
.plat-card.peerspace .plat-icon{background:rgba(0,196,140,.15);font-size:1.4rem;}

.plat-name{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--white);}
.plat-sub{font-size:.75rem;color:rgba(245,240,232,.4);margin-top:.15rem;}
.plat-listings{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;flex:1;}
.plat-listing{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:var(--r-sm);text-decoration:none;transition:all var(--t);}
.plat-listing:hover{background:rgba(255,222,89,.05);border-color:var(--gold-border);opacity:1;}
.plat-listing-city{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,240,232,.35);margin-bottom:.15rem;}
.plat-listing-name{font-size:.88rem;font-weight:600;color:var(--white);}
.plat-arrow{color:var(--gold);opacity:.5;flex-shrink:0;transition:all var(--t);}
.plat-listing:hover .plat-arrow{opacity:1;transform:translateX(3px);}
.plat-desc{padding:.75rem 1.25rem;font-size:.85rem;color:rgba(245,240,232,.45);line-height:1.65;flex:1;}
.plat-card-foot{padding:1rem 1.25rem 1.5rem;border-top:1px solid rgba(255,255,255,.05);}
.plat-card-foot .btn{width:100%;justify-content:center;}

/* ─────────────────────────────────────
   AMENITIES
───────────────────────────────────── */
.amenities-section{background:var(--black);}
.amenities-layout{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2.5rem,6vw,6rem);align-items:center;}
.amenities-photo{border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,222,89,.12);aspect-ratio:4/3;}
.amenities-photo img{width:100%;height:100%;object-fit:cover;}
.amenities-list{margin-top:2.5rem;display:grid;grid-template-columns:1fr 1fr;gap:.6rem;}
.amenity{display:flex;align-items:center;gap:.85rem;padding:.85rem 1rem;border:1px solid rgba(255,255,255,.06);border-radius:var(--r-sm);font-size:.87rem;color:rgba(245,240,232,.6);transition:all var(--t);}
.amenity:hover{border-color:rgba(255,222,89,.18);color:var(--white);background:rgba(255,222,89,.04);}
.amenity-icon{width:32px;height:32px;border-radius:7px;background:rgba(255,222,89,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.amenity-icon svg{width:15px;height:15px;color:var(--gold);}

/* ─────────────────────────────────────
   WHY US
───────────────────────────────────── */
.why-section{background:linear-gradient(160deg,#0e0c07 0%,var(--black-warm) 100%);position:relative;overflow:hidden;}
.why-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(255,222,89,.06) 0%,transparent 70%);pointer-events:none;}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:3rem;}
.why-card{padding:2rem 1.75rem;border:1px solid rgba(255,222,89,.12);border-radius:var(--r);background:rgba(255,222,89,.03);position:relative;overflow:hidden;transition:all var(--t);}
.why-card:hover{background:rgba(255,222,89,.06);transform:translateY(-3px);box-shadow:var(--shadow-gold);}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);opacity:0;transition:opacity var(--t);}
.why-card:hover::before{opacity:1;}
.why-num{font-family:var(--font-display);font-size:3rem;font-weight:800;color:rgba(255,222,89,.07);line-height:1;margin-bottom:1.25rem;}
.why-card h4{font-size:.95rem;font-weight:700;color:var(--white);margin-bottom:.6rem;}
.why-card p{font-size:.83rem;color:rgba(245,240,232,.45);line-height:1.6;}

/* ─────────────────────────────────────
   FAQ
───────────────────────────────────── */
.faq-section{background:var(--surface);}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:3rem;}
.faq-item{border:1px solid rgba(255,255,255,.07);border-radius:var(--r-sm);overflow:hidden;transition:border-color var(--t);}
.faq-item.open{border-color:rgba(255,222,89,.2);}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.4rem;cursor:pointer;font-family:var(--font-display);font-size:.88rem;font-weight:600;color:var(--white);user-select:none;transition:color var(--t);}
.faq-q:hover{color:var(--gold);}
.faq-item.open .faq-q{color:var(--gold);}
.faq-icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:1px solid rgba(255,222,89,.2);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:.9rem;transition:transform var(--t),background var(--t);}
.faq-item.open .faq-icon{transform:rotate(45deg);background:rgba(255,222,89,.1);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding var(--t);padding:0 1.4rem;font-size:.86rem;color:rgba(245,240,232,.5);line-height:1.75;}
.faq-item.open .faq-a{max-height:240px;padding:0 1.4rem 1.15rem;}

/* ─────────────────────────────────────
   DEWBERRY HIDEOUT
───────────────────────────────────── */
.dewberry-section{background:radial-gradient(ellipse 70% 70% at 50% 50%,rgba(139,111,255,.12) 0%,transparent 65%),var(--black);padding-block:clamp(5rem,12vw,10rem);text-align:center;position:relative;overflow:hidden;}
.dew-badge{display:inline-flex;align-items:center;gap:.6rem;background:rgba(139,111,255,.1);border:1px solid rgba(139,111,255,.25);border-radius:50px;padding:.45rem 1.2rem;font-family:var(--font-display);font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#b09fff;margin-bottom:1.75rem;}
.dew-dot{width:6px;height:6px;border-radius:50%;background:#8b6fff;animation:pulse 2s ease-in-out infinite;}
.dew-h2{font-size:clamp(2.5rem,7vw,6rem);font-weight:800;letter-spacing:-.03em;color:var(--white);margin-bottom:1rem;}
.dew-h2 .dew-gold{color:var(--gold);}
.dew-lead{font-size:1rem;color:rgba(245,240,232,.5);max-width:500px;margin:0 auto 2.5rem;line-height:1.75;}
.countdown-wrap{display:flex;gap:1.5rem;justify-content:center;margin-bottom:2.5rem;flex-wrap:wrap;}
.countdown-unit{display:flex;flex-direction:column;align-items:center;}
.countdown-num{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:var(--white);background:rgba(139,111,255,.1);border:1px solid rgba(139,111,255,.2);border-radius:var(--r-sm);min-width:88px;text-align:center;padding:.5rem .25rem;line-height:1.1;}
.countdown-lbl{font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#8b6fff;margin-top:.45rem;}
.dew-link{display:inline-flex;align-items:center;gap:.6rem;background:rgba(139,111,255,.1);border:1.5px solid rgba(139,111,255,.3);border-radius:var(--r-sm);padding:.85rem 1.75rem;font-family:var(--font-display);font-size:.88rem;font-weight:700;color:#b09fff;text-decoration:none;transition:all var(--t);}
.dew-link:hover{background:rgba(139,111,255,.2);color:#b09fff;opacity:1;transform:translateY(-2px);box-shadow:0 8px 28px rgba(139,111,255,.2);}

/* ─────────────────────────────────────
   CONTACT
───────────────────────────────────── */
.contact-section{background:var(--black-warm);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start;}
.contact-links{display:flex;flex-direction:column;gap:.6rem;margin-top:2rem;}
.c-link{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--r-sm);color:rgba(245,240,232,.55);text-decoration:none;font-size:.88rem;transition:all var(--t);}
.c-link:hover{border-color:var(--gold-border);color:var(--gold);background:rgba(255,222,89,.04);opacity:1;}
.c-link-icon{width:38px;height:38px;border-radius:8px;background:rgba(255,222,89,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.c-link-icon svg{width:16px;height:16px;color:var(--gold);}

/* Form */
.form{display:flex;flex-direction:column;gap:.85rem;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;}
.fg{display:flex;flex-direction:column;gap:.35rem;}
.fg label{font-family:var(--font-display);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,240,232,.35);}
.fg input,.fg select,.fg textarea{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--r-sm);padding:.8rem 1rem;color:var(--white);font-family:var(--font-body);font-size:.9rem;transition:border-color var(--t),background var(--t);outline:none;-webkit-appearance:none;}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(245,240,232,.2);}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);background:rgba(255,222,89,.03);}
.fg select option{background:var(--surface);}
.fg textarea{resize:vertical;min-height:110px;}

/* ─────────────────────────────────────
   LIGHTBOX
───────────────────────────────────── */
.lightbox{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.97);align-items:center;justify-content:center;padding:1rem;}
.lightbox.open{display:flex;}
.lb-img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:var(--r-sm);}
.lb-close,.lb-nav{position:fixed;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);cursor:pointer;color:var(--white);transition:all var(--t);display:flex;align-items:center;justify-content:center;z-index:10000;}
.lb-close{top:1.5rem;right:1.5rem;width:44px;height:44px;border-radius:50%;font-size:1.2rem;}
.lb-close:hover{background:rgba(255,222,89,.15);color:var(--gold);border-color:var(--gold-border);}
.lb-nav{top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;font-size:1.4rem;}
.lb-nav:hover{background:rgba(255,222,89,.15);color:var(--gold);border-color:var(--gold-border);}
.lb-prev{left:1.25rem;}
.lb-next{right:1.25rem;}
.lb-counter{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);font-family:var(--font-display);font-size:.72rem;letter-spacing:.1em;color:rgba(245,240,232,.4);background:rgba(0,0,0,.5);padding:.35rem .9rem;border-radius:50px;}

/* ─────────────────────────────────────
   TALLY EMBED
───────────────────────────────────── */
.tally-wrap{
  width:100%;
  border-radius:var(--r);
  overflow:hidden;
}

/* Tally iframe inherits dark transparent background */
.tally-wrap iframe{
  display:block;
  border-radius:var(--r);
  min-height:400px;
}

/* ─────────────────────────────────────
   FOOTER
───────────────────────────────────── */
.footer{background:var(--black);border-top:1px solid rgba(255,255,255,.06);padding-block:2.25rem;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;}
.footer-logo{display:flex;align-items:center;gap:.65rem;}
.footer-logo img{width:30px;height:30px;border-radius:6px;}
.footer-brand{font-family:var(--font-display);font-size:.8rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--white);}
.footer-copy{font-size:.74rem;color:rgba(245,240,232,.3);}
.footer-social{display:flex;gap:.6rem;}
.footer-social a{width:34px;height:34px;border-radius:7px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:rgba(245,240,232,.4);text-decoration:none;transition:all var(--t);}
.footer-social a:hover{background:rgba(255,222,89,.1);color:var(--gold);border-color:var(--gold-border);opacity:1;}
.footer-social svg{width:14px;height:14px;}

/* ─────────────────────────────────────
   SCROLL ANIMATIONS
───────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}
.fade-up:nth-child(2){transition-delay:.08s;}
.fade-up:nth-child(3){transition-delay:.16s;}
.fade-up:nth-child(4){transition-delay:.24s;}
.fade-up:nth-child(5){transition-delay:.32s;}

/* ─────────────────────────────────────
   RESPONSIVE
───────────────────────────────────── */
@media(max-width:1024px){
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .platform-grid{grid-template-columns:1fr;}
  .props-editorial{grid-template-columns:1fr 1fr;}
  .props-editorial .prop-card:first-child{grid-row:span 1;min-height:400px;}
}

@media(max-width:900px){
  .city-grid,.city-grid.flip{grid-template-columns:1fr;}
  .city-grid.flip .city-visuals{order:0;}
  .city-grid.flip .city-copy{order:0;}
  .city-photo-thumb{right:0 !important;left:auto !important;}
  .contact-grid{grid-template-columns:1fr;}
  .faq-grid{grid-template-columns:1fr;}
  .amenities-layout{grid-template-columns:1fr;}
  .city-stats{grid-template-columns:repeat(4,1fr);}
  .props-editorial{grid-template-columns:1fr;}
}

@media(max-width:700px){
  .section{padding-block:3.5rem;}
  .nav-links,.nav .btn-gold{display:none;}
  .nav-toggle{display:flex;}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:58px;left:0;right:0;background:rgba(10,10,10,.97);backdrop-filter:blur(24px);padding:2rem;gap:1.5rem;border-bottom:1px solid var(--gold-border);z-index:999;}
  .nav .btn-gold.open{display:block;}
  .hero h1{letter-spacing:-.025em;}
  .hero-stats{gap:1.5rem;padding-top:2rem;}
  .why-grid{grid-template-columns:1fr;}
  .city-stats{grid-template-columns:1fr 1fr;}
  .form-row{grid-template-columns:1fr;}
  .footer-inner{flex-direction:column;text-align:center;}
  .gallery-grid{grid-template-columns:repeat(3,1fr);}
  .gallery-grid .g-item:first-child{grid-column:span 2;}
  .countdown-wrap{gap:.75rem;}
}

@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr 1fr;}
  .amenities-list{grid-template-columns:1fr;}
  .countdown-num{min-width:64px;font-size:1.8rem;}
  .hero-ctas{flex-direction:column;align-items:flex-start;}
}
