/* LuxEstate — Premium real estate theme */

:root{
  --navy:#0b1228;
  --navy-2:#121a37;
  --gold:#c9a44c;
  --gold-2:#e6c469;
  --cream:#f6f1e7;
  --charcoal:#1c1f26;
  --bg:#ffffff;
  --fg:#0b1228;
  --muted:#6b7280;
  --line:rgba(11,18,40,.08);
  --card:#ffffff;
  --shadow-sm:0 4px 14px rgba(11,18,40,.06);
  --shadow-md:0 18px 40px -12px rgba(11,18,40,.18);
  --shadow-lg:0 40px 80px -20px rgba(11,18,40,.35);
  --radius:18px;
  --radius-sm:12px;
  --ease:cubic-bezier(.22,1,.36,1);
  --serif:"Cormorant Garamond", "Times New Roman", serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --container:1240px;
}

.mode-dark{
  --bg:#070b1a;
  --fg:#f1efe8;
  --card:#0f1530;
  --line:rgba(255,255,255,.08);
  --muted:#9aa1b2;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font-family:var(--sans);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  transition:background-color .35s var(--ease), color .35s var(--ease);
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em}
p{margin:0 0 1em}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font:inherit}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
@media (max-width:768px){.section{padding:64px 0}}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:#fff;color:#000;padding:8px 14px;z-index:9999;border-radius:6px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 26px;border-radius:999px;font-weight:600;font-size:14px;letter-spacing:.02em;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background-color .25s var(--ease), color .25s var(--ease);
  cursor:pointer;min-height:44px;text-align:center;
}
.btn-lg{padding:16px 32px;font-size:15px}
.btn-block{width:100%}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#10131f;box-shadow:0 10px 24px -8px rgba(201,164,76,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 30px -10px rgba(201,164,76,.7);color:#10131f}
.btn-outline{border:1px solid var(--line);background:transparent;color:var(--fg)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  background:color-mix(in oklab, var(--bg) 80%, transparent);
  border-bottom:1px solid var(--line);
  transition:background-color .3s var(--ease), border-color .3s var(--ease);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:78px}
.site-title{font-family:var(--serif);font-size:24px;font-weight:600;display:inline-flex;align-items:center;gap:8px}
.logo-mark{color:var(--gold);font-size:20px}
.primary-nav .menu{display:flex;gap:32px;list-style:none;margin:0;padding:0}
.primary-nav a{font-size:14px;font-weight:500;letter-spacing:.02em;position:relative}
.primary-nav a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.primary-nav a:hover::after{transform:scaleX(1)}
.header-actions{display:flex;align-items:center;gap:10px}
.theme-toggle{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center}
.theme-toggle:hover{border-color:var(--gold);color:var(--gold)}
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px;width:42px;height:42px;border-radius:8px;border:1px solid var(--line)}
.menu-toggle span{width:20px;height:2px;background:currentColor;display:block;margin:0 auto}

@media (max-width:960px){
  .primary-nav{display:none}
  .primary-nav.is-open{display:block;position:absolute;inset:78px 0 auto 0;background:var(--bg);border-bottom:1px solid var(--line);padding:24px}
  .primary-nav.is-open .menu{flex-direction:column;gap:18px}
  .menu-toggle{display:inline-flex}
  .header-actions .btn-outline{display:none}
}

/* HERO */
.hero{
  position:relative;
  min-height:92vh;
  display:flex;align-items:center;
  color:#fff;
  overflow:hidden;
  isolation:isolate;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transform:scale(1.08);
  animation:heroZoom 18s var(--ease) infinite alternate;
  z-index:-2;
}
@keyframes heroZoom{from{transform:scale(1.05)}to{transform:scale(1.15)}}
.hero-overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(60% 50% at 20% 30%, rgba(201,164,76,.25), transparent 60%),
    linear-gradient(180deg, rgba(7,11,26,.4) 0%, rgba(7,11,26,.75) 60%, rgba(7,11,26,.95) 100%);
}
.hero-particles{position:absolute;inset:0;pointer-events:none;z-index:-1}
.hero-particles span{
  position:absolute;width:6px;height:6px;background:var(--gold);border-radius:50%;opacity:.6;
  filter:blur(.5px);
  animation:float 14s ease-in-out infinite;
}
.hero-particles span:nth-child(1){top:20%;left:10%;animation-delay:0s}
.hero-particles span:nth-child(2){top:60%;left:20%;animation-delay:-2s;width:4px;height:4px}
.hero-particles span:nth-child(3){top:30%;left:75%;animation-delay:-4s}
.hero-particles span:nth-child(4){top:75%;left:60%;animation-delay:-6s;width:5px;height:5px}
.hero-particles span:nth-child(5){top:15%;left:50%;animation-delay:-8s;width:3px;height:3px}
.hero-particles span:nth-child(6){top:50%;left:85%;animation-delay:-10s}
@keyframes float{0%,100%{transform:translateY(0) translateX(0)}50%{transform:translateY(-30px) translateX(15px)}}
.hero-inner{position:relative;padding:120px 24px 200px;width:100%}
.hero-eyebrow{font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin:0 0 16px}
.hero-title{font-size:clamp(44px,7vw,96px);font-weight:500;margin:0 0 18px;max-width:18ch;color:#fff;text-shadow:0 6px 30px rgba(0,0,0,.35)}
.hero-subtitle{font-size:clamp(16px,1.4vw,20px);max-width:58ch;color:rgba(255,255,255,.85);margin:0 0 40px}
.hero-search{
  display:grid;
  grid-template-columns:repeat(4, 1fr) auto;
  gap:8px;align-items:end;
  padding:14px;
  max-width:1100px;
}
.hero-search .field{display:flex;flex-direction:column;gap:6px;padding:0 12px}
.hero-search label{font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:rgba(255,255,255,.75)}
.hero-search input,
.hero-search select{
  background:transparent;border:0;color:#fff;font-size:15px;padding:6px 0;
  border-bottom:1px solid rgba(255,255,255,.2);outline:none;
}
.hero-search select option{color:#000}
.hero-search input::placeholder{color:rgba(255,255,255,.6)}
.hero-search .btn{min-height:54px;padding:0 30px}
@media (max-width:900px){
  .hero-search{grid-template-columns:1fr 1fr;}
  .hero-search .btn{grid-column:1/-1}
}
.hero-stats{display:flex;flex-wrap:wrap;gap:40px;margin-top:48px}
.hero-stats > div{display:flex;flex-direction:column}
.hero-stats strong{font-family:var(--serif);font-size:42px;font-weight:600;color:var(--gold)}
.hero-stats span{font-size:13px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.7)}

.hero-skyline{
  position:absolute;left:0;right:0;bottom:0;
  width:100%;height:160px;color:rgba(0,0,0,.55);
  opacity:.9;pointer-events:none;
}

/* Glass */
.glass{
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
}
.glass-dark{
  background:linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
}
.glass-light{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  padding:28px;
}

/* Section heads */
.section-head{text-align:center;max-width:680px;margin:0 auto 56px}
.eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin:0 0 12px}
.section-title{font-size:clamp(32px,4vw,52px);margin:0 0 16px}
.section-sub{color:var(--muted);font-size:17px}

/* Property cards */
.properties-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px;
}
.property-card{
  background:var(--card);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  border:1px solid var(--line);
}
.property-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.property-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.property-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.property-card:hover .property-media img{transform:scale(1.08)}
.property-badge{
  position:absolute;top:16px;left:16px;
  background:rgba(11,18,40,.85);color:var(--gold);
  padding:6px 14px;border-radius:999px;font-size:11px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;
  backdrop-filter:blur(8px);
}
.favorite-btn{
  position:absolute;top:14px;right:14px;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.9);color:#0b1228;
  font-size:18px;display:inline-flex;align-items:center;justify-content:center;
  transition:transform .25s var(--ease), background-color .25s var(--ease), color .25s var(--ease);
}
.favorite-btn:hover, .favorite-btn.is-active{background:var(--gold);color:#fff;transform:scale(1.1)}
.property-body{padding:24px}
.property-price{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--gold);margin-bottom:6px}
.property-title{font-size:22px;margin:0 0 8px}
.property-title a:hover{color:var(--gold)}
.property-address{color:var(--muted);font-size:14px;margin:0 0 18px}
.property-meta{display:flex;gap:18px;list-style:none;padding:14px 0 0;margin:0;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}
.property-meta strong{color:var(--fg);font-weight:600;margin-right:4px}

/* Categories */
.section-dark{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.section-dark::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 20% 0%, rgba(201,164,76,.18), transparent 60%);
  pointer-events:none;
}
.categories-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:18px;
  position:relative;
}
.category-card{
  padding:36px 22px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);
  color:#fff;
}
.category-card:hover{transform:translateY(-6px);border-color:var(--gold);color:var(--gold)}
.cat-icon{font-size:36px}
.category-card h3{font-size:18px;margin:0;color:inherit}

/* CTA */
.cta-band{background:linear-gradient(135deg, var(--cream), #fff);position:relative}
.mode-dark .cta-band{background:linear-gradient(135deg, var(--navy-2), var(--navy))}
.cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
@media (max-width:900px){.cta-inner{grid-template-columns:1fr}}
.inquiry-form{display:grid;gap:14px;background:var(--card);padding:32px;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow-md)}
.inquiry-form input,.inquiry-form textarea,.inquiry-form select{
  width:100%;padding:14px 16px;border-radius:12px;border:1px solid var(--line);background:transparent;color:var(--fg);
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.inquiry-form input:focus,.inquiry-form textarea:focus,.inquiry-form select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,164,76,.15)}
.inquiry-form textarea{min-height:120px;resize:vertical}
.form-feedback{margin:0;font-size:14px;min-height:20px}
.form-feedback.is-success{color:#0a8a4b}
.form-feedback.is-error{color:#b91c1c}
.hp{position:absolute;left:-9999px;opacity:0;pointer-events:none}

/* Single property */
.property-hero{position:relative;height:72vh;min-height:480px;color:#fff;overflow:hidden}
.property-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-1}
.property-hero-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:64px 0;background:linear-gradient(180deg,transparent 30%,rgba(7,11,26,.85))}
.badge{background:rgba(201,164,76,.95);color:#10131f;padding:6px 14px;border-radius:999px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;font-weight:700}
.property-headline{font-size:clamp(36px,5vw,68px);margin:14px 0 8px}
.property-address-lg{font-size:18px;color:rgba(255,255,255,.85);margin:0}
.property-price-lg{font-family:var(--serif);font-size:42px;color:var(--gold);margin-top:14px}
.single-grid{display:grid;grid-template-columns:2fr 1fr;gap:48px}
@media (max-width:960px){.single-grid{grid-template-columns:1fr}}
.property-stats{list-style:none;padding:24px;margin:0 0 32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:20px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius)}
.property-stats li{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}
.property-stats strong{font-family:var(--serif);font-size:28px;color:var(--gold)}
.property-stats span{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.property-section{margin-bottom:40px}
.property-section h2{font-size:28px;margin:0 0 16px}
.amenities-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;color:var(--muted)}
.property-map{height:380px;border-radius:var(--radius);background:linear-gradient(135deg,#e9eef7,#cfd6e3);display:flex;align-items:center;justify-content:center;color:var(--muted)}
.video-wrap iframe{width:100%;aspect-ratio:16/9;border:0;border-radius:var(--radius)}
.mortgage-card{margin-top:24px}
.mortgage-calc{display:grid;gap:14px}
.mortgage-calc label{display:grid;gap:6px;font-size:13px;color:var(--muted)}
.mortgage-calc input{padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--fg)}
.mortgage-result{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--line)}
.mortgage-result strong{font-family:var(--serif);font-size:24px;color:var(--gold)}

/* Archive */
.archive-hero{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;padding:96px 0 64px;text-align:center}
.archive-hero .page-title{font-size:clamp(36px,5vw,60px);color:#fff;margin:0 0 12px}
.archive-grid{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start}
@media (max-width:960px){.archive-grid{grid-template-columns:1fr}}
.archive-filters{padding:24px;position:sticky;top:100px}
.archive-filters label{display:grid;gap:6px;font-size:13px;margin-bottom:14px;color:var(--muted)}
.archive-filters input,.archive-filters select{padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--fg)}
.filter-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.filter-title{font-size:18px;margin:0 0 16px}

/* Posts */
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:32px}
.post-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.post-thumb img{aspect-ratio:16/10;object-fit:cover;width:100%}
.post-body{padding:22px}
.post-title{font-size:22px;margin:0 0 8px}
.post-meta{font-size:13px;color:var(--muted);margin-bottom:8px}
.page-header{text-align:center;margin-bottom:48px}
.page-title{font-size:clamp(32px,4vw,48px);margin:0}

/* Footer */
.site-footer{background:var(--navy);color:rgba(255,255,255,.85);padding:80px 0 32px;margin-top:80px;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.footer-grid{grid-template-columns:1fr}}
.footer-logo{font-family:var(--serif);font-size:28px;color:#fff;margin:0 0 14px}
.footer-contact{font-style:normal;display:grid;gap:6px;color:rgba(255,255,255,.7);font-size:14px}
.footer-col .widget-title{font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer-links{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:14px}
.footer-links a{color:rgba(255,255,255,.75)}
.footer-links a:hover{color:var(--gold)}
.footer-bottom{padding-top:32px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px;color:rgba(255,255,255,.6)}

/* Floating WhatsApp */
.floating-wa{
  position:fixed;right:24px;bottom:24px;z-index:60;
  width:60px;height:60px;border-radius:50%;
  background:#25d366;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 12px 28px rgba(37,211,102,.45);
  transition:transform .25s var(--ease);
}
.floating-wa:hover{transform:scale(1.1);color:#fff}

/* Reveal animation */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
[data-reveal].is-visible{opacity:1;transform:none}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;transition-duration:.001ms !important}
  .hero-bg{animation:none}
}

/* 404 */
.error-404{text-align:center;padding:120px 24px}
.error-404 .display{font-family:var(--serif);font-size:160px;color:var(--gold);margin:0;line-height:1}
.error-404 h2{font-size:24px;margin:0 0 32px}

/* Pagination */
.pagination, .navigation.pagination{display:flex;justify-content:center;gap:8px;margin-top:48px}
.page-numbers{padding:10px 16px;border:1px solid var(--line);border-radius:10px;color:var(--fg);font-size:14px}
.page-numbers.current,.page-numbers:hover{background:var(--gold);color:#10131f;border-color:var(--gold)}
