:root{
  --navy:#0A1F44;
  --navy-deep:#06152F;
  --navy-soft:#16305A;
  --gold:#C9A96E;
  --gold-deep:#A88A52;
  --ivory:#F5EFE0;
  --cream:#FAF6EC;
  --white:#FFFFFF;
  --ink:#1A1A1A;
  --gray:#6B6B6B;
  --line:rgba(201,169,110,.25);
  --serif:'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1240px;margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif)}
.gold{color:var(--gold)}
.uppercase{text-transform:uppercase;letter-spacing:.18em}
.tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.section{padding:96px 0}
.section-dark{background:var(--navy);color:var(--ivory)}
.section-cream{background:var(--cream)}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.15;letter-spacing:-.01em}
h2{font-size:clamp(32px,4.5vw,52px);margin-bottom:18px}
h3{font-size:clamp(22px,2.5vw,30px)}
p{font-size:16px;color:var(--gray)}
.section-dark p{color:rgba(245,239,224,.75)}
.lead{font-size:clamp(17px,1.4vw,20px);line-height:1.7;color:var(--gray);max-width:720px}
.section-dark .lead{color:rgba(245,239,224,.8)}
.divider{width:60px;height:1px;background:var(--gold);margin:24px 0}
.divider-center{margin:24px auto}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,31,68,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,169,110,.15);transition:transform .35s ease,background .3s,box-shadow .3s}
.nav--hidden{transform:translateY(-100%)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;gap:14px}
.nav-logo img{height:38px;width:auto}
.nav-menu{display:flex;gap:32px;align-items:center}
.nav-menu a{font-size:13px;color:rgba(245,239,224,.85);font-weight:500;letter-spacing:.04em;transition:color .2s}
.nav-menu a:hover{color:var(--gold)}
.btn{display:inline-block;padding:14px 28px;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;background:var(--gold);color:var(--navy);border:none;cursor:pointer;transition:all .3s;font-family:var(--sans)}
.btn:hover{background:var(--gold-deep);transform:translateY(-1px);box-shadow:0 8px 24px rgba(201,169,110,.4)}
.btn-outline{background:transparent;color:var(--gold);border:1px solid var(--gold)}
.btn-outline:hover{background:var(--gold);color:var(--navy)}
.btn-block{display:block;width:100%;padding:18px;font-size:14px}
.nav-cta{padding:11px 22px;font-size:12px}
.nav-toggle{display:none;background:none;border:0;color:var(--ivory);font-size:24px;cursor:pointer}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;color:var(--ivory);overflow:hidden;display:flex;align-items:center;padding:120px 0 60px}
.hero-bg{position:absolute;inset:0;background:url('../assets/hero/hero-main.jpg') center/cover;z-index:0}
.hero-photo-mobile{display:none}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(110deg,rgba(6,21,47,.94) 0%,rgba(10,31,68,.78) 45%,rgba(6,21,47,.5) 100%)}
/* Subtle gold corner ornament */
.hero::before,.hero::after{content:'';position:absolute;width:80px;height:80px;border:1px solid rgba(201,169,110,.3);z-index:1;pointer-events:none}
.hero::before{top:96px;left:32px;border-right:0;border-bottom:0}
.hero::after{bottom:32px;right:32px;border-left:0;border-top:0}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.35fr 1fr;gap:72px;align-items:start;width:100%}
.hero-mark{display:flex;align-items:center;gap:18px;margin-bottom:28px;opacity:.85}
.hero-mark img{height:32px}
.hero-mark span{font-size:10px;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);font-weight:500}
.hero h1{font-family:var(--serif);font-size:clamp(32px,4.4vw,56px);font-weight:300;color:var(--ivory);line-height:1.1;margin-bottom:14px;letter-spacing:-.015em}
.hero h1 em{font-style:italic;color:var(--gold);font-weight:400}
.hero-tagline{font-family:var(--serif);font-size:clamp(17px,1.6vw,22px);color:rgba(245,239,224,.92);line-height:1.5;font-style:italic;font-weight:300;max-width:580px;margin-bottom:0;padding-left:18px;border-left:2px solid var(--gold)}
.hero-sub{font-size:clamp(15px,1.3vw,17px);color:rgba(245,239,224,.82);line-height:1.75;max-width:580px;margin-top:24px;margin-bottom:0;font-weight:300}
.hero-sub strong{font-weight:600}
.hero-kicker{display:inline-flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;font-weight:600}
.hero-kicker::before,.hero-kicker::after{content:'';width:32px;height:1px;background:var(--gold);opacity:.6}
.hero-hook{margin:28px 0;padding:24px 28px 24px 32px;background:linear-gradient(135deg,rgba(201,169,110,.12) 0%,rgba(201,169,110,.04) 100%);border-left:3px solid var(--gold);font-family:var(--serif);font-size:19px;font-style:italic;color:var(--ivory);line-height:1.55;max-width:580px;position:relative;backdrop-filter:blur(8px)}
.hero-hook::before{content:'"';position:absolute;top:-8px;left:14px;font-size:64px;color:var(--gold);opacity:.4;line-height:1;font-family:var(--serif)}
.hero-hook .hook-line{display:block;margin-bottom:14px}
.hero-hook .hook-line:last-child{margin-bottom:0;padding-top:14px;border-top:1px solid rgba(201,169,110,.2)}
.hero-hook em{color:var(--gold);font-style:italic;font-weight:500;not-italic;font-style:normal;font-weight:600}

/* Hero privileges - FULL WIDTH BAR (4 cols ngang hàng) */
.priv-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:64px;background:rgba(201,169,110,.25);border:1px solid rgba(201,169,110,.35);position:relative;z-index:2}
.priv-cell{padding:28px 26px;background:rgba(6,21,47,.7);transition:all .35s;cursor:default;position:relative;overflow:hidden;backdrop-filter:blur(10px);min-height:200px;display:flex;flex-direction:column}
.priv-cell::before{content:'';position:absolute;top:0;left:0;width:0;height:2px;background:var(--gold);transition:width .45s ease}
.priv-cell:hover::before{width:100%}
.priv-cell:hover{background:rgba(201,169,110,.12);transform:translateY(-3px)}
.priv-num{font-family:var(--serif);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.priv-num::after{content:'';flex:1;height:1px;background:rgba(201,169,110,.35)}
.priv-name{font-family:var(--serif);font-size:21px;font-weight:500;color:var(--ivory);margin-bottom:12px;line-height:1.2;letter-spacing:-.005em}
.priv-desc{font-size:13px;color:rgba(245,239,224,.72);line-height:1.65;letter-spacing:.01em;margin-top:auto}

/* Hero gold scarcity strip — FULL WIDTH */
.hero-strip-full{display:flex;align-items:center;justify-content:space-between;margin-top:1px;padding:18px 32px;background:var(--gold);color:var(--navy);gap:24px;flex-wrap:wrap;position:relative;z-index:2}
.hero-strip-text{font-size:14px;font-weight:500;letter-spacing:.02em;flex:1;min-width:280px}
.hero-strip-text strong{font-family:var(--serif);font-size:19px;font-weight:700;font-style:italic;letter-spacing:.01em}
.hero-strip-cta{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;white-space:nowrap;color:var(--navy);text-decoration:none;border:1px solid var(--navy);padding:10px 22px;transition:all .25s}
.hero-strip-cta:hover{background:var(--navy);color:var(--gold)}
.hero-form{background:rgba(255,255,255,.04);backdrop-filter:blur(20px);border:1px solid rgba(201,169,110,.3);padding:36px 32px;margin-top:8px;align-self:start}
.hero-form .form-title{font-family:var(--serif);font-size:26px;color:var(--ivory);margin-bottom:8px;line-height:1.25}
.hero-form .form-sub{font-size:13px;color:rgba(245,239,224,.7);margin-bottom:24px}
.form-group{margin-bottom:14px}
.form-input,.form-select{width:100%;padding:14px 16px;background:rgba(255,255,255,.06);border:1px solid rgba(245,239,224,.18);color:var(--ivory);font-size:14px;font-family:var(--sans);transition:all .2s;outline:none}
.form-input::placeholder{color:rgba(245,239,224,.5)}
.form-input:focus,.form-select:focus{border-color:var(--gold);background:rgba(255,255,255,.08)}
.form-select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23C9A96E' d='M6 8 0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;padding-right:42px}
.form-select option{background:var(--navy);color:var(--ivory)}
.form-foot{margin-top:14px;font-size:11px;color:rgba(245,239,224,.55);text-align:center}

/* ============ STATS BAR ============ */
.stats-bar{background:var(--ivory);padding:48px 0;border-bottom:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:24px}
.stat{text-align:center;padding:8px}
.stat-num{font-family:var(--serif);font-size:clamp(32px,3.2vw,44px);font-weight:600;color:var(--navy);line-height:1;margin-bottom:6px}
.stat-num small{font-size:55%;color:var(--gold);font-weight:500}
.stat-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);font-weight:500}

/* ============ USP ============ */
.usp-head{text-align:center;margin-bottom:64px}
.usp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.usp-card{padding:40px 32px;background:var(--white);border:1px solid var(--line);transition:all .3s;position:relative}
.usp-card:hover{background:var(--navy);color:var(--ivory);border-color:var(--gold);transform:translateY(-4px);box-shadow:0 20px 60px rgba(10,31,68,.18)}
.usp-card:hover h3{color:var(--ivory)}
.usp-card:hover p{color:rgba(245,239,224,.82)}
.usp-card:hover .usp-stat{border-color:rgba(201,169,110,.25)}
.usp-num{font-family:var(--serif);font-size:48px;color:var(--gold);font-weight:300;line-height:1;margin-bottom:16px;font-style:italic}
.usp-card h3{margin-bottom:12px;color:var(--navy)}
.usp-card p{font-size:15px}
.usp-stat{margin-top:18px;padding-top:18px;border-top:1px solid var(--line);font-size:13px;color:var(--gold);font-weight:600;letter-spacing:.05em}

/* ============ LOCATION ============ */
.location-head{text-align:center;max-width:760px;margin:0 auto 40px}
.location-visual{position:relative;margin-bottom:40px}
.location-visual img{width:100%;height:auto;border:1px solid var(--line);display:block}
.location-info-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:stretch}
.location-distance{padding:32px;background:var(--cream);border:1px solid var(--line)}
.location-distance h4{font-family:var(--serif);font-size:20px;color:var(--navy);margin-bottom:18px;font-weight:500;display:flex;align-items:center;gap:10px}
.location-distance h4::before{content:'';width:32px;height:1px;background:var(--gold)}
.location-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0}
.location-list li{padding:14px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:12px}
.location-list li:nth-last-child(-n+2){border-bottom:0}
.location-list li:nth-child(odd){padding-right:18px;border-right:1px solid var(--line);padding-left:0}
.location-list li:nth-child(even){padding-left:18px}
.location-list .place{font-weight:500;color:var(--navy);font-size:13px;line-height:1.35}
.location-list .time{font-family:var(--serif);font-size:18px;color:var(--gold);font-weight:600;white-space:nowrap;font-style:italic}
.location-insight{padding:32px;background:var(--navy);color:var(--ivory);border-left:3px solid var(--gold);display:flex;flex-direction:column;justify-content:center}
.location-insight .insight-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.location-insight p{color:rgba(245,239,224,.92);font-size:15px;line-height:1.7;margin:0}
.location-insight strong{color:var(--gold);font-weight:600}
.location-insight-stat{margin-top:16px;padding-top:16px;border-top:1px solid rgba(201,169,110,.2);font-family:var(--serif);font-size:24px;color:var(--gold);font-style:italic;font-weight:600}

/* ============ ARCHITECTURE / VIEWS ============ */
.arch-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--navy)}
.arch-image{min-height:520px;background-size:cover;background-position:center}
.arch-content{padding:80px 60px;color:var(--ivory)}
.arch-content h2{color:var(--ivory)}
.arch-content p{color:rgba(245,239,224,.78);font-size:16px;margin-bottom:20px}
.view-stats{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px;padding-top:32px;border-top:1px solid rgba(201,169,110,.25)}
.view-stat{display:flex;align-items:baseline;gap:10px}
.view-num{font-family:var(--serif);font-size:36px;color:var(--gold);font-weight:600;line-height:1}
.view-label{font-size:13px;color:rgba(245,239,224,.7);letter-spacing:.05em}

/* ============ FLOOR PLANS ============ */
.plans-head{text-align:center;margin-bottom:64px}
.plans-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.plan-card{background:var(--white);border:1px solid var(--line);padding:36px 32px;transition:all .3s;position:relative}
.plan-card:hover{border-color:var(--gold);box-shadow:0 20px 50px rgba(10,31,68,.08)}
.plan-tag{display:inline-block;font-size:11px;padding:4px 10px;background:var(--navy);color:var(--gold);letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
.plan-card h3{color:var(--navy);margin-bottom:14px;font-size:26px}
.plan-card .area{font-family:var(--serif);font-size:22px;color:var(--gold);font-style:italic;margin-bottom:18px}
.plan-card .for{font-size:14px;color:var(--gray);margin-bottom:24px;line-height:1.6}
.plan-features{list-style:none;margin-bottom:24px}
.plan-features li{font-size:13px;color:var(--gray);padding:6px 0 6px 22px;position:relative}
.plan-features li::before{content:'';position:absolute;left:0;top:13px;width:10px;height:1px;background:var(--gold)}
.plan-cta-row{display:flex;gap:12px;flex-wrap:wrap}
.plan-cta-row .btn{flex:1;min-width:140px;font-size:12px;padding:12px 18px}

/* Lead magnet block — FORM 2 */
.leadmagnet{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-soft) 100%);color:var(--ivory);padding:80px 0;position:relative;overflow:hidden}
.leadmagnet::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(201,169,110,.15) 0%,transparent 70%);border-radius:50%}
.leadmagnet-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center;position:relative;z-index:1}
.leadmagnet h2{color:var(--ivory);margin-bottom:20px}
.leadmagnet p{color:rgba(245,239,224,.8);font-size:16px;margin-bottom:24px;max-width:520px}
.gift-list{list-style:none;margin-top:24px}
.gift-list li{padding:10px 0;font-size:14px;color:rgba(245,239,224,.9);display:flex;align-items:center;gap:12px}
.gift-list li::before{content:'✦';color:var(--gold);font-size:14px}

/* ============ CTA BAND NGANG · NHẬN THÔNG TIN ============ */
.cta-band{background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy) 55%,var(--navy-soft) 100%);color:var(--ivory);padding:60px 0;position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-band::before{content:'';position:absolute;top:-120px;right:-80px;width:380px;height:380px;background:radial-gradient(circle,rgba(201,169,110,.16) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.cta-band-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;position:relative;z-index:1}
.cta-band-title{font-size:clamp(26px,3vw,40px);color:var(--ivory);margin-bottom:10px}
.cta-band-sub{color:rgba(245,239,224,.8);font-size:16px;max-width:540px;margin:0}
.cta-band-form{display:flex;flex-wrap:wrap;gap:12px;align-items:stretch}
.cta-band-form .form-input{flex:1 1 200px;width:auto;margin:0}
.cta-band-form .btn{flex:0 0 auto;padding:14px 30px;white-space:nowrap}
.cta-band-note{flex:1 1 100%;font-size:12px;color:rgba(245,239,224,.6);margin-top:2px}
@media(max-width:860px){
  .cta-band{padding:48px 0}
  .cta-band-inner{grid-template-columns:1fr;gap:26px}
  .cta-band-form .form-input{flex:1 1 100%}
  .cta-band-form .btn{flex:1 1 100%;width:100%}
}

/* ============ AMENITIES ============ */
.amen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.amen-card{position:relative;overflow:hidden;aspect-ratio:4/5;cursor:default}
.amen-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.amen-card:hover img{transform:scale(1.05)}
.amen-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(6,21,47,.95) 100%);padding:24px;display:flex;flex-direction:column;justify-content:flex-end;color:var(--ivory)}
.amen-overlay .label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-weight:600}
.amen-overlay h4{font-family:var(--serif);font-size:24px;font-weight:400;line-height:1.2;margin-bottom:8px}
.amen-overlay p{font-size:13px;color:rgba(245,239,224,.8);line-height:1.55;margin:0}

/* External amenities */
.ext-amen{margin-top:64px;padding:48px;background:var(--white);border:1px solid var(--line)}
.ext-amen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.ext-amen-item{text-align:center}
.ext-amen-icon{width:54px;height:54px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;border:1px solid var(--gold);color:var(--gold);font-size:24px;border-radius:50%}
.ext-amen-item h4{font-family:var(--serif);font-size:20px;color:var(--navy);margin-bottom:8px}
.ext-amen-item p{font-size:13px;color:var(--gray);margin:0}

/* ============ PRODUCT TYPES ============ */
.product-table{margin-top:48px;background:var(--white);border:1px solid var(--line)}
.product-row{display:grid;grid-template-columns:1.4fr 1fr 1.6fr 1.4fr 200px;gap:24px;padding:24px 28px;border-bottom:1px solid var(--line);align-items:center}
.product-row:last-child{border-bottom:0}
.product-row.header{background:var(--navy);color:var(--ivory)}
.product-row.header div{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600}
.product-name{font-family:var(--serif);font-size:22px;color:var(--navy);font-weight:600}
.product-area{font-size:14px;color:var(--gold);font-weight:500}
.product-for{font-size:14px;color:var(--ink);font-weight:500}
.product-why{font-size:13px;color:var(--gray);line-height:1.5}
.product-row .btn{font-size:11px;padding:10px 16px}

/* ============ PRICING ============ */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:48px}
.price-card{padding:48px 40px;border:1px solid var(--line);background:var(--white);position:relative}
.price-card.featured{background:var(--navy);color:var(--ivory);border-color:var(--gold)}
.price-card.featured h3{color:var(--ivory)}
.price-card.featured p{color:rgba(245,239,224,.75)}
.price-badge{position:absolute;top:-12px;right:24px;background:var(--gold);color:var(--navy);padding:6px 14px;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase}
.price-card h3{color:var(--navy);margin-bottom:8px;font-size:24px}
.price-amount{font-family:var(--serif);font-size:52px;font-weight:600;color:var(--gold);line-height:1;margin:20px 0 6px;font-style:italic}
.price-unit{font-size:14px;color:var(--gray);margin-bottom:20px}
.price-card.featured .price-unit{color:rgba(245,239,224,.7)}
.price-features{list-style:none;margin:24px 0}
.price-features li{padding:10px 0;font-size:14px;border-bottom:1px solid var(--line)}
.price-card.featured .price-features li{border-color:rgba(201,169,110,.2);color:rgba(245,239,224,.85)}
.price-features li:last-child{border:0}
.price-note{font-size:12px;color:var(--gray);margin-top:16px;font-style:italic}
.price-card.featured .price-note{color:rgba(245,239,224,.6)}

/* ============ CSBH - Payment policy ============ */
.csbh-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.csbh-card{padding:36px 32px;background:var(--cream);border-top:3px solid var(--gold)}
.csbh-card h4{font-family:var(--serif);font-size:22px;color:var(--navy);margin-bottom:8px}
.csbh-card .csbh-rate{font-size:13px;color:var(--gold);font-weight:600;text-transform:uppercase;letter-spacing:.14em;margin-bottom:16px}
.csbh-card ul{list-style:none}
.csbh-card li{padding:8px 0;font-size:14px;color:var(--ink);display:flex;justify-content:space-between}
.csbh-card li span:last-child{color:var(--gold);font-weight:600}
.csbh-highlight{background:var(--ivory);padding:14px;margin-top:16px;font-size:13px;color:var(--navy);line-height:1.5;font-weight:500}

/* ============ LEGAL / TIMELINE ============ */
.timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:48px;position:relative}
.timeline::before{content:'';position:absolute;top:24px;left:5%;right:5%;height:1px;background:var(--gold);opacity:.4;z-index:0}
.timeline-step{text-align:center;position:relative;z-index:1;padding:0 12px}
.timeline-dot{width:48px;height:48px;background:var(--white);border:2px solid var(--gold);border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;color:var(--gold);font-family:var(--serif);font-weight:600;font-size:18px}
.timeline-step.done .timeline-dot{background:var(--gold);color:var(--navy)}
.timeline-date{font-size:11px;color:var(--gold);font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.timeline-label{font-size:13px;color:var(--ink);font-weight:500;line-height:1.4}

.legal-list{margin-top:32px;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.legal-item{padding:16px 20px;background:var(--cream);border-left:3px solid var(--gold);font-size:14px;color:var(--ink)}

/* ============ SOCIAL PROOF ============ */
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.proof-card{padding:36px;background:var(--white);border:1px solid var(--line)}
.proof-quote{font-family:var(--serif);font-size:18px;line-height:1.6;color:var(--navy);margin-bottom:24px;font-style:italic}
.proof-quote::before{content:'"';font-size:48px;color:var(--gold);line-height:0;vertical-align:-12px;margin-right:6px}
.proof-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--line)}
.proof-avatar{width:48px;height:48px;border-radius:50%;background:var(--ivory);display:flex;align-items:center;justify-content:center;color:var(--gold);font-family:var(--serif);font-weight:600;font-size:20px}
.proof-name{font-size:14px;font-weight:600;color:var(--navy)}
.proof-role{font-size:12px;color:var(--gray)}

.partners{margin-top:80px;padding:48px;background:var(--cream);text-align:center}
.partners h3{color:var(--navy);margin-bottom:36px}
.partners-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.partner-item h4{font-family:var(--serif);font-size:36px;color:var(--gold);font-weight:600;margin-bottom:6px}
.partner-item p{font-size:13px;color:var(--gray);margin:0}

/* ============ SALE PROFILE ============ */
.sale-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:center;background:var(--navy);color:var(--ivory);padding:64px;position:relative;overflow:hidden}
.sale-wrap::before{content:'';position:absolute;top:0;right:0;width:300px;height:300px;background:radial-gradient(circle,rgba(201,169,110,.15) 0%,transparent 70%)}
.sale-avatar{width:280px;height:280px;border-radius:50%;background:url('../assets/sale/truong-van-binh.webp') center top/cover no-repeat,linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 100%);border:6px solid rgba(201,169,110,.35);margin:0 auto;box-shadow:0 18px 48px rgba(0,0,0,.35);position:relative}
.sale-content h2{color:var(--ivory);margin-bottom:8px}
.sale-content .sale-title{font-size:14px;color:var(--gold);font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:24px}
.sale-content p{color:rgba(245,239,224,.85);font-size:16px;margin-bottom:18px}
.sale-creds{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:32px 0;padding:24px 0;border-top:1px solid rgba(201,169,110,.25);border-bottom:1px solid rgba(201,169,110,.25)}
.sale-cred-num{font-family:var(--serif);font-size:32px;color:var(--gold);font-weight:600;line-height:1}
.sale-cred-label{font-size:12px;color:rgba(245,239,224,.7);margin-top:4px;letter-spacing:.05em}
.sale-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.sale-pledge{margin-top:20px;padding:18px;background:rgba(255,255,255,.05);border-left:3px solid var(--gold);font-family:var(--serif);font-style:italic;font-size:17px;color:var(--ivory)}

/* ============ FAQ ============ */
.faq-list{max-width:860px;margin:48px auto 0}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{padding:24px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--serif);font-size:20px;color:var(--navy);font-weight:500;transition:color .2s}
.faq-q:hover{color:var(--gold)}
.faq-q .arrow{font-size:24px;color:var(--gold);transition:transform .3s;flex-shrink:0}
.faq-item.open .arrow{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;font-size:15px;color:var(--gray);line-height:1.7}
.faq-item.open .faq-a{max-height:400px;padding-bottom:24px}

/* ============ FINAL CTA ============ */
.final-cta{background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy) 50%,var(--navy-soft) 100%);color:var(--ivory);padding:120px 0;text-align:center;position:relative;overflow:hidden}
.final-cta::before,.final-cta::after{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(201,169,110,.1) 0%,transparent 70%)}
.final-cta::before{top:-200px;left:-200px}
.final-cta::after{bottom:-200px;right:-200px}
.final-cta-inner{position:relative;z-index:1;max-width:780px;margin:0 auto}
.final-cta h2{color:var(--ivory);font-size:clamp(36px,5vw,58px);margin-bottom:18px}
.final-cta h2 em{color:var(--gold);font-style:italic}
.final-cta .lead{color:rgba(245,239,224,.85);max-width:600px;margin:0 auto 16px}
.final-benefits{display:flex;justify-content:center;gap:48px;margin:32px 0;flex-wrap:wrap}
.final-benefit{font-size:14px;color:var(--gold);font-weight:600;letter-spacing:.06em}
.final-form{max-width:560px;margin:32px auto 0;background:rgba(255,255,255,.05);border:1px solid rgba(201,169,110,.3);padding:36px;backdrop-filter:blur(14px)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.final-trust{margin-top:18px;font-size:12px;color:rgba(245,239,224,.6);letter-spacing:.05em}

/* ============ FOOTER ============ */
.footer{background:var(--navy-deep);color:rgba(245,239,224,.7);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo img{height:48px;margin-bottom:18px}
.footer h5{font-family:var(--serif);font-size:18px;color:var(--ivory);margin-bottom:18px;font-weight:500}
.footer ul{list-style:none}
.footer li{padding:6px 0;font-size:14px}
.footer li a:hover{color:var(--gold)}
.footer-bottom{padding-top:32px;border-top:1px solid rgba(245,239,224,.1);font-size:12px;color:rgba(245,239,224,.5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* ============ FLOATING CTA (rung + pulse ring) ============ */
.float-cta{position:fixed;right:24px;bottom:24px;z-index:900;display:flex;flex-direction:column;gap:18px}
.float-btn{width:58px;height:58px;border-radius:50%;background:var(--gold);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:26px;cursor:pointer;transition:transform .25s,background .25s;border:0;text-decoration:none;position:relative;animation:phone-shake 2.6s cubic-bezier(.36,.07,.19,.97) infinite,pulse-ring-gold 2s ease-out infinite;transform-origin:center}
.float-btn:hover{transform:scale(1.12);background:var(--gold-deep);animation-play-state:paused}
.float-btn.zalo{background:#0068FF;color:#fff;font-size:13px;font-weight:700;letter-spacing:.05em;animation:phone-shake 2.6s cubic-bezier(.36,.07,.19,.97) infinite,pulse-ring-blue 2s ease-out infinite;animation-delay:.7s,.7s}
.float-btn.zalo:hover{background:#0050C2}

@keyframes phone-shake{
  0%, 65%, 100% { transform: rotate(0deg); }
  68%, 76%, 84% { transform: rotate(-15deg); }
  72%, 80%, 88% { transform: rotate(15deg); }
  92% { transform: rotate(0deg); }
}
@keyframes pulse-ring-gold{
  0% { box-shadow: 0 0 0 0 rgba(201,169,110,.55), 0 8px 24px rgba(10,31,68,.35); }
  70% { box-shadow: 0 0 0 22px rgba(201,169,110,0), 0 8px 24px rgba(10,31,68,.35); }
  100% { box-shadow: 0 0 0 0 rgba(201,169,110,0), 0 8px 24px rgba(10,31,68,.35); }
}
@keyframes pulse-ring-blue{
  0% { box-shadow: 0 0 0 0 rgba(0,104,255,.55), 0 8px 24px rgba(10,31,68,.35); }
  70% { box-shadow: 0 0 0 22px rgba(0,104,255,0), 0 8px 24px rgba(10,31,68,.35); }
  100% { box-shadow: 0 0 0 0 rgba(0,104,255,0), 0 8px 24px rgba(10,31,68,.35); }
}

/* Sticky mobile CTA */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--navy);padding:12px;z-index:900;gap:8px;border-top:1px solid var(--gold)}
.mobile-cta .btn{flex:1;font-size:12px;padding:14px;text-align:center}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero{padding-top:100px;padding-bottom:40px}
  .priv-bar{grid-template-columns:repeat(2,1fr);margin-top:48px}
  .priv-cell{min-height:auto;padding:22px 20px}
  .priv-name{font-size:18px}
  .hero-strip-full{padding:16px 20px;gap:14px}
  .hero-strip-cta{padding:10px 18px}
  .arch-grid{grid-template-columns:1fr}
  .arch-content{padding:48px 32px}
  .stats-grid{grid-template-columns:repeat(3,1fr);gap:32px}
  .usp-grid{grid-template-columns:1fr;gap:20px}
  .location-info-grid{grid-template-columns:1fr;gap:20px}
  .location-distance{padding:24px}
  .location-list{grid-template-columns:1fr}
  .location-list li{padding:12px 0!important;border-right:0!important;padding-left:0!important;padding-right:0!important;border-bottom:1px solid var(--line)!important}
  .location-list li:last-child{border-bottom:0!important}
  .leadmagnet-grid{grid-template-columns:1fr;gap:32px}
  .amen-grid{grid-template-columns:repeat(2,1fr)}
  .ext-amen-grid{grid-template-columns:1fr;gap:24px}
  .plans-grid{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr;gap:20px}
  .csbh-grid{grid-template-columns:1fr;gap:20px}
  .timeline{grid-template-columns:repeat(5,1fr);gap:8px}
  .timeline::before{display:none}
  .proof-grid{grid-template-columns:1fr}
  .partners-grid{grid-template-columns:1fr;gap:24px}
  .sale-wrap{grid-template-columns:1fr;padding:40px 28px;gap:24px;text-align:center}
  .sale-avatar{width:180px;height:180px;font-size:64px}
  .sale-cta{justify-content:center}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .product-row{grid-template-columns:1fr;gap:8px;padding:24px}
  .product-row.header{display:none}
  .product-name{font-size:20px}
  .nav-menu{display:none}
  .nav-cta{display:none}
  .nav-toggle{display:block}
  .nav-menu.open{display:flex;position:absolute;top:72px;left:0;right:0;background:var(--navy);flex-direction:column;padding:24px;gap:18px;border-bottom:1px solid var(--gold)}
  .mobile-cta{display:none}                                /* bỏ thanh Gọi ngay / Nhận tư vấn */
  .float-cta{bottom:20px}
  .hero-mark{display:none}                                 /* bỏ "Part of the M Series | ..." */
  .hero-kicker{display:none}                               /* bỏ "Private Residences · Số ít..." */
  .section{padding:64px 0}
  .legal-list{grid-template-columns:1fr}
  .ext-amen{padding:32px 24px}
  .form-row{grid-template-columns:1fr}
}
@media (max-width:600px){
  .priv-bar{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .amen-grid{grid-template-columns:1fr}
  .hero-form{padding:28px 22px}
  .container{padding:0 18px}
  .final-benefits{gap:16px;flex-direction:column}
  .timeline{grid-template-columns:repeat(2,1fr);row-gap:24px}
  .footer-grid{grid-template-columns:1fr}
  /* ----- Hero mobile: gọn gàng ----- */
  .hero::before,.hero::after{display:none}                 /* bỏ ô góc vàng */
  .hero-tagline{font-size:17px;padding-left:14px}
}
/* ----- Hero mobile: hiện ảnh phối cảnh đầy đủ & rõ ----- */
@media (max-width:860px){
  .hero{min-height:auto}                                   /* không ép cao 100vh để bố cục thoáng */
  .hero-photo-mobile{display:block;width:100%;height:auto;margin-top:30px;border:1px solid rgba(201,169,110,.4);box-shadow:0 16px 46px rgba(0,0,0,.5)}
  .hero-bg::after{background:linear-gradient(180deg,rgba(6,21,47,.92) 0%,rgba(6,21,47,.86) 100%)} /* nền tối đều cho chữ dễ đọc */
}

/* ============ ARCHITECTURAL DIVIDER (full-width parallax) ============ */
.arch-divider{position:relative;min-height:520px;background-size:cover;background-position:center;background-attachment:fixed;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--ivory);overflow:hidden}
.arch-divider::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,21,47,.75) 0%,rgba(10,31,68,.55) 50%,rgba(6,21,47,.85) 100%);z-index:0}
.arch-divider-inner{position:relative;z-index:1;max-width:760px;padding:80px 32px}
.arch-divider .tag{color:var(--gold)}
.arch-divider h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,44px);color:var(--ivory);font-weight:300;line-height:1.25;font-style:italic;margin:0}
.arch-divider h2 em{color:var(--gold);font-style:italic}
.arch-divider .quote-mark{font-family:var(--serif);font-size:90px;color:var(--gold);line-height:.5;opacity:.4;margin-bottom:-30px;display:block}
.arch-divider-attr{margin-top:28px;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:600}
.arch-divider-attr::before,.arch-divider-attr::after{content:'—';margin:0 12px;color:rgba(201,169,110,.5)}
/* corners ornament */
.arch-divider .corner{position:absolute;width:60px;height:60px;border:1px solid rgba(201,169,110,.4);z-index:1}
.arch-divider .corner.tl{top:32px;left:32px;border-right:0;border-bottom:0}
.arch-divider .corner.tr{top:32px;right:32px;border-left:0;border-bottom:0}
.arch-divider .corner.bl{bottom:32px;left:32px;border-right:0;border-top:0}
.arch-divider .corner.br{bottom:32px;right:32px;border-left:0;border-top:0}

@media (max-width:1024px){
  .arch-divider{background-attachment:scroll;min-height:380px}
  .arch-divider-inner{padding:60px 24px}
  .arch-divider .corner{width:40px;height:40px}
  .arch-divider .corner.tl,.arch-divider .corner.tr{top:16px}
  .arch-divider .corner.tl,.arch-divider .corner.bl{left:16px}
  .arch-divider .corner.tr,.arch-divider .corner.br{right:16px}
  .arch-divider .corner.bl,.arch-divider .corner.br{bottom:16px}
}

/* ============ VIDEO SLIDER (horizontal) ============ */
.video-slider{position:relative;margin-top:48px}
.video-slider-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;padding:8px 4px 24px;margin:-8px -4px 0}
.video-slider-track::-webkit-scrollbar{display:none}
.video-slide{flex:0 0 calc(50% - 12px);scroll-snap-align:start;position:relative;overflow:hidden;cursor:pointer;aspect-ratio:16/9;background:var(--navy)}
.video-slide img{width:100%;height:100%;object-fit:cover;transition:transform .6s,opacity .3s;opacity:.85}
.video-slide:hover img{transform:scale(1.04);opacity:1}
.video-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:28px;background:linear-gradient(180deg,transparent 35%,rgba(6,21,47,.95) 100%);color:var(--ivory);pointer-events:none}
.video-overlay .label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-weight:600}
.video-overlay h4{font-family:var(--serif);font-size:24px;font-weight:500;line-height:1.25;margin-bottom:6px}
.video-overlay p{font-size:13px;color:rgba(245,239,224,.78);margin:0}
.video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;background:rgba(201,169,110,.92);display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:26px;transition:all .3s;backdrop-filter:blur(8px);padding-left:4px}
.video-slide:hover .video-play{background:var(--gold);transform:translate(-50%,-50%) scale(1.1);box-shadow:0 16px 40px rgba(0,0,0,.45)}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:var(--navy);color:var(--gold);border:1px solid var(--gold);cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .25s;font-family:var(--serif);box-shadow:0 8px 24px rgba(10,31,68,.25)}
.slider-btn:hover{background:var(--gold);color:var(--navy);transform:translateY(-50%) scale(1.06)}
.slider-btn.prev{left:-26px}
.slider-btn.next{right:-26px}
.slider-btn:disabled{opacity:.3;cursor:not-allowed;transform:translateY(-50%)}
.slider-dots{display:flex;justify-content:center;gap:8px;margin-top:24px}
.slider-dot{width:32px;height:3px;background:var(--line);cursor:pointer;border:0;transition:background .25s;padding:0}
.slider-dot.active{background:var(--gold)}
.slider-counter{position:absolute;top:-44px;right:0;font-family:var(--serif);font-size:18px;color:var(--gray);letter-spacing:.05em}
.slider-counter strong{color:var(--gold);font-weight:600}

/* ============ 360 TOUR ============ */
.tour-wrap{margin-top:48px;background:var(--navy);padding:0;position:relative;overflow:hidden}
.tour-iframe-wrap{position:relative;width:100%;aspect-ratio:16/9;background:var(--navy-deep)}
.tour-iframe-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.tour-cta-row{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;background:var(--navy);color:var(--ivory);flex-wrap:wrap;gap:16px}
.tour-cta-row .tour-info{display:flex;align-items:center;gap:14px}
.tour-cta-row .tour-info span{font-size:14px;color:rgba(245,239,224,.85)}
.tour-cta-row .tour-info strong{color:var(--gold);display:block;font-size:16px;font-weight:600;margin-bottom:2px;font-family:var(--serif)}

/* ============ TYPICAL UNITS / FLOOR PLANS ============ */
.typ-tabs{display:flex;gap:0;margin-top:48px;border-bottom:2px solid var(--line);overflow-x:auto;scrollbar-width:none}
.typ-tabs::-webkit-scrollbar{display:none}
.typ-tab{padding:18px 32px;font-size:14px;font-weight:600;letter-spacing:.05em;color:var(--gray);border-bottom:2px solid transparent;cursor:pointer;background:transparent;border:0;border-bottom:2px solid transparent;font-family:var(--sans);transition:all .2s;white-space:nowrap;margin-bottom:-2px}
.typ-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.typ-tab:hover:not(.active){color:var(--navy)}
.typ-panel{display:none;padding:48px 0}
.typ-panel.active{display:block}
.typ-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:flex-start}
.typ-image{background:var(--cream);padding:20px;border:1px solid var(--line)}
.typ-image img{width:100%;height:auto;display:block}
.typ-image .typ-image-cap{font-size:12px;color:var(--gray);margin-top:10px;text-align:center;font-style:italic}
.typ-info h3{color:var(--navy);font-size:32px;margin-bottom:8px}
.typ-info .typ-sub{font-size:14px;color:var(--gold);font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:24px}
.typ-specs{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:24px 0;padding:24px;background:var(--cream);border-left:3px solid var(--gold)}
.typ-spec-num{font-family:var(--serif);font-size:28px;color:var(--navy);font-weight:600;line-height:1}
.typ-spec-num small{font-size:14px;color:var(--gold);font-weight:500}
.typ-spec-label{font-size:12px;color:var(--gray);margin-top:4px;letter-spacing:.04em}
.typ-features{list-style:none;margin:20px 0 24px}
.typ-features li{padding:8px 0 8px 26px;position:relative;font-size:14px;color:var(--ink)}
.typ-features li::before{content:'✦';position:absolute;left:0;color:var(--gold);font-size:13px;top:9px}
.typ-price-block{padding:24px;background:var(--navy);color:var(--ivory);margin:20px 0;border-left:3px solid var(--gold)}
.typ-price-block .typ-price-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:8px}
.typ-price-block .typ-price-amount{font-family:var(--serif);font-size:32px;font-weight:600;color:var(--ivory);line-height:1.1}
.typ-price-block .typ-price-amount em{color:var(--gold);font-style:italic}
.typ-price-block .typ-price-note{font-size:12px;color:rgba(245,239,224,.65);margin-top:8px}
.typ-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.typ-cta-row .btn{flex:1;min-width:180px}

/* ============ MEDIA GALLERY ============ */
.gallery-filters{display:flex;justify-content:center;gap:8px;margin:32px 0 40px;flex-wrap:wrap}
.gallery-filter{padding:10px 20px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;background:transparent;border:1px solid var(--line);color:var(--gray);cursor:pointer;transition:all .2s;font-family:var(--sans)}
.gallery-filter.active,.gallery-filter:hover{background:var(--navy);color:var(--gold);border-color:var(--navy)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.gallery-item{position:relative;overflow:hidden;aspect-ratio:1/1;cursor:pointer;background:var(--cream)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item.hidden{display:none}
.gallery-item::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(6,21,47,.7) 100%);opacity:0;transition:opacity .3s;z-index:1}
.gallery-item:hover::before{opacity:1}
.gallery-item .gallery-label{position:absolute;bottom:0;left:0;right:0;padding:14px 16px;color:var(--ivory);font-size:12px;font-weight:500;opacity:0;transform:translateY(8px);transition:all .3s;z-index:2;letter-spacing:.02em}
.gallery-item:hover .gallery-label{opacity:1;transform:translateY(0)}
.gallery-item.is-video::after{content:'▶';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:rgba(201,169,110,.92);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:13px;padding-left:3px;z-index:2;transition:all .3s}
.gallery-item.is-video:hover::after{background:var(--gold);transform:translate(-50%,-50%) scale(1.1)}

/* Lightbox */
.lightbox{display:none;position:fixed;inset:0;background:rgba(6,21,47,.96);z-index:2500;align-items:center;justify-content:center;padding:32px}
.lightbox.open{display:flex}
.lightbox-content{max-width:1280px;max-height:90vh;width:100%;position:relative}
.lightbox-content img,.lightbox-content video{max-width:100%;max-height:90vh;display:block;margin:0 auto}
.lightbox-content iframe{width:100%;aspect-ratio:16/9;border:0}
.lightbox-close{position:absolute;top:-44px;right:0;background:transparent;border:0;color:var(--ivory);font-size:36px;cursor:pointer;line-height:1}
.lightbox-cap{margin-top:16px;text-align:center;color:rgba(245,239,224,.8);font-size:14px}

@media (max-width:1024px){
  .video-slide{flex:0 0 88%}
  .slider-btn.prev{left:8px}
  .slider-btn.next{right:8px}
  .slider-btn{width:44px;height:44px;font-size:18px}
  .typ-grid{grid-template-columns:1fr;gap:28px}
  .typ-info h3{font-size:26px}
  .typ-specs{grid-template-columns:1fr 1fr;padding:18px;gap:14px}
  .gallery-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .tour-cta-row{padding:18px}
  .tour-cta-row .btn{width:100%}
}
@media (max-width:600px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .typ-cta-row{flex-direction:column}
  .typ-tab{padding:14px 18px;font-size:13px}
  .typ-specs{grid-template-columns:1fr}
}

/* Modal */
.modal{display:none;position:fixed;inset:0;background:rgba(6,21,47,.85);z-index:2000;align-items:center;justify-content:center;padding:24px}
.modal.open{display:flex}
.modal-box{background:var(--white);max-width:480px;width:100%;padding:40px;position:relative}
.modal-close{position:absolute;top:16px;right:18px;background:0;border:0;font-size:24px;cursor:pointer;color:var(--gray)}
.modal h3{color:var(--navy);margin-bottom:8px}
.modal p{font-size:14px;margin-bottom:20px}
.modal .form-input{background:var(--cream);color:var(--ink);border-color:var(--line)}
.modal .form-input::placeholder{color:var(--gray)}
.modal .form-input:focus{background:var(--white);border-color:var(--gold)}
.modal .form-select{background-color:var(--cream);color:var(--ink);border-color:var(--line)}
.modal .form-select option{background:var(--white);color:var(--ink)}

.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(calc(100% + 56px));background:var(--gold);color:var(--navy);padding:16px 32px;font-weight:600;font-size:14px;z-index:3000;transition:transform .4s;box-shadow:0 12px 32px rgba(10,31,68,.3);pointer-events:none}
.toast.show{pointer-events:auto}
.toast.show{transform:translateX(-50%) translateY(0)}
