/*
Theme Name: Luxe Realty
Theme URI: https://example.com/luxe-realty
Author: Your Name
Author URI: https://example.com
Description: A luxury real-estate WordPress theme with a full-screen video hero, slim logo rail, slide-out navigation, and pre-built page templates for Properties, Communities, Buyers & Sellers, About, and Contact. Built to be fully customizable from the WordPress Customizer.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: luxe-realty
Tags: real-estate, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, full-width-template, custom-header, video
*/

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter','Helvetica Neue',Arial,sans-serif;color:#1a1a1a;background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:opacity .2s ease}
a:hover{opacity:.75}
h1,h2,h3,h4{font-family:'Playfair Display','Times New Roman',serif;font-weight:400;letter-spacing:.02em;margin:0 0 .6em}
h1{font-size:clamp(2.4rem,5vw,4.4rem);line-height:1.1}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem)}
h3{font-size:1.4rem}
p{margin:0 0 1em}
.container{max-width:1280px;margin:0 auto;padding:0 24px}

/* ---------- Theme palette ---------- */
:root{
  --color-bg:#ffffff;
  --color-ink:#1a1a1a;
  --color-muted:#6b6b6b;
  --color-line:#e6e2dc;
  --color-accent:#b39867;
  --color-dark:#0e0e0e;
}

/* ---------- Logo rail (top-left) ---------- */
.site-rail{position:fixed;top:0;left:0;width:130px;height:130px;background:var(--color-dark);color:#fff;z-index:90;display:flex;align-items:center;justify-content:center;padding:18px;text-align:center}
.site-rail .custom-logo,.site-rail img{max-width:100%;max-height:100%;width:auto;height:auto}
.site-rail .site-title-text{font-family:'Playfair Display',serif;font-size:1.4rem;letter-spacing:.15em;color:#fff}
.site-rail .site-title-text small{display:block;font-size:.55rem;letter-spacing:.3em;color:var(--color-accent);margin-top:6px;font-family:'Inter',sans-serif}

/* ---------- Menu toggle ---------- */
.menu-toggle{position:fixed;top:130px;left:0;width:130px;height:90px;background:#1a1a1a;color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:90;transition:background .25s ease}
.menu-toggle:hover{background:var(--color-accent)}
.menu-toggle .bars{display:inline-block;width:28px;height:2px;background:#fff;position:relative}
.menu-toggle .bars::before,.menu-toggle .bars::after{content:"";position:absolute;left:0;width:28px;height:2px;background:#fff;transition:transform .3s ease}
.menu-toggle .bars::before{top:-8px}
.menu-toggle .bars::after{top:8px}
body.menu-open .menu-toggle .bars{background:transparent}
body.menu-open .menu-toggle .bars::before{transform:translateY(8px) rotate(45deg)}
body.menu-open .menu-toggle .bars::after{transform:translateY(-8px) rotate(-45deg)}

/* ---------- Slide-out nav ---------- */
.site-nav{position:fixed;top:0;left:-420px;width:380px;max-width:90vw;height:100vh;background:#0e0e0e;color:#fff;padding:160px 48px 40px;z-index:80;overflow-y:auto;transition:left .4s cubic-bezier(.6,.05,.28,.91)}
body.menu-open .site-nav{left:0}
.site-nav ul{list-style:none;padding:0;margin:0}
.site-nav li{margin:0 0 14px}
.site-nav a{display:block;font-family:'Playfair Display',serif;font-size:1.4rem;padding:6px 0;border-bottom:1px solid #1f1f1f;color:#fff}
.site-nav a:hover{color:var(--color-accent);opacity:1}
.site-nav .sub-menu{margin:8px 0 16px 16px}
.site-nav .sub-menu a{font-family:'Inter',sans-serif;font-size:.95rem;letter-spacing:.05em;color:#bdbdbd;border:0;padding:4px 0}
.nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .3s;z-index:70}
body.menu-open .nav-overlay{opacity:1;pointer-events:auto}

/* ---------- Top contact bar ---------- */
.top-bar{position:fixed;top:24px;right:24px;z-index:85;display:flex;gap:24px;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.top-bar a:hover{color:var(--color-accent);opacity:1}

/* ---------- Hero video ---------- */
.hero{position:relative;height:100vh;min-height:680px;overflow:hidden;background:#000}
.hero video,.hero .hero-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.45) 100%)}
.hero-content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:0 0 0 200px;color:#fff;max-width:900px}
.hero-content .eyebrow{font-size:.75rem;letter-spacing:.4em;text-transform:uppercase;color:var(--color-accent);margin-bottom:18px}
.hero-content h1{color:#fff;margin-bottom:22px}
.hero-content p{font-size:1.1rem;max-width:560px;margin-bottom:32px;color:rgba(255,255,255,.9)}
.btn{display:inline-block;padding:14px 34px;background:transparent;border:1px solid #fff;color:#fff;font-size:.8rem;letter-spacing:.25em;text-transform:uppercase;transition:all .25s ease;cursor:pointer}
.btn:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff;opacity:1}
.btn-dark{border-color:var(--color-ink);color:var(--color-ink)}
.btn-dark:hover{background:var(--color-ink);color:#fff}

/* ---------- Sections ---------- */
section.block{padding:120px 0}
.block .section-eyebrow{font-size:.75rem;letter-spacing:.4em;text-transform:uppercase;color:var(--color-accent);margin-bottom:14px}
.block .section-title{margin-bottom:24px}
.block .section-intro{max-width:680px;color:var(--color-muted);margin-bottom:48px}
.block.alt{background:#f7f5f1}
.block.dark{background:var(--color-dark);color:#fff}
.block.dark .section-title{color:#fff}
.block.dark .section-intro{color:rgba(255,255,255,.7)}

/* ---------- Featured properties grid ---------- */
.property-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px}
.property-card{background:#fff;border:1px solid var(--color-line);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}
.property-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(0,0,0,.2)}
.property-card .thumb{aspect-ratio:4/3;background:#eee;background-size:cover;background-position:center}
.property-card .body{padding:24px}
.property-card .price{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--color-ink);margin-bottom:8px}
.property-card .addr{color:var(--color-muted);font-size:.95rem;margin-bottom:16px}
.property-card .meta{display:flex;gap:18px;font-size:.8rem;color:var(--color-muted);text-transform:uppercase;letter-spacing:.1em;border-top:1px solid var(--color-line);padding-top:14px}

/* ---------- Two-column about ---------- */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-split .img{aspect-ratio:4/5;background:#ddd;background-size:cover;background-position:center}
@media(max-width:880px){.about-split{grid-template-columns:1fr;gap:40px}}

/* ---------- CTA strip ---------- */
.cta-strip{padding:80px 0;text-align:center;background:var(--color-dark);color:#fff}
.cta-strip h2{color:#fff;margin-bottom:16px}
.cta-strip p{color:rgba(255,255,255,.75);max-width:560px;margin:0 auto 28px}

/* ---------- Footer ---------- */
.site-footer{background:#0e0e0e;color:#bdbdbd;padding:80px 0 32px;font-size:.9rem}
.site-footer h4{color:#fff;font-family:'Inter',sans-serif;font-size:.8rem;letter-spacing:.25em;text-transform:uppercase;margin-bottom:20px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:10px}
.footer-bottom{border-top:1px solid #1f1f1f;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.8rem;color:#666}

/* ---------- Page content ---------- */
.page-hero{padding:200px 0 80px;background:#f7f5f1;text-align:center}
.page-content{padding:80px 0;max-width:820px;margin:0 auto}
.page-content h2,.page-content h3{margin-top:1.5em}

/* ---------- Contact form ---------- */
.contact-form{display:grid;gap:18px;max-width:640px}
.contact-form input,.contact-form textarea{width:100%;padding:14px 16px;border:1px solid var(--color-line);background:#fff;font-family:inherit;font-size:1rem}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--color-accent)}

/* ---------- Responsive ---------- */
@media(max-width:780px){
  .site-rail{width:90px;height:90px;padding:12px}
  .menu-toggle{top:90px;width:90px;height:70px}
  .top-bar{top:14px;right:14px;gap:14px;font-size:.7rem}
  .hero-content{padding:0 24px;align-items:center;text-align:center}
  section.block{padding:80px 0}
}
