/*
Theme Name: Smart Estate Theme
Theme URI: https://www.smartestateio.com/theme
Author: Smart Estate Technology
Author URI: https://www.smartestateio.com
Description: Premium luxury real estate theme with Smart Estate MLS IDX integration. Designed for Nigerian luxury realtors with B&W monochrome design system, Playfair Display + DM Sans typography, and seamless IDX shortcode support.
Version: 1.0.4
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: smart-estate
Tags: real-estate, luxury, idx, mls, nigeria, one-column, custom-logo, custom-menu, featured-images, theme-options
*/

/* ══════════════════════════════════════════════════════════════════════
   Smart Estate WP Theme 1.0
   Compiled Stylesheet
   ══════════════════════════════════════════════════════════════════════ */

/* ── RESET ─────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'DM Sans',system-ui,sans-serif;color:#1A1A1A;background:#FFFFFF;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}

/* ── DESIGN TOKENS ─────────────────────────────────────────────────── */
:root{
  --burgundy:#1A1A1A;
  --burgundy-deep:#0D0D0D;
  --burgundy-light:#333333;
  --burgundy-tint:rgba(26,26,26,0.05);
  --cream:#FFFFFF;
  --cream-warm:#F7F7F7;
  --cream-deep:#EDEDED;
  --cream-card:#FCFCFC;
  --gold:#999999;
  --gold-light:#B0B0B0;
  --gold-deep:#777777;
  --ink:#0D0D0D;
  --body:#333333;
  --muted:#666666;
  --xmuted:#999999;
  --border:#E0E0E0;
  --shadow:0 4px 24px rgba(0,0,0,0.06);
  --shadow-lg:0 12px 48px rgba(0,0,0,0.10);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --max-w:1280px;
  --px:80px;
}
@media(max-width:1024px){:root{--px:40px}}
@media(max-width:640px){:root{--px:20px}}

/* ── UTILITIES ─────────────────────────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding-left:var(--px);padding-right:var(--px)}
.serif{font-family:var(--serif)}
.gold-line{width:48px;height:2px;background:var(--gold);display:block}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold-deep)}
.section-pad{padding:80px 0}
@media(max-width:768px){.section-pad{padding:56px 0}}

/* ── GLOBAL TRANSITIONS ────────────────────────────────────────────── */
a,button,img,.listing-card,.pillar,.community-card-bg,.testimonial,.market-card,.process-num,.team-card{transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}

/* ── BUTTONS ───────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;letter-spacing:0.04em;padding:15px 36px;border-radius:8px;transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}
.btn-primary{background:var(--burgundy);color:#fff}
.btn-primary:hover{background:var(--burgundy-deep);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.15)}
.btn-outline{border:1.5px solid var(--burgundy);color:var(--burgundy)}
.btn-outline:hover{background:var(--burgundy);color:#fff;transform:translateY(-2px)}
.btn-gold{background:var(--burgundy);color:#fff}
.btn-gold:hover{background:var(--burgundy-deep);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.15)}
.btn-white{background:#fff;color:var(--burgundy);border:1.5px solid var(--border);border-radius:8px}
.btn-white:hover{border-color:var(--burgundy);transform:translateY(-2px)}

/* ── NAV ───────────────────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(255,255,255,0.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:background 0.3s}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:var(--max-w);margin:0 auto;padding:0 var(--px)}
.nav-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
body.admin-bar .nav{top:32px}
.nav-logo-icon{width:40px;height:40px;background:var(--burgundy);border-radius:10px;display:flex;align-items:center;justify-content:center}
.nav-logo-icon svg{width:22px;height:22px}
.nav-brand{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--ink);letter-spacing:-0.2px}
.nav-brand em{color:var(--gold);font-style:normal}
.nav-links{display:flex;align-items:center;gap:20px}
.nav-links li{list-style:none;padding:0;margin:0;display:flex;align-items:center}
.nav-links a{font-size:13px;font-weight:500;color:var(--body);transition:color 0.15s}
.nav-links a:hover,.nav-links a.active,.nav-links .current-menu-item>a{color:var(--burgundy);font-weight:600}
.nav-ctas{display:flex;align-items:center;gap:12px}
.nav-cta-phone{font-size:12px;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:6px}
.nav-cta-phone svg{width:14px;height:14px;stroke:var(--gold)}
.mobile-toggle{display:none;padding:8px;color:var(--ink)}
@media(max-width:1024px){
  .nav-links,.nav-ctas .btn{display:none}
  .mobile-toggle{display:block}
  .nav-cta-phone{display:none}
}
.mobile-menu{position:fixed;top:72px;left:0;right:0;bottom:0;background:var(--cream);z-index:190;padding:24px var(--px);display:none;flex-direction:column;gap:4px;overflow-y:auto}
.mobile-menu.open{display:flex}
.mobile-menu li{list-style:none;padding:0;margin:0}
.mobile-menu a{display:block;padding:14px 16px;font-size:15px;font-weight:500;color:var(--body);border-bottom:1px solid var(--border)}
.mobile-menu .btn{margin-top:16px;text-align:center;justify-content:center}

/* ── PAGE HERO (inner pages) ───────────────────────────────────────── */
.page-hero{position:relative;min-height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-top:72px;background:var(--burgundy-deep)}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.55) 50%,rgba(0,0,0,0.75) 100%)}
.page-hero-content{position:relative;z-index:2;text-align:center;padding:60px var(--px);max-width:700px}
.page-hero .eyebrow{color:var(--gold-light);margin-bottom:16px}
.page-hero h1{font-family:var(--serif);font-size:clamp(32px,5vw,56px);font-weight:400;color:#fff;line-height:1.1;letter-spacing:-0.5px;margin-bottom:16px}
.page-hero p{font-size:16px;color:rgba(255,255,255,0.55);line-height:1.7;max-width:500px;margin:0 auto}
@media(max-width:768px){.page-hero{min-height:320px}.page-hero-content{padding:40px var(--px)}}

/* ── FLOATING SOCIAL SIDEBAR ──────────────────────────────────────── */
.social-float{position:fixed;left:20px;top:50%;transform:translateY(-50%);z-index:150;display:flex;flex-direction:column;gap:6px}
.social-float a{width:42px;height:42px;background:rgba(255,255,255,0.95);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--body);transition:all 0.3s ease;box-shadow:0 2px 8px rgba(0,0,0,0.06)}
.social-float a:hover{background:var(--burgundy);color:#fff;border-color:var(--burgundy);transform:scale(1.1)}
.social-float a svg{width:18px;height:18px}
@media(max-width:1024px){.social-float{display:none}}

/* ── LISTING CARDS ─────────────────────────────────────────────────── */
.listings{background:var(--cream)}
.listings-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:16px}
.listings-header-left h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:500;color:var(--ink);margin-top:12px;letter-spacing:-0.3px}
.listings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.listing-card{background:var(--cream-card);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}
.listing-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,0.10)}
.listing-card-img{position:relative;height:220px;overflow:hidden;background:var(--cream-deep)}
.listing-card-img img{width:100%;height:100%;object-fit:cover}
.listing-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--cream-deep)}
.listing-card-badge{position:absolute;top:12px;left:12px;font-size:9px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:5px 12px;background:var(--burgundy);color:#fff;border-radius:4px}
.listing-card-price-tag{position:absolute;bottom:12px;right:12px;font-family:var(--serif);font-size:18px;font-weight:700;color:#fff;background:rgba(0,0,0,0.75);backdrop-filter:blur(4px);padding:6px 14px;border-radius:6px}
.listing-card-body{padding:20px}
.listing-card-title{font-family:var(--serif);font-size:16px;font-weight:600;color:var(--ink);margin-bottom:4px;line-height:1.3}
.listing-card-address{font-size:12px;color:var(--muted);margin-bottom:14px}
.listing-card-stats{display:flex;gap:16px;padding-top:14px;border-top:1px solid var(--border)}
.listing-card-stat{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--body);font-weight:500}
.listing-card-stat svg{width:14px;height:14px;stroke:var(--gold)}
@media(max-width:1024px){.listings-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.listings-grid{grid-template-columns:1fr}}
.section-view-all{text-align:center;margin-top:40px}

/* ── COMMUNITY CARDS ───────────────────────────────────────────────── */
.community-card{position:relative;height:320px;overflow:hidden;cursor:pointer;border-radius:14px;border:none;box-shadow:0 2px 12px rgba(0,0,0,0.06)}
.community-card-bg{position:absolute;inset:0;transition:transform 0.5s ease}
.community-card-bg img{width:100%;height:100%;object-fit:cover}
.community-card:hover .community-card-bg{transform:scale(1.05)}
.community-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.2) 60%,transparent 100%);z-index:1}
.community-card-content{position:absolute;bottom:0;left:0;right:0;padding:28px;z-index:2}
.community-card h3{font-family:var(--serif);font-size:22px;font-weight:700;color:#fff;margin-bottom:4px}
.community-card span{font-size:12px;color:rgba(255,255,255,0.5);font-weight:500}
.community-card .community-cta{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);margin-top:12px;display:inline-flex;align-items:center;gap:6px;opacity:0;transform:translateY(8px);transition:all 0.3s}
.community-card:hover .community-cta{opacity:1;transform:translateY(0)}

/* ── TESTIMONIALS ──────────────────────────────────────────────────── */
.testimonial{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);border-radius:16px;padding:40px 32px;transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}
.testimonial:hover{background:rgba(255,255,255,0.07);transform:translateY(-4px)}
.testimonial-stars{color:var(--gold);font-size:14px;letter-spacing:2px;margin-bottom:16px}
.testimonial p{font-size:14px;color:rgba(255,255,255,0.65);line-height:1.7;font-style:italic;margin-bottom:20px}
.testimonial-author{font-size:13px;font-weight:600;color:#fff}
.testimonial-role{font-size:11px;color:rgba(255,255,255,0.35);margin-top:2px}

/* ── CONTACT FORM ──────────────────────────────────────────────────── */
.contact-form{background:var(--cream-card);border:1px solid var(--border);border-radius:16px;padding:40px;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.contact-form h3{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--ink);margin-bottom:20px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--muted);letter-spacing:0.04em;text-transform:uppercase;margin-bottom:6px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:13px 16px;border:1px solid var(--border);border-radius:8px;background:#fff;font-family:var(--sans);font-size:14px;color:var(--ink);transition:all 0.25s ease;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--burgundy);box-shadow:0 0 0 3px rgba(26,26,26,0.06)}
.form-group textarea{height:100px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:768px){.form-row{grid-template-columns:1fr}}

/* ── FOOTER ────────────────────────────────────────────────────────── */
.footer{background:var(--burgundy-deep);color:#fff;padding:64px 0 0}
.footer-top{display:grid;grid-template-columns:300px 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.08)}
.footer-brand{font-family:var(--serif);font-size:18px;font-weight:700;margin-bottom:16px}
.footer-brand em{color:var(--gold);font-style:normal}
.footer-desc{font-size:13px;color:rgba(255,255,255,0.35);line-height:1.65;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:36px;height:36px;background:rgba(255,255,255,0.06);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all 0.25s ease;font-size:13px;color:rgba(255,255,255,0.5)}
.footer-social a:hover{background:rgba(255,255,255,0.12)}
.footer h5{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,0.5);margin-bottom:20px}
.footer ul{display:flex;flex-direction:column;gap:10px}
.footer ul a{font-size:13px;color:rgba(255,255,255,0.4);transition:color 0.15s}
.footer ul a:hover{color:var(--gold)}
.footer-bottom{padding:24px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:11px;color:rgba(255,255,255,0.2)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:11px;color:rgba(255,255,255,0.25);transition:color 0.15s}
.footer-legal a:hover{color:rgba(255,255,255,0.5)}
.powered-by{display:flex;align-items:center;gap:8px;font-size:11px;color:rgba(255,255,255,0.2)}
@media(max-width:1024px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:640px){.footer-top{grid-template-columns:1fr;gap:24px}}

/* ── SCROLL ANIMATIONS ─────────────────────────────────────────────── */
/* Content is visible by default; JS adds .will-reveal to enable the animation */
.reveal{transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.will-reveal{opacity:0;transform:translateY(24px)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── PRICE FILTER PILLS ────────────────────────────────────────────── */
.price-pills{display:flex;gap:10px;flex-wrap:wrap;margin-top:32px}
.price-pill{font-size:12px;font-weight:600;padding:10px 22px;border:1.5px solid var(--border);border-radius:100px;color:var(--body);transition:all 0.25s ease;cursor:pointer}
.price-pill:hover,.price-pill.active{border-color:var(--burgundy);color:#fff;background:var(--burgundy)}

/* ── TEAM CARDS ────────────────────────────────────────────────────── */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.team-card{text-align:center;cursor:pointer}
.team-card-img{width:100%;aspect-ratio:3/4;overflow:hidden;border-radius:16px;margin-bottom:16px;position:relative}
.team-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94)}
.team-card:hover .team-card-img img{transform:scale(1.05)}
.team-card h3{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:2px}
.team-card span{font-size:12px;color:var(--muted);font-weight:500}
@media(max-width:1024px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.team-grid{grid-template-columns:1fr;max-width:300px;margin:0 auto}}

/* ── ABOUT PAGE ────────────────────────────────────────────────────── */
.founder{background:var(--cream)}
.founder-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.founder-img{border-radius:16px;overflow:hidden;aspect-ratio:3/4}
.founder-img img{width:100%;height:100%;object-fit:cover}
.founder-text .eyebrow{margin-bottom:16px}
.founder-text h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,42px);font-weight:500;color:var(--ink);line-height:1.15;margin-bottom:24px;letter-spacing:-0.3px}
.founder-text p{font-size:15px;color:var(--body);line-height:1.8;margin-bottom:16px}
.founder-text blockquote{font-family:var(--serif);font-size:20px;font-style:italic;color:var(--ink);line-height:1.5;padding-left:24px;border-left:3px solid var(--burgundy);margin:28px 0}
@media(max-width:768px){.founder-inner{grid-template-columns:1fr;gap:40px}}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.value-card{padding:36px 28px;background:var(--cream-card);border:1px solid var(--border);border-radius:16px;text-align:center;transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}
.value-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,0.06)}
.value-card-icon{width:56px;height:56px;background:var(--burgundy-tint);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.value-card-icon svg{width:24px;height:24px;stroke:var(--burgundy)}
.value-card h3{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:10px}
.value-card p{font-size:13px;color:var(--muted);line-height:1.7}
@media(max-width:768px){.values-grid{grid-template-columns:1fr}}

/* ── LISTINGS PAGE — SEARCH BAR (IDX) ──────────────────────────────── */
.search-bar{background:var(--cream-warm);border-bottom:1px solid var(--border);padding:32px 0}
.search-bar-inner{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.search-field{flex:1;min-width:180px}
.search-field label{display:block;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:6px}
.search-field input,.search-field select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background:#fff;font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;transition:border-color 0.2s}
.search-field input:focus,.search-field select:focus{border-color:var(--burgundy)}
.search-bar .btn{height:46px;padding:0 28px}
@media(max-width:768px){.search-field{min-width:100%}}

/* ── IDX SHORTCODE PLACEHOLDER ─────────────────────────────────────── */
.idx-placeholder{border:2px dashed var(--border);border-radius:16px;padding:48px 32px;text-align:center;background:var(--cream-warm)}
.idx-placeholder-label{font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:8px}
.idx-placeholder-code{font-family:'Courier New',monospace;font-size:14px;color:var(--burgundy);background:var(--burgundy-tint);padding:8px 16px;border-radius:6px;display:inline-block;margin-top:8px}
.idx-placeholder p{font-size:13px;color:var(--muted);margin-top:12px;max-width:400px;margin-left:auto;margin-right:auto}

/* ── INSTAGRAM ─────────────────────────────────────────────────────── */
.instagram-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.instagram-item{position:relative;aspect-ratio:1/1;overflow:hidden;border-radius:12px;cursor:pointer}
.instagram-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94)}
.instagram-item:hover img{transform:scale(1.08)}
.instagram-item::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,0);transition:background 0.3s;border-radius:12px}
.instagram-item:hover::after{background:rgba(0,0,0,0.25)}
.instagram-item .ig-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.7);opacity:0;z-index:2;color:#fff;transition:all 0.3s ease}
.instagram-item:hover .ig-icon{opacity:1;transform:translate(-50%,-50%) scale(1)}
@media(max-width:1024px){.instagram-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.instagram-grid{grid-template-columns:repeat(2,1fr)}}

/* ── MARKET ────────────────────────────────────────────────────────── */
.market-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:36px 24px;text-align:center;transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}
.market-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,0.08)}
.market-card-value{font-family:var(--serif);font-size:36px;font-weight:700;color:var(--ink);line-height:1}
.market-card-label{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:0.04em;text-transform:uppercase;margin-top:8px}
.market-card-delta{font-size:11px;font-weight:700;margin-top:8px;display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px}
.market-card-delta.up{color:#1a7a3a;background:rgba(26,122,58,0.08)}
.market-card-delta.down{color:#b91c1c;background:rgba(185,28,28,0.08)}

/* ── DROPDOWN NAV ──────────────────────────────────────────────────── */
.nav-dropdown{position:relative}
.nav-dropdown>a{display:flex;align-items:center;gap:4px}
.nav-dropdown>a::after{content:'';width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;opacity:0.5;transition:transform 0.25s}
.nav-dropdown:hover>a::after{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:100%;left:-16px;min-width:240px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,0.10);padding:12px 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:all 0.25s cubic-bezier(0.25,0.46,0.45,0.94);z-index:210}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-menu a{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:13px;font-weight:500;color:var(--body);transition:all 0.15s}
.nav-dropdown-menu a:hover{background:var(--burgundy-tint);color:var(--burgundy)}
.nav-dropdown-menu a svg{width:16px;height:16px;stroke:var(--muted);flex-shrink:0}
.nav-dropdown-menu a:hover svg{stroke:var(--burgundy)}
.nav-dropdown-divider{height:1px;background:var(--border);margin:8px 0}
.nav-dropdown-label{padding:4px 20px 8px;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--xmuted)}
/* ── WORDPRESS NAV DROPDOWN (menu-item-has-children + sub-menu) ──────── */
.nav-links .menu-item-has-children{position:relative}
.nav-links .menu-item-has-children>a{display:flex;align-items:center;gap:5px}
.nav-links .menu-item-has-children>a::after{content:'';width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;opacity:0.45;transition:transform 0.25s;flex-shrink:0}
.nav-links .menu-item-has-children:hover>a::after{transform:rotate(180deg)}
.nav-links .sub-menu{position:absolute;top:calc(100% + 10px);left:-20px;min-width:220px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 16px 48px rgba(0,0,0,0.10);padding:10px 0;opacity:0;visibility:hidden;transform:translateY(10px);transition:all 0.25s cubic-bezier(0.25,0.46,0.45,0.94);z-index:220;list-style:none;margin:0}
.nav-links .menu-item-has-children:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-links .sub-menu li{list-style:none;padding:0;margin:0;display:block}
.nav-links .sub-menu a{display:flex;align-items:center;gap:10px;padding:10px 22px;font-size:13px;font-weight:500;color:var(--body);transition:all 0.15s;white-space:nowrap}
.nav-links .sub-menu a:hover{background:var(--cream-warm);color:var(--ink);font-weight:600}
.nav-links .sub-menu a::after{display:none}
/* Mobile sub-menu */
.mobile-menu .sub-menu{list-style:none;padding:0;margin:0;border-top:1px solid var(--border)}
.mobile-menu .sub-menu li{list-style:none;padding:0;margin:0;display:block}
.mobile-menu .sub-menu a{padding:11px 16px 11px 32px;font-size:13px;color:var(--muted)}

/* ── CONSULTATION MODAL ────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(4px);z-index:500;opacity:0;visibility:hidden;transition:all 0.3s ease;display:flex;align-items:center;justify-content:center;padding:24px}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:#fff;border-radius:20px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,0.2);transform:scale(0.95) translateY(16px);transition:transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94);position:relative}
.modal-overlay.open .modal{transform:scale(1) translateY(0)}
.modal-header{padding:32px 32px 0;display:flex;align-items:flex-start;justify-content:space-between}
.modal-header h2{font-family:var(--serif);font-size:24px;font-weight:500;color:var(--ink);letter-spacing:-0.3px}
.modal-header p{font-size:13px;color:var(--muted);margin-top:6px;line-height:1.5}
.modal-close{width:36px;height:36px;border-radius:50%;background:var(--burgundy-tint);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.2s;flex-shrink:0;margin-left:16px}
.modal-close:hover{background:var(--burgundy);color:#fff}
.modal-close svg{width:16px;height:16px;stroke:currentColor}
.modal-body{padding:24px 32px 32px}
.modal-body .form-group{margin-bottom:14px}
.modal-body .btn{width:100%;justify-content:center;margin-top:8px}
.modal-success{text-align:center;padding:48px 32px}
.modal-success svg{width:56px;height:56px;stroke:#1a7a3a;margin:0 auto 16px}
.modal-success h3{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);margin-bottom:8px}
.modal-success p{font-size:14px;color:var(--muted);line-height:1.6}
@media(max-width:640px){.modal{max-width:100%;border-radius:16px}.modal-header,.modal-body{padding-left:20px;padding-right:20px}}

/* ── AVATAR / SERVICE PAGE HERO ────────────────────────────────────── */
.avatar-hero{position:relative;min-height:480px;display:flex;align-items:center;overflow:hidden;margin-top:72px;background:var(--burgundy-deep)}
.avatar-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.avatar-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.5) 60%,rgba(0,0,0,0.3) 100%)}
.avatar-hero-content{position:relative;z-index:2;padding:60px var(--px);max-width:600px}
.avatar-hero .eyebrow{color:var(--gold-light);margin-bottom:16px}
.avatar-hero h1{font-family:var(--serif);font-size:clamp(32px,5vw,52px);font-weight:400;color:#fff;line-height:1.1;letter-spacing:-0.5px;margin-bottom:16px}
.avatar-hero p{font-size:16px;color:rgba(255,255,255,0.6);line-height:1.7;margin-bottom:28px;max-width:460px}
@media(max-width:768px){.avatar-hero{min-height:400px}.avatar-hero-content{padding:40px var(--px)}}

/* ── SERVICE CONTENT BLOCKS ────────────────────────────────────────── */
.service-split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.service-split.reverse{direction:rtl}.service-split.reverse>*{direction:ltr}
.service-split h2{font-family:var(--serif);font-size:clamp(24px,3vw,34px);font-weight:500;color:var(--ink);line-height:1.2;margin-bottom:16px;letter-spacing:-0.2px}
.service-split p{font-size:15px;color:var(--body);line-height:1.8;margin-bottom:12px}
.service-split-img{border-radius:16px;overflow:hidden;aspect-ratio:4/3}
.service-split-img img{width:100%;height:100%;object-fit:cover}
.service-checklist{margin:20px 0;display:flex;flex-direction:column;gap:10px}
.service-checklist li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--body);line-height:1.6}
.service-checklist li svg{width:18px;height:18px;stroke:var(--burgundy);flex-shrink:0;margin-top:2px}
@media(max-width:768px){.service-split,.service-split.reverse{grid-template-columns:1fr;gap:32px;direction:ltr}}

/* ══════════════════════════════════════════════════════════════════════
   HOMEPAGE-SPECIFIC STYLES
   ══════════════════════════════════════════════════════════════════════ */

/* ── HERO (split: text left, video right, blended) ─────────────────── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;margin-top:72px;background:#0D0D0D}
.hero-video-wrap{position:absolute;top:0;right:0;width:60%;height:100%;overflow:hidden}
.hero-video{width:100%;height:100%;object-fit:cover;opacity:0.55}
.hero-video-wrap::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to right,#0D0D0D 0%,rgba(13,13,13,0.85) 15%,rgba(13,13,13,0.3) 50%,rgba(13,13,13,0.1) 80%,rgba(13,13,13,0.25) 100%)}
.hero-video-wrap::after{content:'';position:absolute;inset:0;z-index:2;background:linear-gradient(to bottom,rgba(13,13,13,0.4) 0%,transparent 20%,transparent 80%,rgba(13,13,13,0.5) 100%)}
.hero-content{position:relative;z-index:10;text-align:left;padding:0 var(--px);max-width:600px;margin-left:max(var(--px), calc((100vw - var(--max-w)) / 2 + var(--px)))}
.hero-eyebrow{font-size:12px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold-light);margin-bottom:24px}
.hero h1{font-family:var(--serif);font-size:clamp(38px,5.5vw,64px);font-weight:400;color:#fff;line-height:1.08;margin-bottom:24px;letter-spacing:-0.5px}
.hero h1 em{font-style:italic;font-weight:500;color:rgba(255,255,255,0.75)}
.hero-sub{font-size:clamp(15px,1.6vw,17px);color:rgba(255,255,255,0.5);line-height:1.8;margin-bottom:36px;max-width:460px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-ctas .btn{min-width:150px;justify-content:center}
.hero-scroll{position:absolute;bottom:32px;left:var(--px);z-index:10;color:rgba(255,255,255,0.25);font-size:11px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;animation:float 3s ease-in-out infinite}
.hero-scroll svg{width:16px;height:16px;stroke:rgba(255,255,255,0.4)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@media(max-width:1024px){
  .hero-video-wrap{width:100%;opacity:0.35}
  .hero-content{text-align:center;margin:0 auto;max-width:600px}
  .hero-ctas{justify-content:center}
  .hero-scroll{left:50%;transform:translateX(-50%)}
}
@media(max-width:640px){.hero{min-height:90vh}}

/* ── INTRO / MISSION ──────────────────────────────────────────────── */
.intro{background:var(--cream)}
.intro-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.intro-text .eyebrow{margin-bottom:16px}
.intro-text h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,42px);font-weight:500;color:var(--ink);line-height:1.15;margin-bottom:24px;letter-spacing:-0.3px}
.intro-text p{font-size:15px;color:var(--body);line-height:1.8;margin-bottom:16px}
.intro-img{position:relative;height:480px;overflow:hidden;border-radius:16px}
.intro-img-placeholder{width:100%;height:100%;background:linear-gradient(145deg,var(--burgundy-tint),var(--cream-deep));display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--muted)}
.intro-stat-bar{display:flex;gap:40px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}
.intro-stat{text-align:left}
.intro-stat-num{font-family:var(--serif);font-size:32px;font-weight:700;color:var(--burgundy)}
.intro-stat-label{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase;margin-top:2px}
@media(max-width:768px){
  .intro-inner{grid-template-columns:1fr;gap:40px}
  .intro-img{height:320px}
  .intro-stat-bar{gap:24px}
}

/* ── VALUE PILLARS ─────────────────────────────────────────────────── */
.pillars{background:var(--burgundy-deep);color:#fff}
.pillars-header{text-align:center;margin-bottom:56px}
.pillars-header .eyebrow{color:var(--gold)}
.pillars-header h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:400;margin-top:12px;color:#fff;letter-spacing:-0.3px}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.pillar{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);border-radius:16px;padding:44px 36px;transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}
.pillar:hover{background:rgba(255,255,255,0.08);transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,0.2)}
.pillar-icon{width:56px;height:56px;background:rgba(255,255,255,0.08);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.pillar-icon svg{width:28px;height:28px;stroke:rgba(255,255,255,0.7)}
.pillar h3{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:14px;letter-spacing:-0.2px}
.pillar p{font-size:14px;color:rgba(255,255,255,0.50);line-height:1.8}
@media(max-width:768px){.pillars-grid{grid-template-columns:1fr;gap:20px}}

/* ── FEATURED SHOWCASE ─────────────────────────────────────────────── */
.showcase{background:var(--cream-warm);border-top:1px solid var(--border)}
.showcase-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:16px}
.showcase-header h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:500;color:var(--ink);letter-spacing:-0.3px}
.showcase-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.showcase-card{position:relative;border-radius:16px;overflow:hidden;height:400px;cursor:pointer}
.showcase-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s cubic-bezier(0.25,0.46,0.45,0.94)}
.showcase-card:hover img{transform:scale(1.04)}
.showcase-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.1) 50%,transparent 100%)}
.showcase-card-content{position:absolute;bottom:0;left:0;right:0;padding:32px;z-index:2}
.showcase-card-badge{font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:4px 12px;border-radius:4px;display:inline-block;margin-bottom:12px}
.showcase-card-badge.sold{background:#1a7a3a;color:#fff}
.showcase-card-badge.active{background:#fff;color:var(--ink)}
.showcase-card h3{font-family:var(--serif);font-size:24px;font-weight:600;color:#fff;margin-bottom:4px}
.showcase-card .showcase-address{font-size:13px;color:rgba(255,255,255,0.5);margin-bottom:12px}
.showcase-card .showcase-price{font-family:var(--serif);font-size:28px;font-weight:700;color:#fff}
.showcase-card .showcase-stats{display:flex;gap:16px;margin-top:10px}
.showcase-card .showcase-stat{font-size:12px;color:rgba(255,255,255,0.6);display:flex;align-items:center;gap:4px}
.showcase-card:first-child{grid-row:span 2;height:auto}
@media(max-width:768px){.showcase-grid{grid-template-columns:1fr}.showcase-card:first-child{grid-row:auto;height:400px}}

/* ── COMMUNITIES HEADER ────────────────────────────────────────────── */
.communities-header{text-align:center;margin-bottom:48px}
.communities-header h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:500;color:var(--ink);margin-top:12px;letter-spacing:-0.3px}
.communities-header p{font-size:15px;color:var(--muted);line-height:1.7;margin-top:12px;max-width:560px;margin-left:auto;margin-right:auto}
.communities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:1024px){.communities-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.communities-grid{grid-template-columns:1fr}}

/* ── MARKET SECTION ────────────────────────────────────────────────── */
.market-header{text-align:center;margin-bottom:48px}
.market-header h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:500;color:var(--ink);margin-top:12px;letter-spacing:-0.3px}
.market-header p{font-size:15px;color:var(--muted);line-height:1.7;margin-top:12px;max-width:560px;margin-left:auto;margin-right:auto}
.market-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}
@media(max-width:1024px){.market-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.market-grid{grid-template-columns:1fr}}
.market-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
.market-detail-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:32px;box-shadow:var(--shadow)}
.market-detail-card h3{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.market-detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--cream-deep);font-size:14px}
.market-detail-row span:first-child{color:var(--body)}
.market-detail-row span:last-child{font-weight:600;color:var(--ink)}
.market-source{text-align:center;margin-top:32px;font-size:13px;color:var(--muted)}
.market-source a{color:var(--burgundy);font-weight:600;text-decoration:underline}
@media(max-width:768px){.market-detail-grid{grid-template-columns:1fr}}

/* ── IDX BANNER ────────────────────────────────────────────────────── */
.idx-banner{background:var(--burgundy-deep);color:#fff;position:relative;overflow:hidden}
.idx-banner-pattern{position:absolute;inset:0;opacity:0.03;background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);background-size:32px 32px}
.idx-inner{display:grid;grid-template-columns:1fr 400px;gap:64px;align-items:center;position:relative;z-index:2}
.idx-text h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:500;color:#fff;margin-top:12px;letter-spacing:-0.3px;line-height:1.15;margin-bottom:16px}
.idx-text p{font-size:15px;color:rgba(255,255,255,0.5);line-height:1.8;margin-bottom:24px}
.idx-features{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.idx-feature{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:rgba(255,255,255,0.7)}
.idx-feature svg{width:18px;height:18px;stroke:var(--gold);flex-shrink:0}
.idx-mockup{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:36px 32px;text-align:center}
.idx-mockup-label{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.idx-mockup-title{font-family:var(--serif);font-size:20px;font-weight:600;color:#fff;margin-bottom:8px}
.idx-mockup-desc{font-size:13px;color:rgba(255,255,255,0.45);line-height:1.7}
.mls-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:6px 14px;border:1px solid var(--border);border-radius:6px;color:var(--gold);border-color:rgba(153,153,153,0.25);background:rgba(153,153,153,0.08)}
.mls-badge svg{width:14px;height:14px}
@media(max-width:1024px){.idx-inner{grid-template-columns:1fr;gap:40px}.idx-mockup{max-width:400px}}

/* ── PROCESS ───────────────────────────────────────────────────────── */
.process{background:var(--cream-warm)}
.process-header{text-align:center;margin-bottom:56px}
.process-header h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:500;color:var(--ink);margin-top:12px;letter-spacing:-0.3px}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.process-step{text-align:center;padding:20px}
.process-num{font-family:var(--serif);font-size:48px;font-weight:700;color:var(--cream-deep);margin-bottom:16px;line-height:1;transition:color 0.3s}
.process-step:hover .process-num{color:var(--burgundy)}
.process-step h3{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:10px}
.process-step p{font-size:13px;color:var(--muted);line-height:1.7}
@media(max-width:1024px){.process-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.process-grid{grid-template-columns:1fr}}

/* ── TESTIMONIALS SECTION ──────────────────────────────────────────── */
.testimonials{background:var(--burgundy-deep);color:#fff}
.testimonials-header{text-align:center;margin-bottom:48px}
.testimonials-header .eyebrow{color:var(--gold)}
.testimonials-header h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:400;margin-top:12px;color:#fff;letter-spacing:-0.3px}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:1024px){.testimonials-grid{grid-template-columns:1fr;max-width:600px;margin:0 auto}}

/* ── INSTAGRAM SECTION ─────────────────────────────────────────────── */
.instagram-header{text-align:center;margin-bottom:40px}
.instagram-header h2{font-family:var(--serif);font-size:clamp(24px,3vw,36px);font-weight:500;color:var(--ink);margin-top:12px;letter-spacing:-0.3px}
.instagram-header p{font-size:14px;color:var(--muted);margin-top:8px}
.instagram-header a{color:var(--burgundy);font-weight:600}
.instagram-cta{text-align:center;margin-top:32px}

/* ── CONTACT BAND ──────────────────────────────────────────────────── */
.contact-band{background:var(--cream-warm);border-top:1px solid var(--border)}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.contact-text .eyebrow{margin-bottom:16px}
.contact-text h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:500;color:var(--ink);line-height:1.15;margin-bottom:16px;letter-spacing:-0.3px}
.contact-text p{font-size:15px;color:var(--body);line-height:1.8;margin-bottom:24px}
.contact-details{display:flex;flex-direction:column;gap:20px}
.contact-detail{display:flex;gap:16px;align-items:flex-start}
.contact-detail-icon{width:44px;height:44px;background:var(--burgundy-tint);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-detail-icon svg{width:20px;height:20px;stroke:var(--burgundy)}
.contact-detail-text{font-size:14px;color:var(--body);line-height:1.5}
.contact-detail-text strong{display:block;font-size:12px;font-weight:700;color:var(--ink);letter-spacing:0.04em;text-transform:uppercase;margin-bottom:2px}
@media(max-width:768px){.contact-inner{grid-template-columns:1fr;gap:40px}}

/* ══════════════════════════════════════════════════════════════════════
   BLOG SINGLE POST STYLES
   ══════════════════════════════════════════════════════════════════════ */

/* ── READING PROGRESS BAR ─────────────────────────────────────────── */
.reading-progress{position:fixed;top:72px;left:0;width:0;height:3px;background:var(--burgundy);z-index:300;transition:width 0.1s linear}

/* ── BREADCRUMB ───────────────────────────────────────────────────── */
.breadcrumb{padding:20px 0;font-size:13px;color:var(--muted)}
.breadcrumb a{color:var(--muted);transition:color 0.15s}
.breadcrumb a:hover{color:var(--burgundy)}
.breadcrumb span{color:var(--xmuted);margin:0 8px}

/* ── ARTICLE HEADER ───────────────────────────────────────────────── */
.article-header{padding:0 0 48px;max-width:720px}
.article-category{display:inline-block;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:6px 14px;background:var(--burgundy);color:#fff;border-radius:4px;margin-bottom:20px}
.article-header h1{font-family:var(--serif);font-size:clamp(32px,5vw,48px);font-weight:500;color:var(--ink);line-height:1.12;letter-spacing:-0.5px;margin-bottom:16px}
.article-subtitle{font-size:18px;color:var(--muted);line-height:1.6;margin-bottom:32px}
.article-meta{display:flex;align-items:center;gap:16px;padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap}
.author-card{display:flex;align-items:center;gap:14px}
.author-card img{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}
.author-card-info{display:flex;flex-direction:column}
.author-card-name{font-size:14px;font-weight:600;color:var(--ink)}
.author-card-role{font-size:12px;color:var(--muted)}
.meta-divider{width:1px;height:32px;background:var(--border)}
.meta-date{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.meta-date svg{width:14px;height:14px;stroke:var(--gold)}
.meta-read{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.meta-read svg{width:14px;height:14px;stroke:var(--gold)}

/* ── SHARE BUTTONS ────────────────────────────────────────────────── */
.share-row{display:flex;align-items:center;gap:10px;margin-top:20px}
.share-label{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold-deep);margin-right:4px}
.share-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--body);transition:all 0.25s ease;background:#fff;cursor:pointer}
.share-btn:hover{background:var(--burgundy);color:#fff;border-color:var(--burgundy);transform:scale(1.08)}
.share-btn svg{width:16px;height:16px}

/* ── ARTICLE LAYOUT ───────────────────────────────────────────────── */
.article-layout{display:grid;grid-template-columns:1fr 260px;gap:64px;padding-bottom:80px;align-items:start}
.article-body{max-width:720px;font-size:17px;line-height:1.9;color:var(--body)}
.article-body h2{font-family:var(--serif);font-size:28px;font-weight:600;color:var(--ink);margin:48px 0 20px;letter-spacing:-0.3px;line-height:1.2;scroll-margin-top:100px}
.article-body h2:first-of-type{margin-top:0}
.article-body p{margin-bottom:20px}
.article-body strong{color:var(--ink);font-weight:600}
.article-body blockquote{border-left:3px solid var(--burgundy);padding:20px 24px;margin:32px 0;font-style:italic;font-size:19px;line-height:1.7;color:var(--ink);background:var(--cream-warm);border-radius:0 8px 8px 0}
.article-body blockquote cite{display:block;font-size:13px;font-weight:600;font-style:normal;color:var(--muted);margin-top:12px}
.article-body table{width:100%;border-collapse:collapse;margin:32px 0;font-size:14px}
.article-body thead{background:var(--burgundy);color:#fff}
.article-body th{padding:12px 16px;text-align:left;font-weight:600;font-size:12px;letter-spacing:0.04em;text-transform:uppercase}
.article-body td{padding:12px 16px;border-bottom:1px solid var(--border)}
.article-body tbody tr:nth-child(even){background:var(--cream-warm)}
.article-body tbody tr:hover{background:var(--cream-deep)}
.callout{display:flex;gap:16px;padding:24px;margin:32px 0;border-left:4px solid var(--burgundy);background:var(--burgundy-tint);border-radius:0 12px 12px 0}
.callout-icon{flex-shrink:0;width:32px;height:32px;background:var(--burgundy);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}
.callout-icon svg{width:16px;height:16px}
.callout-content{flex:1}
.callout-content strong{display:block;font-size:14px;color:var(--ink);margin-bottom:4px}
.callout-content p{margin:0;font-size:14px;color:var(--body);line-height:1.7}
.stat-inline{display:inline-flex;align-items:baseline;gap:6px;background:var(--cream-warm);padding:4px 12px;border-radius:6px;font-weight:700;color:var(--ink);white-space:nowrap}

/* ── TABLE OF CONTENTS (SIDEBAR) ──────────────────────────────────── */
.toc-sidebar{position:sticky;top:100px;width:240px}
.toc-card{background:var(--cream-card);border:1px solid var(--border);border-radius:14px;padding:24px 20px;box-shadow:var(--shadow)}
.toc-card-title{font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.toc-list{display:flex;flex-direction:column;gap:2px}
.toc-list a{display:block;font-size:13px;color:var(--muted);padding:8px 12px;border-radius:6px;transition:all 0.2s ease;line-height:1.4;border-left:2px solid transparent}
.toc-list a:hover{color:var(--ink);background:var(--cream-warm)}
.toc-list a.active{color:var(--burgundy);font-weight:600;background:var(--burgundy-tint);border-left-color:var(--burgundy)}

/* ── AUDIO READER ─────────────────────────────────────────────────── */
.audio-player{position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--burgundy-deep);z-index:250;display:flex;align-items:center;padding:0 24px;gap:16px;color:#fff;box-shadow:0 -2px 16px rgba(0,0,0,0.15);transform:translateY(100%);transition:transform 0.4s cubic-bezier(0.25,0.46,0.45,0.94)}
.audio-player.visible{transform:translateY(0)}
.audio-play-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.2s;flex-shrink:0}
.audio-play-btn:hover{background:rgba(255,255,255,0.2)}
.audio-play-btn svg{width:18px;height:18px;fill:#fff}
.audio-label{font-size:13px;font-weight:500;color:rgba(255,255,255,0.7);white-space:nowrap}
.audio-label svg{width:16px;height:16px;margin-right:6px;vertical-align:middle;stroke:rgba(255,255,255,0.5)}
.audio-progress{flex:1;height:4px;background:rgba(255,255,255,0.12);border-radius:4px;overflow:hidden;cursor:pointer;min-width:80px}
.audio-progress-fill{height:100%;width:0%;background:#fff;border-radius:4px;transition:width 0.3s linear}
.audio-time{font-size:12px;font-weight:500;color:rgba(255,255,255,0.5);white-space:nowrap;font-variant-numeric:tabular-nums}
.audio-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0.4;transition:opacity 0.2s;flex-shrink:0}
.audio-close:hover{opacity:1}
.audio-close svg{width:14px;height:14px;stroke:#fff}

/* Audio trigger button */
.audio-trigger{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;background:var(--burgundy-deep);color:#fff;border-radius:10px;cursor:pointer;transition:all 0.25s ease;margin:24px 0 8px}
.audio-trigger:hover{background:var(--burgundy);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.12)}
.audio-trigger svg{width:18px;height:18px}
.audio-trigger span{font-size:13px;font-weight:500}
.audio-trigger .audio-dur{font-size:12px;color:rgba(255,255,255,0.5);margin-left:4px}

/* ── AUTHOR BIO BOX ───────────────────────────────────────────────── */
.author-bio{display:flex;gap:24px;padding:36px;background:var(--cream-warm);border:1px solid var(--border);border-radius:16px;margin:56px 0}
.author-bio img{width:80px;height:80px;border-radius:50%;object-fit:cover;flex-shrink:0;border:3px solid var(--border)}
.author-bio-text h4{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:2px}
.author-bio-text .author-bio-role{font-size:12px;color:var(--gold-deep);font-weight:600;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:10px}
.author-bio-text p{font-size:14px;color:var(--body);line-height:1.7;margin-bottom:14px}
.author-bio-links{display:flex;gap:10px;align-items:center}
.author-bio-links a{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all 0.2s}
.author-bio-links a:hover{background:var(--burgundy);color:#fff;border-color:var(--burgundy)}
.author-bio-links a svg{width:14px;height:14px}
.author-bio-links .view-all{font-size:12px;font-weight:600;color:var(--burgundy);margin-left:8px;display:flex;align-items:center;gap:4px}
.author-bio-links .view-all:hover{text-decoration:underline}

/* ── RELATED ARTICLES ─────────────────────────────────────────────── */
.related-section{padding:80px 0;background:var(--cream-warm);border-top:1px solid var(--border)}
.related-header{text-align:center;margin-bottom:48px}
.related-header h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,36px);font-weight:500;color:var(--ink);margin-top:12px;letter-spacing:-0.3px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.related-card{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}
.related-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.related-card-img{height:200px;overflow:hidden}
.related-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s}
.related-card:hover .related-card-img img{transform:scale(1.05)}
.related-card-body{padding:24px}
.related-card-cat{font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:8px}
.related-card-body h3{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:8px}
.related-card-body p{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:14px}
.related-card-meta{font-size:12px;color:var(--xmuted);display:flex;gap:12px}

/* ── CTA BAND ─────────────────────────────────────────────────────── */
.cta-band{background:var(--burgundy-deep);padding:64px 0;text-align:center}
.cta-band h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,40px);font-weight:500;color:#fff;margin-bottom:12px;letter-spacing:-0.3px}
.cta-band p{font-size:16px;color:rgba(255,255,255,0.5);margin-bottom:32px;max-width:480px;margin-left:auto;margin-right:auto}

/* ── ARTICLE HERO IMAGE ──────────────────────────────────────────── */
.article-hero{margin-top:72px;position:relative;height:420px;overflow:hidden}
.article-hero img{width:100%;height:100%;object-fit:cover}
.article-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,0.4) 100%)}

/* ── BLOG SINGLE RESPONSIVE ──────────────────────────────────────── */
@media(max-width:1024px){
  .article-layout{grid-template-columns:1fr;gap:0}
  .toc-sidebar{position:relative;top:0;width:100%;order:-1;margin-bottom:40px}
  .toc-card{padding:16px 20px}
  .toc-list{flex-direction:row;overflow-x:auto;gap:4px;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .toc-list a{white-space:nowrap;font-size:12px;padding:6px 14px;border-left:none;border-bottom:2px solid transparent;border-radius:0}
  .toc-list a.active{border-left:none;border-bottom-color:var(--burgundy)}
  .toc-card-title{margin-bottom:12px;padding-bottom:8px}
  .article-body{max-width:100%}
}
@media(max-width:768px){
  .article-header h1{font-size:28px}
  .article-hero{height:280px}
  .author-bio{flex-direction:column;text-align:center;align-items:center}
  .author-bio-links{justify-content:center}
  .related-grid{grid-template-columns:1fr}
}

/* ── CONTACT PAGE DETAILS ─────────────────────────────────────────── */
.contact-details{padding-top:8px}
.contact-details .eyebrow{margin-bottom:16px}
.contact-details h2{font-family:var(--serif);font-size:clamp(24px,3vw,36px);font-weight:500;color:var(--ink);line-height:1.15;letter-spacing:-0.3px;margin-bottom:12px}
.contact-details > p{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:36px}

/* ── WORDPRESS ALIGNMENT CLASSES ──────────────────────────────────── */
.alignleft{float:left;margin:0 24px 16px 0}
.alignright{float:right;margin:0 0 16px 24px}
.aligncenter{display:block;margin:0 auto 24px}
.wp-caption{max-width:100%;margin-bottom:24px}
.wp-caption-text{font-size:12px;color:var(--muted);font-style:italic;margin-top:8px}

/* ── WORDPRESS BLOCK EDITOR SUPPORT ───────────────────────────────── */
.wp-block-image{margin-bottom:24px}
.wp-block-image figcaption{font-size:12px;color:var(--muted);font-style:italic;margin-top:8px;text-align:center}
.wp-block-quote{border-left:3px solid var(--burgundy);padding:20px 24px;margin:32px 0;font-style:italic;background:var(--cream-warm);border-radius:0 8px 8px 0}
.wp-block-quote cite{display:block;font-size:13px;font-weight:600;font-style:normal;color:var(--muted);margin-top:12px}
.wp-block-separator{border:none;border-top:1px solid var(--border);margin:48px 0}
.wp-block-button .wp-block-button__link{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;letter-spacing:0.04em;padding:15px 36px;border-radius:8px;background:var(--burgundy);color:#fff;transition:all 0.35s cubic-bezier(0.25,0.46,0.45,0.94)}
.wp-block-button .wp-block-button__link:hover{background:var(--burgundy-deep);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.15)}

/* ══════════════════════════════════════════════════════════════════════
   SINGLE PROPERTY
   ══════════════════════════════════════════════════════════════════════ */
/* Gallery */
.property-gallery{margin-top:72px;background:var(--ink)}
.gallery-hero{position:relative;width:100%;height:540px;overflow:hidden;cursor:zoom-in}
.gallery-hero img,.gallery-main-img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity 0.3s}
.gallery-badge{position:absolute;top:20px;left:20px;background:var(--burgundy);color:#fff;font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:6px 14px;border-radius:4px;z-index:2}
.gallery-price{position:absolute;bottom:24px;left:24px;background:rgba(0,0,0,0.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-family:var(--serif);font-size:22px;font-weight:500;padding:10px 20px;border-radius:8px;z-index:2}
.gallery-thumbs{display:flex;gap:8px;padding:12px 20px;overflow-x:auto;background:#111;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.gallery-thumbs::-webkit-scrollbar{display:none}
.gallery-thumbs .thumb{flex-shrink:0;width:88px;height:60px;overflow:hidden;border-radius:6px;border:2px solid transparent;cursor:pointer;padding:0;background:none;transition:border-color 0.2s}
.gallery-thumbs .thumb.active{border-color:var(--gold)}
.gallery-thumbs .thumb img{width:100%;height:100%;object-fit:cover;display:block}
/* Layout */
.property-layout{display:grid;grid-template-columns:1fr 340px;gap:56px;align-items:start;padding:48px 0 80px}
/* Main */
.property-header{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--border)}
.property-title{font-family:var(--serif);font-size:clamp(26px,4vw,40px);font-weight:500;color:var(--ink);line-height:1.15;letter-spacing:-0.4px;margin-bottom:10px}
.property-address{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--muted);margin-bottom:0}
.property-price-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:16px}
.property-price{font-family:var(--serif);font-size:32px;font-weight:600;color:var(--ink);letter-spacing:-0.5px}
.property-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:5px 12px;border-radius:4px;background:var(--cream-deep);color:var(--ink)}
.property-badge.sold{background:#fce4ec;color:#880e4f}
.mls-code{display:inline-block;font-size:11px;color:var(--muted);background:var(--cream-warm);padding:4px 10px;border-radius:4px;letter-spacing:0.05em;border:1px solid var(--border)}
/* Stats grid */
.property-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:32px 0}
.detail-item{display:flex;flex-direction:column;gap:4px;padding:18px 16px;background:#fff}
.detail-label{font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}
.detail-value{font-size:17px;font-weight:600;color:var(--ink);font-family:var(--serif)}
/* Highlights */
.property-highlights{margin:0 0 36px;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.property-highlights li{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--body);line-height:1.5}
.property-highlights li svg{flex-shrink:0;margin-top:1px}
/* Features grid */
.property-features-grid{margin:0 0 36px;padding:0;list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:10px 16px}
.property-feature-item{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--body);line-height:1.4}
.property-feature-item svg{flex-shrink:0}
@media(max-width:600px){.property-features-grid{grid-template-columns:repeat(2,1fr)}}
/* Description & sections */
.property-description{font-size:16px;line-height:1.85;color:var(--body);margin-bottom:40px}
.property-description h2{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--ink);margin:32px 0 12px}
.property-section-title{font-family:var(--serif);font-size:20px;font-weight:500;color:var(--ink);margin:40px 0 16px;padding-top:40px;border-top:1px solid var(--border)}
.property-section-title:first-child{margin-top:0;padding-top:0;border-top:none}
/* Video */
.property-video-wrap{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:12px;margin-bottom:40px;background:var(--ink)}
.property-video-wrap iframe,.property-video-wrap video{position:absolute;top:0;left:0;width:100%;height:100%;border:0;border-radius:12px}
/* Virtual Tour button */
.property-tour-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-weight:600;color:var(--ink);text-decoration:none;transition:all 0.2s;margin-bottom:40px;background:#fff}
.property-tour-btn:hover{border-color:var(--burgundy);color:var(--burgundy);transform:translateY(-1px)}
/* Map */
.property-map-wrap{border-radius:12px;overflow:hidden;height:380px;margin-bottom:40px}
.property-map-wrap iframe{width:100%;height:100%;border:0;display:block}
/* Sidebar */
.property-sidebar{display:flex;flex-direction:column;gap:16px;position:sticky;top:88px}
.sidebar-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.sidebar-price{font-family:var(--serif);font-size:28px;font-weight:600;color:var(--ink);letter-spacing:-0.4px;margin-bottom:4px}
.sidebar-type{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}
.sidebar-card h3{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--ink);margin-bottom:16px}
.agent-info{display:flex;gap:12px;align-items:center;margin-bottom:16px}
.agent-photo{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0}
.agent-photo-placeholder{width:52px;height:52px;border-radius:50%;background:var(--cream-deep);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.agent-details strong{display:block;font-size:14px;font-weight:700;color:var(--ink);line-height:1.3}
.agent-details span{font-size:12px;color:var(--muted)}
.sidebar-contact-row{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--body);text-decoration:none;padding:8px 0;border-bottom:1px solid var(--border);transition:color 0.2s}
.sidebar-contact-row:last-child{border-bottom:none}
.sidebar-contact-row:hover{color:var(--burgundy)}
.sidebar-contact-row svg{flex-shrink:0;stroke:var(--burgundy)}
.sidebar-mls{font-size:11px;color:var(--muted);text-align:center}
/* Responsive */
@media(max-width:1100px){
  .property-layout{grid-template-columns:1fr 300px;gap:36px}
}
@media(max-width:900px){
  .property-layout{grid-template-columns:1fr;gap:32px}
  .property-sidebar{position:relative;top:0}
  .property-stats{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:640px){
  .gallery-hero{height:280px}
  .gallery-price{font-size:17px;padding:8px 14px}
  .property-stats{grid-template-columns:repeat(2,1fr)}
  .property-price{font-size:24px}
  .sidebar-price{font-size:22px}
}
