/* ===========================
   TVH AURORA VILLAS - STYLES
   Fonts & Colors matched to brochure
   =========================== */

/* Brochure fonts:
   Headings/Logo : Cormorant Garamond — elegant serif matching brochure titles
   Labels/UI     : Raleway           — thin geometric sans matching brochure labels
   Body text     : Jost              — clean modern sans matching brochure body
*/
@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@100;200;300;400;500;600&family=Jost:wght@200;300;400;500;600&display=swap');
@font-face {
  font-family: 'Masonry';
  src: url('fonts/Medium.woff2') format('woff2'),
       url('fonts/Medium.woff') format('woff'),
       url('fonts/Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
}
/* === CSS VARIABLES — exact brochure palette === */
:root {
  /* Brochure navy — deep blue from cover & back page */
  --navy:       #1B2A5E;
  --navy-dark:  #122050;
  --navy-mid:   #243270;
  --navy-light: #2d3d7a;

  /* Brochure gold — warm gold from "Experience luxury" script & rule lines */
  --gold:       #C9A84C;
  --gold-light: #DFC06E;
  --gold-pale:  #F0DFA8;
  --gold-dim:   rgba(201,168,76,0.15);

  /* Brochure cream — warm off-white from light content pages */
  --cream:      #F5EFE6;
  --cream-dark: #EDE3D5;
  --cream-mid:  #E8DDD0;

  --white: #FFFFFF;

  /* Text tones */
  --text-dark:  #1B2A5E;
  --text-mid:   #4A5578;
  --text-light: #8A90AA;

  --transition: cubic-bezier(0.4, 0, 0.2, 1);
}

/* === RESET === */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Jost', sans-serif;
  background: var(--cream);
  color: var(--text-dark);
  overflow-x: hidden;
  cursor: none;
}

/* === CUSTOM CURSOR === */
.cursor {
  width: 12px; height: 12px;
  background: var(--gold); border-radius: 50%;
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9999;
  transition: transform 0.15s var(--transition), opacity 0.3s;
  transform: translate(-50%, -50%);
}
.cursor-follower {
  width: 36px; height: 36px;
  border: 1px solid rgba(201,168,76,0.5); border-radius: 50%;
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9998;
  transition: transform 0.4s var(--transition), opacity 0.3s;
  transform: translate(-50%, -50%);
}
.cursor.hover { transform: translate(-50%,-50%) scale(2.5); background: rgba(201,168,76,0.4); }
.cursor-follower.hover { transform: translate(-50%,-50%) scale(1.5); }

/* === PRELOADER === */
.preloader {
  position: fixed; inset: 0;
  background: var(--navy-dark); z-index: 10000;
  display: flex; align-items: center; justify-content: center; flex-direction: column;
  transition: opacity 0.8s var(--transition), visibility 0.8s;
}
.preloader.hidden { opacity: 0; visibility: hidden; }
.preloader-logo {
  font-family: 'Masonry', serif;
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 300; letter-spacing: 0.4em; color: var(--white);
  animation: preloaderPulse 1.5s ease-in-out infinite;
}
.preloader-logo span { color: var(--gold); }
.preloader-sub {
  font-family: 'Raleway', sans-serif;
  font-size: 0.62rem; font-weight: 300; letter-spacing: 0.5em;
  text-transform: uppercase; color: rgba(255,255,255,0.35); margin-top: 0.5rem;
}
.preloader-bar {
  width: 200px; height: 1px;
  background: rgba(255,255,255,0.1); margin-top: 2rem; overflow: hidden; position: relative;
}
.preloader-bar::after {
  content: ''; position: absolute; top: 0; left: -100%;
  width: 100%; height: 100%; background: var(--gold);
  animation: preloaderLine 2s var(--transition) forwards;
}
@keyframes preloaderPulse { 0%,100%{opacity:0.4} 50%{opacity:1} }
@keyframes preloaderLine  { 0%{left:-100%} 100%{left:0} }

/* === HEADER === */
header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  padding: 1.5rem 4rem;
  display: flex; align-items: center; justify-content: space-between;
  transition: all 0.5s var(--transition);
}
header.scrolled {
  background: rgba(18,32,80,0.97);
  backdrop-filter: blur(20px);
  padding: 1rem 4rem;
  box-shadow: 0 2px 40px rgba(0,0,0,0.35);
}
.nav-logo { display: flex; align-items: center; text-decoration: none; gap: 0; }
.nav-logo::after { display: none !important; }
.nav-logo-img { height: 75px; width: auto; display: block; }
.nav-logo-img { height: 85px; width: auto; }
.nav-logo-tvh {
  font-family: 'Raleway', sans-serif; font-size: 0.6rem; font-weight: 600;
  letter-spacing: 0.65em; color: var(--gold);
}
.nav-logo-name {
  font-family: 'Masonry', serif; font-size: 1.3rem; font-weight: 400;
  letter-spacing: 0.25em; color: var(--white); line-height: 1.2;
}
.nav-logo-name span { color: var(--gold); }
.nav-logo-tagline {
  font-family: 'Raleway', sans-serif; font-size: 0.5rem; font-weight: 300;
  letter-spacing: 0.35em; text-transform: uppercase; color: rgba(255,255,255,0.4); margin-top: 0.15rem;
}
.nav-links { display: flex; align-items: center; gap: 2.5rem; list-style: none; }
.nav-links a {
  font-family: 'Raleway', sans-serif; font-weight: 400; font-size: 0.7rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,0.8); text-decoration: none; position: relative; transition: color 0.3s;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -4px; left: 0;
  width: 0; height: 1px; background: var(--gold);
  transition: width 0.4s var(--transition);
}
.nav-logo::after { display: none !important; }
.nav-links a:hover { color: var(--gold); }
.nav-links a:hover::after { width: 100%; }
.nav-cta {
  background: transparent !important; border: 1px solid var(--gold) !important;
  color: var(--gold) !important; padding: 0.55rem 1.4rem; cursor: pointer; transition: all 0.3s !important;
}
.nav-cta:hover { background: var(--gold) !important; color: var(--navy-dark) !important; }
.nav-cta::after { display: none !important; }
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 5px; }
.hamburger span { display: block; width: 25px; height: 1.5px; background: var(--white); transition: all 0.3s; }

/* === MOBILE MENU === */
.mobile-menu {
  position: fixed; inset: 0; background: var(--navy-dark); z-index: 999;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2rem;
  transform: translateX(100%); transition: transform 0.5s var(--transition);
}
.mobile-menu.open { transform: translateX(0); }
.mobile-menu .nav-links { flex-direction: column; gap: 1.5rem; text-align: center; }
.mobile-menu .nav-links a { font-size: 1.3rem; letter-spacing: 0.15em; }
.close-menu { position: absolute; top: 2rem; right: 2rem; font-size: 1.5rem; color: var(--white); background: none; border: none; cursor: pointer; }

/* === HERO === */
.hero { height: 100vh; min-height: 700px; position: relative; display: flex; align-items: center; overflow: hidden; }
.hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(145deg, #0e1940 0%, #1B2A5E 45%, #243270 75%, #1B2A5E 100%);
}
/* Sample background image — replace with real villa photo when ready */
.hero-bg-img {
  position: absolute; inset: 0;
  background-image: url('https://images.unsplash.com/photo-1613977257363-707ba9348227?w=1800&q=80');
  background-size: cover; background-position: center 30%;
  opacity: 0.18; mix-blend-mode: luminosity;
}
.hero-bg-pattern {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(ellipse at 75% 50%, rgba(201,168,76,0.10) 0%, transparent 60%),
    radial-gradient(ellipse at 15% 80%, rgba(201,168,76,0.06) 0%, transparent 50%);
}
.hero-particles { position: absolute; inset: 0; overflow: hidden; }
.particle {
  position: absolute; width: 1px; height: 1px;
  background: var(--gold); border-radius: 50%;
  animation: particleFloat linear infinite; opacity: 0;
}
@keyframes particleFloat {
  0%   { transform: translateY(100vh) scale(0); opacity: 0; }
  10%  { opacity: 0.7; }
  90%  { opacity: 0.2; }
  100% { transform: translateY(-100px) scale(1); opacity: 0; }
}
.hero-architectural-lines { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.arch-line { position: absolute; background: rgba(201,168,76,0.1); }
.arch-line-1 { width:1px; height:60%; top:20%; right:20%; animation:drawLine 2s ease forwards 1s; transform-origin:top; transform:scaleY(0); }
.arch-line-2 { width:25%; height:1px; top:20%; right:20%; animation:drawLineH 2s ease forwards 1.2s; transform-origin:right; transform:scaleX(0); }
.arch-line-3 { width:1px; height:40%; bottom:20%; left:15%; animation:drawLine 2s ease forwards 1.5s; transform-origin:bottom; transform:scaleY(0); }
@keyframes drawLine  { to { transform: scaleY(1); } }
@keyframes drawLineH { to { transform: scaleX(1); } }

.hero-content { position: relative; z-index: 2; padding: 0 6rem; max-width: 1400px; margin: 0 auto; width: 100%; }
/* .hero-tag {
  font-family: 'Raleway', sans-serif; font-size: 0.62rem; font-weight: 400;
  letter-spacing: 0.45em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 1.5rem; opacity: 0; transform: translateY(20px);
  animation: fadeUp 0.8s var(--transition) forwards 0.5s;
  display: flex; align-items: center; gap: 1rem;
} */

.hero-headline {
  font-family: 'Masonry', serif;
  font-size: clamp(3.5rem, 7vw, 6.5rem); font-weight: 300; line-height: 1.05;
  color: var(--white); margin-bottom: 1.5rem; overflow: hidden; margin-top: 3.5rem;
}
.hero-headline .line { display:block; opacity:0; transform:translateY(100%); animation:slideUp 1s var(--transition) forwards; }
.hero-headline .line:nth-child(1) { animation-delay: 0.7s; }
.hero-headline .line:nth-child(2) { animation-delay: 0.9s; font-style:italic; color:var(--gold-light); font-weight:300; }
.hero-headline .line:nth-child(3) { animation-delay: 1.1s; }
.hero-subtitle {
  font-family: 'Jost', sans-serif; font-weight: 200; font-size: 1rem;
  letter-spacing: 0.06em; color: rgba(255,255,255,0.6); max-width: 450px; line-height: 1.85;
  opacity: 0; transform: translateY(20px); animation: fadeUp 0.8s var(--transition) forwards 1.3s; margin-bottom: 3rem;
}
.hero-actions {
  display: flex; align-items: center; gap: 2rem;
  opacity: 0; transform: translateY(20px); animation: fadeUp 0.8s var(--transition) forwards 1.5s;
}
.btn-primary {
  background: var(--gold); color: var(--navy-dark); border: none; padding: 1rem 2.5rem;
  font-family: 'Raleway', sans-serif; font-weight: 600; font-size: 0.7rem;
  letter-spacing: 0.32em; text-transform: uppercase;
  text-decoration: none; display: inline-block; cursor: pointer;
  position: relative; overflow: hidden; transition: all 0.4s var(--transition);
}
.btn-primary::before {
  content:''; position:absolute; inset:0; background:var(--navy-dark);
  transform:translateX(-100%); transition:transform 0.4s var(--transition);
}
.btn-primary:hover { color: var(--gold); }
.btn-primary:hover::before { transform: translateX(0); }
.btn-primary span { position: relative; z-index: 1; }
.btn-outline {
  background: transparent; color: rgba(255,255,255,0.7); border: none; padding: 0;
  font-family: 'Raleway', sans-serif; font-weight: 400; font-size: 0.7rem;
  letter-spacing: 0.25em; text-transform: uppercase; text-decoration: none;
  display: inline-flex; align-items: center; gap: 0.75rem; cursor: pointer; transition: color 0.3s;
}
.btn-outline::after { content:'→'; transition:transform 0.3s; }
.btn-outline:hover { color: var(--gold); }
.btn-outline:hover::after { transform: translateX(6px); }

.hero-stats {
  position: absolute; right: 6rem; bottom: 4rem; display: flex; gap: 3rem;
  opacity: 0; animation: fadeUp 0.8s var(--transition) forwards 1.8s;
}
.hero-stat-item { text-align: center; border-left: 1px solid rgba(201,168,76,0.3); padding-left: 1.5rem; }
.hero-stat-num { font-family:'Masonry',serif; font-size:2.2rem; font-weight:400; color:var(--gold); line-height:1; display:block; }
.hero-stat-label { font-family:'Raleway',sans-serif; font-size:0.58rem; font-weight:300; letter-spacing:0.22em; text-transform:uppercase; color:rgba(255,255,255,0.4); display:block; margin-top:0.3rem; }

.hero-scroll-indicator {
  position: absolute; bottom: 3rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  opacity: 0; animation: fadeIn 1s forwards 2.2s;
}
.scroll-text { font-family:'Raleway',sans-serif; font-size:0.55rem; letter-spacing:0.3em; text-transform:uppercase; color:rgba(255,255,255,0.35); writing-mode:vertical-rl; }
.scroll-line { width:1px; height:60px; background:linear-gradient(to bottom, var(--gold), transparent); animation:scrollPulse 2s ease-in-out infinite; }
@keyframes scrollPulse { 0%,100%{opacity:0.3;transform:scaleY(1)} 50%{opacity:1;transform:scaleY(0.6)} }

/* === KEYFRAMES === */
@keyframes fadeUp  { to { opacity:1; transform:translateY(0); } }
@keyframes slideUp { to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn  { to { opacity:1; } }

/* === SECTION COMMONS === */
.section { position: relative; }
.section-tag {
  font-family: 'Raleway', sans-serif; font-size: 0.6rem; font-weight: 500;
  letter-spacing: 0.45em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 1rem; display: flex; align-items: center; gap: 1rem;
}
.section-tag::before { content:''; display:block; width:30px; height:1px; background:var(--gold); }
.section-title { font-family:'Masonry',serif; font-size:clamp(2.2rem,4vw,3.5rem); font-weight:400; line-height:1.15; color:var(--navy); }
.section-title.light { color: var(--white); }
.section-title em { font-style:italic; color:var(--gold); font-weight:300; }
.section-body { font-family:'Jost',sans-serif; font-weight:300; font-size:0.95rem; line-height:1.9; color:var(--text-mid); }
.section-body.light { color: rgba(255,255,255,0.6); }

/* Reveal animations */
.reveal        { opacity:0; transform:translateY(40px); transition:opacity 0.9s var(--transition),transform 0.9s var(--transition); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left   { opacity:0; transform:translateX(-60px); transition:opacity 0.9s var(--transition),transform 0.9s var(--transition); }
.reveal-left.visible { opacity:1; transform:translateX(0); }
.reveal-right  { opacity:0; transform:translateX(60px); transition:opacity 0.9s var(--transition),transform 0.9s var(--transition); }
.reveal-right.visible { opacity:1; transform:translateX(0); }
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; }
.delay-5 { transition-delay: 0.5s; }
.delay-6 { transition-delay: 0.6s; }

/* === ABOUT === */
.about {
  padding: 8rem 6rem; background: var(--cream);
  display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center;
  max-width: 1400px; margin: 0 auto;
}
.about-visual { position: relative; height: 600px; }
/* Sample images — swap URLs for real photos */
.about-img-main {
  width: 75%; height: 500px; position: absolute; top: 0; right: 0;
  background-image: url('https://images.unsplash.com/photo-1600585154340-be6161a56a0c?w=900&q=80');
  background-size: cover; background-position: center;
  box-shadow: 30px 30px 80px rgba(27,42,94,0.18);
}
.about-img-accent {
  width: 50%; height: 280px; position: absolute; bottom: 0; left: 0;
  background-image: url('https://images.unsplash.com/photo-1600566753086-00f18fb6b3ea?w=600&q=80');
  background-size: cover; background-position: center;
  box-shadow: 20px 20px 50px rgba(27,42,94,0.18);
  border: 6px solid var(--cream);
}
.about-badge {
  position: absolute; top: 50%; right: -30px; transform: translateY(-50%);
  width: 100px; height: 100px; background: var(--gold); border-radius: 50%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  z-index: 2; animation: rotateBadge 20s linear infinite;
}
.about-badge-num  { font-family:'Raleway',sans-serif; font-size:1rem; font-weight:700; color:var(--navy-dark); line-height:1; }
.about-badge-text { font-family:'Raleway',sans-serif; font-size:0.48rem; font-weight:400; letter-spacing:0.08em; color:var(--navy-dark); text-transform:uppercase; line-height:1.3; text-align:center; }
@keyframes rotateBadge { from{transform:translateY(-50%) rotate(0deg)} to{transform:translateY(-50%) rotate(360deg)} }
.about-content { padding: 1rem 0; }
.about-divider { width:60px; height:2px; background:linear-gradient(to right, var(--gold), transparent); margin: 1.5rem 0 2rem; }
.about-features { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-top:2.5rem; }
.about-feature { display:flex; align-items:flex-start; gap:1rem; }
.feature-icon { width:40px; height:40px; min-width:40px; border:1px solid rgba(201,168,76,0.3); display:flex; align-items:center; justify-content:center; font-size:1rem; transition:all 0.3s; }
.about-feature:hover .feature-icon { background:var(--gold); border-color:var(--gold); }
.feature-text h4 { font-family:'Raleway',sans-serif; font-size:0.7rem; font-weight:600; letter-spacing:0.15em; text-transform:uppercase; color:var(--navy); margin-bottom:0.2rem; }
.feature-text p  { font-size:0.82rem; color:var(--text-light); line-height:1.5; }

/* === VILLAS === */
.villas-section { background:var(--navy-dark); padding:8rem 6rem; position:relative; overflow:hidden; }
.villas-section::before { content:''; position:absolute; top:-100px; right:-100px; width:600px; height:600px; border-radius:50%; background:radial-gradient(ellipse, rgba(201,168,76,0.07) 0%, transparent 70%); }
.villas-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:4rem; max-width:1400px; margin-left:auto; margin-right:auto; }
.villas-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; max-width:1400px; margin:0 auto; }
.villa-card { position:relative; overflow:hidden; cursor:pointer; transition:transform 0.6s var(--transition); }
.villa-card-inner { position:relative; height:480px; overflow:hidden; }
.villa-card-bg { position:absolute; inset:0; transition:transform 0.8s var(--transition); }
.villa-card:hover .villa-card-bg { transform:scale(1.06); }
/* Sample villa images — replace with real exterior photos */
.villa-img-1 { width:100%;height:100%; background-image:url('https://images.unsplash.com/photo-1613977257592-4871e5fcd7c4?w=800&q=80'); background-size:cover; background-position:center; }
.villa-img-2 { width:100%;height:100%; background-image:url('https://images.unsplash.com/photo-1583608205776-bfd35f0d9f83?w=800&q=80'); background-size:cover; background-position:center; }
.villa-img-3 { width:100%;height:100%; background-image:url('https://images.unsplash.com/photo-1600047509807-ba8f99d2cdde?w=800&q=80'); background-size:cover; background-position:center; }
.villa-img-4 { width:100%;height:100%; background-image:url('https://images.unsplash.com/photo-1600596542815-ffad4c1539a9?w=800&q=80'); background-size:cover; background-position:center; }

.villa-card-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(18,32,80,0.95) 0%, rgba(18,32,80,0.4) 50%, transparent 100%); transition:opacity 0.4s; }
.villa-card:hover .villa-card-overlay { background:linear-gradient(to top, rgba(18,32,80,0.98) 0%, rgba(18,32,80,0.6) 60%, rgba(18,32,80,0.2) 100%); }
.villa-card-content { position:absolute; bottom:0; left:0; right:0; padding:2rem; }
.villa-number { font-family:'Raleway',sans-serif; font-size:0.6rem; letter-spacing:0.35em; color:var(--gold); margin-bottom:0.5rem; }
.villa-name   { font-family:'Masonry',serif; font-size:1.8rem; font-weight:400; color:var(--white); margin-bottom:0.5rem; }
.villa-size   { font-family:'Jost',sans-serif; font-size:0.8rem; font-weight:300; color:rgba(255,255,255,0.6); letter-spacing:0.1em; }
.villa-details { margin-top:1.2rem; opacity:0; transform:translateY(20px); transition:all 0.5s var(--transition) 0.1s; display:flex; gap:0.6rem; flex-wrap:wrap; }
.villa-card:hover .villa-details { opacity:1; transform:translateY(0); }
.villa-detail-pill { font-family:'Raleway',sans-serif; font-size:0.6rem; letter-spacing:0.15em; color:rgba(255,255,255,0.7); border:1px solid rgba(201,168,76,0.35); padding:0.3rem 0.7rem; }
.villa-cta { display:inline-flex; align-items:center; gap:0.6rem; margin-top:1rem; font-family:'Raleway',sans-serif; font-size:0.62rem; letter-spacing:0.25em; text-transform:uppercase; color:var(--gold); opacity:0; transform:translateY(10px); transition:all 0.4s var(--transition) 0.2s; }
.villa-card:hover .villa-cta { opacity:1; transform:translateY(0); }

/* === FEATURES === */
.features-section { padding: 6rem; background: var(--cream); }
.features-inner   { max-width: 1400px; margin: 0 auto; }
.features-header { text-align:center; margin-bottom:5rem; }
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.feature-card {
  padding: 2rem;
  background: var(--white);
  border: 1px solid rgba(27,42,94,0.07);
  border-radius: 10px;
  position: relative;
  transition: all 0.4s;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}
.feature-card::before { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--gold); transition:width 0.5s var(--transition); }
.feature-card:hover {
  box-shadow: 0 12px 40px rgba(27,42,94,0.1);
  transform: translateY(-4px);
}
.feature-card:hover::before { width:100%; }
/* Top row: number on left, icon on right */
.feature-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.5rem;
}
.feature-card-num {
  font-family: 'Masonry', serif;
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--gold);
  line-height: 1;
}
.feature-card-icon-box {
  width: 44px; height: 44px;
  border: 1px solid rgba(201,168,76,0.35);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  background: var(--cream);
  transition: background 0.3s;
}
.feature-card:hover .feature-card-icon-box {
  background: var(--gold);
  border-color: var(--gold);
}
.feature-card:hover .feature-card-num { color:rgba(201,168,76,0.28); }
.feature-card-icon  { font-size:1.4rem; margin-bottom:1.2rem; display:block; }
.feature-card-title {
  font-family: 'Raleway', sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--navy);
}

.feature-card-text {
  font-family: 'Jost', sans-serif;
  font-size: 0.85rem;
  font-weight: 300;
  color: var(--text-mid);
  line-height: 1.8;
}
/* === FLOOR PLANS === */
.floorplan-section { background:var(--cream-dark); padding:8rem 6rem; }
.floorplan-inner   { max-width:1400px; margin:0 auto; }
.floorplan-header  { margin-bottom:3rem; }
.floorplan-tabs { display:flex; gap:0; margin-bottom:3rem; border-bottom:1px solid rgba(27,42,94,0.12); }
.floorplan-tab { font-family:'Raleway',sans-serif; font-size:0.68rem; font-weight:500; letter-spacing:0.22em; text-transform:uppercase; color:var(--text-light); padding:0.8rem 1.8rem; border-bottom:2px solid transparent; margin-bottom:-1px; cursor:pointer; transition:all 0.3s; background:none; border-top:none; border-left:none; border-right:none; }
.floorplan-tab:hover { color:var(--navy); }
.floorplan-tab.active { color:var(--gold); border-bottom-color:var(--gold); }
.floorplan-pane { display:none; }
.floorplan-pane.active { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.floorplan-image-container { position:relative; background:var(--white); padding:2rem; box-shadow:0 10px 40px rgba(27,42,94,0.08); }
/* Floor plan placeholder — replace div with <img src="images/floorplan-v1-ground.jpg"> */
.floorplan-placeholder { height:450px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.6rem; background:linear-gradient(135deg, var(--cream) 0%, var(--cream-dark) 100%); text-align:center; }
.floorplan-placeholder-icon  { font-size:3rem; opacity:0.35; }
.floorplan-placeholder-label { font-family:'Masonry',serif; font-size:1.1rem; font-weight:400; letter-spacing:0.2em; color:var(--navy); opacity:0.55; }
.floorplan-placeholder-area  { font-family:'Raleway',sans-serif; font-size:0.72rem; font-weight:500; letter-spacing:0.3em; color:var(--gold); }
.floorplan-placeholder-note  { font-family:'Jost',sans-serif; font-size:0.62rem; font-weight:300; color:var(--text-light); margin-top:0.3rem; }
.floorplan-info { padding:1rem 0; }
.floorplan-villa-name  { font-family:'Masonry',serif; font-size:2.5rem; font-weight:400; color:var(--navy); margin-bottom:0.3rem; }
.floorplan-total-area  { font-family:'Raleway',sans-serif; font-size:0.7rem; font-weight:500; letter-spacing:0.3em; color:var(--gold); text-transform:uppercase; margin-bottom:2rem; }
.floorplan-breakdown   { margin-bottom:2rem; }
.floorplan-floor-item  { display:flex; justify-content:space-between; align-items:center; padding:0.9rem 0; border-bottom:1px solid rgba(27,42,94,0.06); }
.floor-label     { font-family:'Jost',sans-serif; font-size:0.82rem; font-weight:300; letter-spacing:0.06em; color:var(--text-mid); }
.floor-label-sub { font-family:'Jost',sans-serif; font-size:0.68rem; font-weight:300; color:var(--text-light); margin-top:0.2rem; }
.floor-area      { font-family:'Masonry',serif; font-size:1.2rem; font-weight:400; color:var(--navy); }

/* === SPECS === */
.specs-section { background:var(--navy); padding:8rem 6rem; position:relative; overflow:hidden; }
.specs-section::after { content:''; position:absolute; bottom:0; left:0; width:100%; height:2px; background:linear-gradient(to right, transparent, var(--gold), transparent); }
.specs-inner { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:1fr 2fr; gap:6rem; align-items:start; }
.specs-header { position:sticky; top:120px; }
.specs-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.spec-item { padding:1.8rem; border:1px solid rgba(255,255,255,0.07); position:relative; transition:all 0.4s; }
.spec-item::before { content:''; position:absolute; top:0; left:0; width:3px; height:0; background:var(--gold); transition:height 0.4s var(--transition); }
.spec-item:hover { border-color:rgba(201,168,76,0.22); background:rgba(255,255,255,0.02); }
.spec-item:hover::before { height:100%; }
.spec-category { font-family:'Raleway',sans-serif; font-size:0.58rem; letter-spacing:0.35em; text-transform:uppercase; color:var(--gold); margin-bottom:0.5rem; }
.spec-title    { font-family:'Masonry',serif; font-size:1.3rem; font-weight:400; color:var(--white); margin-bottom:0.5rem; }
.spec-desc     { font-family:'Jost',sans-serif; font-size:0.82rem; font-weight:300; line-height:1.75; color:rgba(255,255,255,0.45); }

/* === LOCATION === */
.location-section { padding:8rem 6rem; background:var(--cream); }
.location-inner   { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:1fr 1.2fr; gap:5rem; align-items:center; }
.location-map { height:480px; position:relative; overflow:hidden; box-shadow:0 20px 60px rgba(27,42,94,0.15); }
.location-map iframe { width:100%; height:100%; border:none; }
.location-map::before { content:''; position:absolute; inset:0; border:2px solid rgba(201,168,76,0.35); z-index:2; pointer-events:none; }
.location-address { margin-top:1.5rem; padding:1.2rem 1.8rem; background:var(--navy-dark); display:flex; align-items:center; gap:1.5rem; }
.location-pin { font-size:1.2rem; color:var(--gold); }
.address-text { font-family:'Jost',sans-serif; font-size:0.85rem; line-height:1.65; color:rgba(255,255,255,0.65); }
.address-text strong { font-family:'Raleway',sans-serif; font-weight:500; letter-spacing:0.1em; color:var(--white); display:block; margin-bottom:0.2rem; }
.location-nearby-item { display:flex; align-items:center; gap:0.8rem; margin-bottom:0.75rem; }
.location-nearby-dot  { color:var(--gold); font-size:0.65rem; }
.location-nearby-text { font-family:'Jost',sans-serif; font-size:0.88rem; font-weight:300; color:var(--text-mid); }

/* === CONTACT === */
.contact-section { background:var(--navy-dark); padding:8rem 6rem; position:relative; overflow:hidden; }
.contact-bg-text { position:absolute; font-family:'Masonry',serif; font-size:clamp(6rem,15vw,16rem); font-weight:300; color:rgba(255,255,255,0.02); top:50%; left:50%; transform:translate(-50%,-50%); white-space:nowrap; pointer-events:none; user-select:none; }
.contact-inner { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:center; position:relative; z-index:1; }
.contact-form-group { margin-bottom:1.2rem; }
.contact-form-group input,
.contact-form-group select,
.contact-form-group textarea {
  width:100%; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.1);
  color:var(--white); padding:0.95rem 1.2rem;
  font-family:'Jost',sans-serif; font-size:0.88rem; font-weight:300;
  outline:none; transition:border-color 0.3s; appearance:none; letter-spacing:0.04em;
}
.contact-form-group input::placeholder,
.contact-form-group textarea::placeholder { color:rgba(255,255,255,0.28); }
.contact-form-group input:focus,
.contact-form-group select:focus,
.contact-form-group textarea:focus { border-color:var(--gold); }
.contact-form-group select { cursor:pointer; color:rgba(255,255,255,0.55); }
.contact-form-group select option { background:var(--navy-dark); color:var(--white); }
.contact-form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.contact-submit {
  width:100%; background:var(--gold); border:none; color:var(--navy-dark); padding:1.1rem;
  font-family:'Raleway',sans-serif; font-weight:700; font-size:0.7rem;
  letter-spacing:0.35em; text-transform:uppercase;
  cursor:pointer; position:relative; overflow:hidden; transition:all 0.4s; margin-top:0.5rem;
}
.contact-submit::before { content:''; position:absolute; inset:0; background:var(--gold-light); transform:scaleX(0); transform-origin:left; transition:transform 0.4s var(--transition); }
.contact-submit:hover::before { transform:scaleX(1); }
.contact-submit span { position:relative; z-index:1; }
.contact-info { padding:1rem 0; }
.contact-detail { display:flex; align-items:flex-start; gap:1.5rem; margin-bottom:2.5rem; }
.contact-detail-icon { width:44px; height:44px; min-width:44px; border:1px solid rgba(201,168,76,0.3); display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:1rem; }
.contact-detail-text h4 { font-family:'Raleway',sans-serif; font-size:0.6rem; font-weight:500; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); margin-bottom:0.35rem; }
.contact-detail-text p  { font-family:'Jost',sans-serif; font-size:0.95rem; font-weight:300; color:rgba(255,255,255,0.75); line-height:1.65; }
.contact-detail-text a  { color:rgba(255,255,255,0.75); text-decoration:none; transition:color 0.3s; }
.contact-detail-text a:hover { color:var(--gold); }

/* === COUNTER === */
.counter-section { background:var(--gold); padding:4rem 6rem; }
.counter-inner { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; text-align:center; }
.counter-item { position:relative; }
.counter-item + .counter-item::before { content:''; position:absolute; left:0; top:20%; height:60%; width:1px; background:rgba(27,42,94,0.2); }
.counter-num   { font-family:'Masonry',serif; font-size:3rem; font-weight:400; color:var(--navy-dark); line-height:1; display:block; }
.counter-label { font-family:'Raleway',sans-serif; font-size:0.6rem; font-weight:500; letter-spacing:0.3em; text-transform:uppercase; color:rgba(27,42,94,0.65); margin-top:0.5rem; display:block; }

/* === FOOTER === */
footer { background:#080f1e; padding:3rem 6rem; border-top:1px solid rgba(201,168,76,0.12); }
.footer-inner { max-width:1400px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; }
.footer-logo-wrap { display:flex; flex-direction:column; }
.footer-tvh  { font-family:'Raleway',sans-serif; font-size:0.58rem; font-weight:600; letter-spacing:0.65em; color:var(--gold); }
.footer-name { font-family:'Masonry',serif; font-size:1.3rem; font-weight:400; letter-spacing:0.22em; color:var(--white); }
.footer-name span { color:var(--gold); }
.footer-tagline-txt { font-family:'Raleway',sans-serif; font-size:0.48rem; font-weight:300; letter-spacing:0.35em; color:rgba(255,255,255,0.3); text-transform:uppercase; margin-top:0.1rem; }
.footer-copyright { font-family:'Jost',sans-serif; font-size:0.75rem; font-weight:300; letter-spacing:0.06em; color:rgba(255,255,255,0.3); text-align:center; }
.footer-tag { font-family:'Raleway',sans-serif; font-size:0.65rem; font-weight:400; letter-spacing:0.2em; color:rgba(255,255,255,0.3); }
.footer-tag span { color:var(--gold); }

/* === FORM SUCCESS === */
.form-success { display:none; text-align:center; padding:3rem; color:var(--gold); }
.form-success.show { display:block; }
.form-success h3 { font-family:'Masonry',serif; font-size:2rem; margin-bottom:1rem; }
.form-success p  { font-family:'Jost',sans-serif; color:rgba(255,255,255,0.55); font-size:0.9rem; font-weight:300; }

/* === SECTION NUMBER DECO === */
.section-number { font-family:'Masonry',serif; font-size:6rem; font-weight:300; color:rgba(201,168,76,0.05); position:absolute; right:5rem; top:3rem; line-height:1; pointer-events:none; user-select:none; }

/* === RESPONSIVE === */
@media (max-width: 1100px) {
  header, header.scrolled { padding: 1.5rem 3rem; }
  .hero-content { padding: 0 3rem; }
  .hero-stats { right: 3rem; }
  .about { padding: 6rem 3rem; gap: 4rem; }
  .villas-section,.features-section,.floorplan-section,.specs-section,.location-section,.contact-section { padding: 6rem 3rem; }
  .counter-section { padding: 4rem 3rem; }
  footer { padding: 3rem; }
  .villas-grid { grid-template-columns: repeat(2,1fr); }
  .features-grid { grid-template-columns: repeat(2,1fr); }
  .specs-inner { grid-template-columns: 1fr; gap: 3rem; }
  .specs-header { position: static; }
}
@media (max-width: 768px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .hero-content { padding: 0 1.5rem; }
  .hero-stats { display: none; }
  .about { grid-template-columns: 1fr; gap: 3rem; padding: 5rem 1.5rem; }
  .about-visual { height: 380px; }
  .about-img-main { width: 85%; height: 380px; }
  .about-img-accent { display: none; }
  .about-badge { right: 0; }
  .villas-section,.features-section,.floorplan-section,.specs-section,.location-section,.contact-section { padding: 5rem 1.5rem; }
  .villas-header { flex-direction: column; gap: 1.5rem; align-items: flex-start; }
  .villas-grid { grid-template-columns: 1fr; }
  .features-grid { grid-template-columns: 1fr; }
  .floorplan-pane.active { grid-template-columns: 1fr; }
  .specs-grid { grid-template-columns: 1fr; }
  .location-inner { grid-template-columns: 1fr; }
  .contact-inner { grid-template-columns: 1fr; gap: 3rem; }
  .contact-form-grid { grid-template-columns: 1fr; }
  .counter-section { padding: 3rem 1.5rem; }
  .counter-inner { grid-template-columns: repeat(2,1fr); }
  footer { padding: 2rem 1.5rem; }
  .footer-inner { flex-direction: column; gap: 1.2rem; text-align: center; }
  header.scrolled { padding: 1rem 1.5rem; }
  header { padding: 1.5rem; }
}

/* === ABOUT SECTION === */
.about-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 5rem;
  background: var(--cream);
  padding: 6rem;
  max-width: 1400px;
  margin: 0 auto;
  align-items: start;
}
.about-left {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.about-heading {
  font-family: 'Masonry', serif;
  font-size: clamp(1.8rem, 2.8vw, 2.8rem);
  font-weight: 400;
  line-height: 1.2;
  color: var(--navy);
}
.about-heading em { font-style: italic; color: var(--gold); font-weight: 300; }
.about-divider { width: 50px; height: 2px; background: var(--gold); }
.about-stats-row {
  display: flex;
  padding: 1.2rem 0;
  border-top: 1px solid rgba(27,42,94,0.1);
  border-bottom: 1px solid rgba(27,42,94,0.1);
}
.about-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}
.about-stat + .about-stat::before {
  content: '';
  position: absolute;
  left: 0; top: 10%; height: 80%;
  width: 1px;
  background: rgba(27,42,94,0.15);
}
.about-stat-num {
  font-family: 'Masonry', serif;
  font-size: 2rem; font-weight: 500;
  color: var(--navy); line-height: 1; display: block;
}
.about-stat-label {
  font-family: 'Raleway', sans-serif;
  font-size: 0.58rem; font-weight: 500;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-light); display: block;
  margin-top: 0.3rem; text-align: center;
}
.about-img-wrap { position: relative; padding-bottom: 80px; }
.about-main-img {
  width: 100%; height: 340px; border-radius: 16px;
  background-image: url('https://images.unsplash.com/photo-1600566753086-00f18fb6b3ea?w=900&q=80');
  background-size: cover; background-position: center;
  box-shadow: 0 20px 60px rgba(27,42,94,0.15);
}
.about-thumbs {
  position: absolute; bottom: 0;
  left: 30px; right: 30px;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 10px; z-index: 2;
}
.about-thumb {
  height: 110px; border-radius: 12px;
  background-size: cover; background-position: center;
  border: 3px solid var(--white);
  box-shadow: 0 8px 24px rgba(27,42,94,0.18);
}
.about-thumb-1 { background-image: url('https://images.unsplash.com/photo-1613977257592-4871e5fcd7c4?w=400&q=80'); }
.about-thumb-2 { background-image: url('https://images.unsplash.com/photo-1576013551627-0cc20b96c2a7?w=400&q=80'); }
.about-thumb-3 { background-image: url('https://images.unsplash.com/photo-1613977257363-707ba9348227?w=400&q=80'); }
.about-right {
  display: flex;
  flex-direction: column;
  padding-top: 2rem;
}
.about-feat-item {
  display: flex; align-items: flex-start; gap: 1rem;
  padding: 1.4rem 1.6rem;
  background: var(--white); border-radius: 12px;
  border: 1px solid rgba(201,168,76,0.15);
  box-shadow: 0 4px 20px rgba(27,42,94,0.06);
  transition: all 0.3s;
}
.about-feat-item:hover {
  box-shadow: 0 8px 30px rgba(27,42,94,0.12);
  transform: translateX(4px);
  border-color: rgba(201,168,76,0.35);
}
.about-feat-icon {
  font-size: 1.4rem; width: 44px; height: 44px; min-width: 44px;
  border: 1px solid rgba(201,168,76,0.35); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  background: var(--cream); flex-shrink: 0; transition: background 0.3s;
}
.about-feat-item:hover .about-feat-icon { background: var(--gold); border-color: var(--gold); }
.about-feat-title {
  font-family: 'Raleway', sans-serif;
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--navy); margin-bottom: 0.3rem;
}
.about-feat-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.85rem; font-weight: 300;
  color: var(--text-mid); line-height: 1.65;
}
@media (max-width: 900px) {
  .about-wrap { grid-template-columns: 1fr; padding: 4rem 1.5rem; gap: 3rem; }
  .about-right { padding-top: 0; }
}