/* ============================================================
   SAINT TROPEZ Luxe Experience — Main Stylesheet v1
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500;600&display=swap');

:root {
  --midnight: #0a1628;
  --midnight-light: #0f1f3d;
  --midnight-mid: #132040;
  --gold: #c5a44e;
  --gold-light: #d4b86a;
  --gold-pale: #e8d5a3;
  --cream: #faf5eb;
  --cream-dark: #f0e8d0;
  --white: #ffffff;
  --text-dark: #1a1a2e;
  --text-mid: #4a4a6a;
  --text-light: #8a8aaa;
  --border: rgba(197,164,78,0.22);
  --shadow: 0 8px 40px rgba(10,22,40,0.16);
  --shadow-gold: 0 4px 24px rgba(197,164,78,0.2);
  --transition: all 0.35s cubic-bezier(0.25,0.46,0.45,0.94);
  --font-serif: 'Playfair Display','Georgia',serif;
  --font-secondary: 'Cormorant Garamond','Georgia',serif;
  --font-sans: 'Montserrat','Helvetica Neue',sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:var(--font-sans);background:var(--cream);color:var(--text-dark);line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--gold);text-decoration:none;transition:var(--transition);}
a:hover{color:var(--gold-light);}
ul,ol{list-style:none;}

h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:500;line-height:1.2;letter-spacing:0.01em;}
h1{font-size:clamp(2rem,4vw,3.5rem);}
h2{font-size:clamp(1.6rem,3vw,2.6rem);}
h3{font-size:clamp(1.2rem,2.2vw,1.8rem);}
h4{font-size:1.25rem;}
p{font-size:0.95rem;line-height:1.8;color:var(--text-mid);}
.lead{font-family:var(--font-secondary);font-size:1.2rem;font-weight:300;line-height:1.75;letter-spacing:0.01em;}

.container{width:100%;max-width:1280px;margin:0 auto;padding:0 40px;}
.container-narrow{width:100%;max-width:860px;margin:0 auto;padding:0 40px;}
.section-pad{padding:100px 0;}
.section-pad-sm{padding:64px 0;}
.text-center{text-align:center;}
.text-gold{color:var(--gold);}
.bg-midnight{background-color:var(--midnight);}
.bg-cream{background-color:var(--cream);}

.label{font-family:var(--font-sans);font-size:0.7rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:14px;}
.divider-gold{width:56px;height:1px;background:var(--gold);margin:20px auto 32px;opacity:0.7;}
.divider-gold-left{width:56px;height:1px;background:var(--gold);margin:20px 0 32px;opacity:0.7;}

/* --- Buttons --- */
.btn{display:inline-block;font-family:var(--font-sans);font-size:0.72rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;padding:16px 40px;border:1px solid var(--gold);color:var(--gold);background:transparent;cursor:pointer;transition:var(--transition);text-decoration:none;position:relative;overflow:hidden;}
.btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--gold);transition:var(--transition);z-index:0;}
.btn:hover::before{left:0;}
.btn:hover{color:var(--midnight);}
.btn-text{position:relative;z-index:1;}
.btn-solid{background:var(--gold);color:var(--midnight);border-color:var(--gold);}
.btn-solid::before{background:var(--gold-light);}
.btn-solid:hover{color:var(--midnight);}

/* ============================================================
   NAVIGATION
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:var(--transition);}
.site-header.scrolled{background:rgba(10,22,40,0.97);backdrop-filter:blur(12px);box-shadow:0 2px 30px rgba(0,0,0,0.4);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:22px 40px;max-width:1440px;margin:0 auto;}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
.nav-logo img{height:44px;width:auto;}
.nav-logo-text{font-family:var(--font-serif);font-size:0.85rem;font-weight:400;letter-spacing:0.12em;color:var(--cream);text-transform:uppercase;line-height:1.35;}
.nav-logo-text span{display:block;font-size:0.58rem;letter-spacing:0.3em;color:var(--gold);font-family:var(--font-sans);font-weight:600;}
.nav-menu{display:flex;align-items:center;gap:36px;}
.nav-menu a{font-family:var(--font-sans);font-size:0.7rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:rgba(250,245,235,0.85);text-decoration:none;transition:var(--transition);position:relative;padding-bottom:4px;}
.nav-menu a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold);transition:width 0.3s ease;}
.nav-menu a:hover,.nav-menu a.active{color:var(--gold);}
.nav-menu a:hover::after,.nav-menu a.active::after{width:100%;}
.nav-cta{font-size:0.65rem !important;padding:11px 28px !important;border:1px solid rgba(197,164,78,0.6) !important;color:var(--gold) !important;letter-spacing:0.2em !important;background:transparent;}
.nav-cta:hover{background:var(--gold) !important;color:var(--midnight) !important;border-color:var(--gold) !important;}
.nav-cta::after{display:none !important;}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none;}
.nav-toggle span{display:block;width:26px;height:1.5px;background:var(--cream);transition:var(--transition);}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:998;}
.nav-overlay.open{display:block;}

/* ============================================================
   SPLIT HERO
   ============================================================ */
.hero.hero-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;}
.hero-text-half{display:flex;flex-direction:column;justify-content:center;padding:60px;background:#0a1628;color:#fff;}
.hero-video-half{position:relative;overflow:hidden;background:#0a1628;}
.hero-split-video{width:100%;height:100%;object-fit:cover;opacity:0.8;}
.hero-video-half::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,22,40,0.35) 0%,transparent 70%);pointer-events:none;}

.hero-eyebrow{font-family:var(--font-sans);font-size:0.68rem;font-weight:600;letter-spacing:0.35em;text-transform:uppercase;color:var(--gold);margin-bottom:28px;display:flex;align-items:center;gap:14px;}
.hero-eyebrow::before{content:'';display:block;width:32px;height:1px;background:var(--gold);opacity:0.7;}
.hero-text-half h1{font-size:clamp(2.2rem,3.5vw,3.8rem);font-weight:400;line-height:1.15;color:var(--cream);margin-bottom:28px;letter-spacing:-0.01em;}
.hero-text-half h1 em{font-style:italic;color:var(--gold);}
.hero-text-half .hero-lead{font-family:var(--font-secondary);font-size:1.15rem;font-weight:300;line-height:1.75;color:rgba(250,245,235,0.75);margin-bottom:44px;max-width:440px;}
.hero-stats{display:flex;gap:40px;margin-top:52px;padding-top:40px;border-top:1px solid rgba(197,164,78,0.2);}
.hero-stat{display:flex;flex-direction:column;}
.hero-stat-number{font-family:var(--font-serif);font-size:2rem;font-weight:400;color:var(--gold);line-height:1;}
.hero-stat-label{font-family:var(--font-sans);font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(250,245,235,0.5);margin-top:6px;}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero{background:var(--midnight);padding:160px 0 80px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--midnight) 55%,var(--midnight-light) 100%);}
.page-hero-content{position:relative;z-index:1;text-align:center;color:var(--cream);}
.page-hero-content h1{color:var(--cream);margin-bottom:20px;}
.page-hero-content .lead{color:rgba(250,245,235,0.7);max-width:640px;margin:0 auto;}

/* ============================================================
   SECTIONS
   ============================================================ */
.section-header{text-align:center;margin-bottom:64px;}
.section-header h2{color:var(--midnight);}
.section-header.light h2{color:var(--cream);}
.section-intro{background:var(--midnight);color:var(--cream);}
.section-intro h2{color:var(--cream);margin-bottom:24px;}

.two-col-text{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.two-col-text img{width:100%;height:520px;object-fit:cover;}

/* --- Services Grid --- */
.services-section{background:var(--cream);}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);}
.service-card{background:var(--white);padding:52px 44px;transition:var(--transition);position:relative;overflow:hidden;}
.service-card::before{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:var(--gold);transition:width 0.4s ease;}
.service-card:hover::before{width:100%;}
.service-card:hover{background:var(--cream);}
.service-icon{font-size:2rem;margin-bottom:24px;color:var(--gold);}
.service-card h3{font-size:1.25rem;color:var(--midnight);margin-bottom:14px;}
.service-card p{font-size:0.88rem;line-height:1.75;}
.service-card .service-link{display:inline-block;margin-top:24px;font-size:0.68rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid transparent;padding-bottom:2px;}
.service-card .service-link:hover{border-color:var(--gold);}

/* --- Properties Grid --- */
.properties-section{background:var(--midnight);}
.properties-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:56px;}
.property-card{background:var(--midnight-light);overflow:hidden;transition:var(--transition);border:1px solid rgba(197,164,78,0.1);}
.property-card:hover{border-color:rgba(197,164,78,0.4);transform:translateY(-4px);box-shadow:var(--shadow-gold);}
.property-card-img{height:260px;overflow:hidden;position:relative;}
.property-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;}
.property-card:hover .property-card-img img{transform:scale(1.06);}
.property-badge{position:absolute;top:20px;left:20px;background:var(--gold);color:var(--midnight);font-size:0.6rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;padding:6px 14px;}
.property-card-body{padding:28px 32px 36px;}
.property-location{font-size:0.67rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:10px;}
.property-card-body h3{font-size:1.2rem;color:var(--cream);margin-bottom:12px;line-height:1.3;}
.property-card-body p{font-size:0.84rem;color:rgba(250,245,235,0.55);margin-bottom:20px;}
.property-meta{display:flex;gap:20px;padding-top:20px;border-top:1px solid rgba(197,164,78,0.15);}
.property-meta-item{display:flex;flex-direction:column;gap:2px;}
.property-meta-item span:first-child{font-size:0.64rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(250,245,235,0.35);}
.property-meta-item span:last-child{font-size:0.85rem;font-weight:500;color:var(--cream);}

/* --- Banner / Parallax --- */
.banner-section{background-image:url('/images/vue-sainttropez.jpg');background-size:cover;background-position:center;background-attachment:fixed;position:relative;padding:120px 0;text-align:center;}
.banner-section::before{content:'';position:absolute;inset:0;background:rgba(10,22,40,0.72);}
.banner-content{position:relative;z-index:1;color:var(--cream);max-width:720px;margin:0 auto;}
.banner-content h2{color:var(--cream);margin-bottom:20px;font-size:clamp(1.8rem,3vw,3rem);}
.banner-content p{font-family:var(--font-secondary);font-size:1.15rem;color:rgba(250,245,235,0.75);margin-bottom:40px;}

/* --- CTA Two Col --- */
.cta-two-col{display:grid;grid-template-columns:1fr 1fr;min-height:520px;}
.cta-two-col-image{overflow:hidden;}
.cta-two-col-image img{width:100%;height:100%;object-fit:cover;}
.cta-two-col-body{background:var(--midnight);display:flex;flex-direction:column;justify-content:center;padding:80px;color:var(--cream);}
.cta-two-col-body h2{color:var(--cream);margin-bottom:20px;}
.cta-two-col-body p{color:rgba(250,245,235,0.7);font-family:var(--font-secondary);font-size:1.05rem;margin-bottom:36px;line-height:1.8;}

/* --- Testimonials --- */
.testimonials-section{background:var(--cream-dark);}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.testimonial-card{background:var(--white);padding:44px 40px;position:relative;border-bottom:3px solid transparent;transition:var(--transition);}
.testimonial-card:hover{border-bottom-color:var(--gold);}
.testimonial-quote{font-family:var(--font-serif);font-size:3rem;color:var(--gold);line-height:0.5;margin-bottom:28px;opacity:0.5;}
.testimonial-card p{font-family:var(--font-secondary);font-size:1rem;font-style:italic;line-height:1.8;color:var(--text-mid);margin-bottom:28px;}
.testimonial-author strong{font-family:var(--font-sans);font-size:0.78rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--midnight);display:block;margin-bottom:3px;}
.testimonial-author span{font-size:0.75rem;color:var(--text-light);letter-spacing:0.08em;}

/* --- Blog / Insights cards --- */
.blog-section{background:var(--white);}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.blog-card{background:var(--white);border:1px solid rgba(197,164,78,0.12);overflow:hidden;transition:var(--transition);}
.blog-card:hover{border-color:rgba(197,164,78,0.4);box-shadow:var(--shadow);transform:translateY(-4px);}
.blog-card-img{height:220px;overflow:hidden;}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;}
.blog-card:hover .blog-card-img img{transform:scale(1.05);}
.blog-card-body{padding:28px 30px 36px;}
.blog-category{font-size:0.62rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.blog-card-body h3{font-size:1.1rem;color:var(--midnight);margin-bottom:12px;line-height:1.35;}
.blog-card-body p{font-size:0.84rem;line-height:1.75;margin-bottom:20px;}
.blog-meta{font-size:0.72rem;color:var(--text-light);letter-spacing:0.08em;margin-bottom:16px;}
.blog-read-more{font-size:0.67rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid transparent;padding-bottom:2px;}
.blog-read-more:hover{border-color:var(--gold);}

/* --- Article Layout --- */
.article-hero-img{height:520px;width:100%;object-fit:cover;display:block;}
.article-header{background:var(--midnight);padding:64px 0 48px;text-align:center;}
.article-header h1{color:var(--cream);font-size:clamp(1.8rem,3vw,3rem);max-width:800px;margin:0 auto 20px;line-height:1.25;}
.article-meta{font-size:0.75rem;color:rgba(250,245,235,0.5);letter-spacing:0.12em;}
.article-body{background:var(--white);padding:80px 0 100px;}
.article-content{max-width:780px;margin:0 auto;padding:0 40px;}
.article-content p{font-size:1rem;line-height:1.9;color:var(--text-mid);margin-bottom:28px;}
.article-content h2{font-size:1.75rem;color:var(--midnight);margin:52px 0 20px;}
.article-content h3{font-size:1.3rem;color:var(--midnight);margin:36px 0 16px;}
.article-content ul{margin:20px 0 28px 24px;list-style:disc;}
.article-content ol{margin:20px 0 28px 24px;list-style:decimal;}
.article-content li{font-size:0.96rem;line-height:1.8;color:var(--text-mid);margin-bottom:8px;}
.article-content strong{font-weight:600;color:var(--text-dark);}
.article-content a{color:var(--gold);border-bottom:1px solid rgba(197,164,78,0.4);padding-bottom:1px;}
.article-content a:hover{border-color:var(--gold);}
.article-content blockquote{border-left:3px solid var(--gold);padding:20px 32px;margin:36px 0;background:var(--cream);font-family:var(--font-secondary);font-size:1.15rem;font-style:italic;color:var(--text-dark);}
.article-mid-img{width:100%;height:420px;object-fit:cover;margin:52px 0;display:block;}
.breadcrumb{background:var(--midnight-light);padding:16px 40px;font-size:0.72rem;color:rgba(250,245,235,0.45);letter-spacing:0.08em;}
.breadcrumb a{color:rgba(197,164,78,0.8);}
.breadcrumb a:hover{color:var(--gold);}
.breadcrumb span{margin:0 8px;opacity:0.35;}

/* --- Insights page grid --- */
.insights-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;padding:80px 0 100px;}

/* --- Contact --- */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start;}
.contact-info h2{color:var(--midnight);margin-bottom:20px;}
.contact-info .lead{margin-bottom:40px;}
.contact-detail{display:flex;flex-direction:column;gap:20px;}
.contact-detail-item{display:flex;gap:18px;align-items:flex-start;}
.contact-detail-icon{width:40px;height:40px;min-width:40px;background:var(--midnight);display:flex;align-items:center;justify-content:center;margin-top:2px;}
.contact-detail-icon svg{width:18px;height:18px;stroke:var(--gold);fill:none;}
.contact-detail-text strong{display:block;font-family:var(--font-sans);font-size:0.68rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--midnight);margin-bottom:4px;}
.contact-detail-text span{font-size:0.9rem;color:var(--text-mid);}
.contact-form{background:var(--midnight);padding:56px 52px;}
.contact-form h3{font-size:1.5rem;color:var(--cream);margin-bottom:36px;font-family:var(--font-serif);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.form-group{margin-bottom:24px;}
.form-group label{display:block;font-size:0.66rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.form-group input,.form-group select,.form-group textarea{width:100%;background:rgba(250,245,235,0.06);border:1px solid rgba(197,164,78,0.2);color:var(--cream);font-family:var(--font-sans);font-size:0.88rem;padding:14px 18px;outline:none;transition:var(--transition);-webkit-appearance:none;appearance:none;}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(250,245,235,0.3);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:rgba(197,164,78,0.6);background:rgba(250,245,235,0.1);}
.form-group select option{background:var(--midnight);color:var(--cream);}
.form-group textarea{min-height:140px;resize:vertical;}

/* --- Sitemap --- */
.sitemap-section{background:var(--cream);padding:80px 0 100px;}
.sitemap-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;margin-top:52px;}
.sitemap-col h3{font-size:0.72rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border);}
.sitemap-col ul{display:flex;flex-direction:column;gap:10px;}
.sitemap-col ul li a{font-size:0.88rem;color:var(--text-mid);transition:var(--transition);}
.sitemap-col ul li a:hover{color:var(--gold);padding-left:6px;}

/* --- 404 --- */
.error-section{min-height:100vh;background:var(--midnight);display:flex;align-items:center;justify-content:center;text-align:center;padding:40px;}
.error-content{color:var(--cream);}
.error-number{font-family:var(--font-serif);font-size:clamp(6rem,15vw,12rem);font-weight:400;color:transparent;-webkit-text-stroke:1px rgba(197,164,78,0.4);line-height:1;margin-bottom:20px;}
.error-content h1{font-size:1.8rem;color:var(--cream);margin-bottom:16px;}
.error-content p{color:rgba(250,245,235,0.6);font-family:var(--font-secondary);font-size:1.1rem;max-width:480px;margin:0 auto 40px;}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--midnight);color:var(--cream);padding:80px 0 0;border-top:1px solid rgba(197,164,78,0.15);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:64px;padding-bottom:64px;}
.footer-brand img{height:40px;width:auto;margin-bottom:20px;}
.footer-brand p{font-size:0.84rem;line-height:1.8;color:rgba(250,245,235,0.5);max-width:300px;margin-bottom:28px;}
.footer-socials{display:flex;gap:14px;}
.footer-social-link{width:36px;height:36px;border:1px solid rgba(197,164,78,0.25);display:flex;align-items:center;justify-content:center;color:rgba(250,245,235,0.5);font-size:0.75rem;transition:var(--transition);text-decoration:none;}
.footer-social-link:hover{border-color:var(--gold);color:var(--gold);}
.footer-col h4{font-size:0.68rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;}
.footer-col ul{display:flex;flex-direction:column;gap:11px;}
.footer-col ul li a{font-size:0.84rem;color:rgba(250,245,235,0.5);transition:var(--transition);}
.footer-col ul li a:hover{color:var(--gold);}
.footer-bottom{border-top:1px solid rgba(197,164,78,0.1);padding:28px 0;display:flex;align-items:center;justify-content:space-between;}
.footer-bottom p,.footer-bottom a{font-size:0.75rem;color:rgba(250,245,235,0.3);letter-spacing:0.06em;}
.footer-bottom a:hover{color:var(--gold);}
.footer-legal-links{display:flex;gap:28px;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:48px;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:900px){
  .two-col-text{grid-template-columns:1fr;gap:40px;}
  .two-col-text img{height:360px;}
  .cta-two-col{grid-template-columns:1fr;}
  .cta-two-col-image{height:320px;}
  .cta-two-col-body{padding:56px 40px;}
  .contact-grid{grid-template-columns:1fr;gap:48px;}
  .sitemap-grid{grid-template-columns:repeat(2,1fr);}
  .testimonials-grid{grid-template-columns:repeat(2,1fr);}
  .blog-grid{grid-template-columns:repeat(2,1fr);}
  .insights-page-grid{grid-template-columns:repeat(2,1fr);}
  .properties-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  .container{padding:0 24px;}
  .container-narrow{padding:0 24px;}
  .section-pad{padding:72px 0;}
  .hero.hero-split{grid-template-columns:1fr;}
  .hero-video-half{height:300px;}
  .hero-text-half{padding:80px 32px 52px;order:-1;}
  .hero-stats{gap:28px;flex-wrap:wrap;}
  .nav-inner{padding:18px 24px;}
  .nav-menu{position:fixed;top:0;right:-100%;width:80vw;max-width:360px;height:100vh;background:var(--midnight);flex-direction:column;align-items:flex-start;padding:100px 40px 40px;gap:28px;transition:right 0.4s cubic-bezier(0.25,0.46,0.45,0.94);box-shadow:-10px 0 40px rgba(0,0,0,0.4);z-index:999;}
  .nav-menu.open{right:0;}
  .nav-menu a{font-size:0.85rem;color:var(--cream);}
  .nav-toggle{display:flex;}
  .services-grid{grid-template-columns:1fr;}
  .properties-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .contact-form{padding:40px 28px;}
  .footer-grid{grid-template-columns:1fr;gap:40px;}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center;}
  .testimonials-grid{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .insights-page-grid{grid-template-columns:1fr;}
  .sitemap-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .article-content{padding:0 24px;}
  .breadcrumb{padding:16px 24px;}
}
@media(max-width:480px){
  .sitemap-grid{grid-template-columns:1fr;}
  .banner-section{background-attachment:scroll;}
}

/* --- Fade-up animation --- */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease;}
.fade-up.visible{opacity:1;transform:none;}
