/* ============================================================
   Candelaria Luxury Properties — Shared Site Stylesheet
   ============================================================ */

/* ---------- Compass Fonts ---------- */
@font-face{font-family:'Compass Serif';src:url('../fonts/CompassSerif-Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Compass Serif';src:url('../fonts/CompassSerif-Italic.ttf') format('truetype');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Compass Serif';src:url('../fonts/CompassSerif-SemiBold.ttf') format('truetype');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Compass Serif';src:url('../fonts/CompassSerif-SemiBoldItalic.ttf') format('truetype');font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:'Compass Sans';src:url('../fonts/CompassSans-Light.ttf') format('truetype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Compass Sans';src:url('../fonts/CompassSans-Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Compass Sans';src:url('../fonts/CompassSans-Medium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Compass Display';src:url('../fonts/CompassDisplay-Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Compass Display';src:url('../fonts/CompassDisplay-Italic.ttf') format('truetype');font-weight:400;font-style:italic;font-display:swap}

:root{
  --bg:#ffffff;
  --bg-alt:#ede5d6;        /* soft sandy beige */
  --bg-soft:#f6f1e8;       /* very pale sandy cream */
  --line:#d8cfbc;          /* muted taupe line */
  --text:#1a1815;          /* warm near-black */
  --text-mid:#3d3a35;      /* warm dark grey */
  --text-dim:#6e6a62;
  --text-mute:#9a958c;
  --accent:#9a8769;        /* warm sandy taupe */
  --accent-soft:#bba78a;   /* soft sandy taupe */
  --display:'Compass Display','Compass Serif',Georgia,serif;
  --serif:'Compass Serif',Georgia,serif;
  --sans:'Compass Sans',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-weight:300;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .25s ease, opacity .25s ease}
a:hover{color:var(--accent)}
.container{max-width:1280px;margin:0 auto;padding:0 32px}

.eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);font-weight:500;margin:0 0 18px}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;margin:0;color:var(--text)}
h1{font-size:clamp(46px,7vw,92px);line-height:1.02}
h2{font-size:clamp(32px,4.4vw,54px);line-height:1.08}
h3{font-size:clamp(22px,2.4vw,30px);line-height:1.25}
h4{font-size:14px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;font-family:var(--sans);color:var(--text)}
em{font-family:var(--display);font-style:italic;color:var(--accent);font-weight:400}
p{margin:0 0 1em;color:var(--text-mid)}
strong{font-weight:500;color:var(--text)}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;background:rgba(255,255,255,0);transition:background .3s ease, padding .3s ease, box-shadow .3s ease, border-color .3s ease;border-bottom:1px solid transparent}
.site-header.over-hero .nav a,.site-header.over-hero .nav-phone{color:#fff}
.site-header.over-hero .nav a:hover{color:var(--accent-soft)}
.site-header.over-hero .logo-black{display:none}
.site-header.over-hero .logo-white{display:block}
.site-header .logo-white{display:none}
.site-header.scrolled{background:rgba(255,255,255,.98);padding:12px 0;border-bottom:1px solid var(--line);box-shadow:0 1px 24px rgba(0,0,0,.04)}
.site-header.scrolled .nav a,.site-header.scrolled .nav-phone{color:var(--text-mid)}
.site-header.scrolled .logo-black{display:block}
.site-header.scrolled .logo-white{display:none}
.site-header.scrolled .btn.ghost{border-color:var(--text);color:var(--text)}

.header-inner{display:flex;align-items:center;justify-content:space-between;gap:32px}
.brand-logo{display:inline-flex;align-items:center;height:42px}
.brand-logo img{height:36px;width:auto;display:block}

.nav{display:flex;gap:22px;align-items:center;white-space:nowrap}
.nav a{font-family:var(--sans);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:400;color:var(--text-mid);white-space:nowrap}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-phone{font-family:var(--sans);font-size:12.5px;letter-spacing:.04em;color:var(--text-mid);font-weight:400;white-space:nowrap}
.btn{white-space:nowrap}

.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border:1px solid var(--accent);color:var(--accent);font-family:var(--sans);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;background:transparent;cursor:pointer;transition:all .3s ease}
.btn:hover{background:var(--accent);color:#fff}
.btn.solid{background:var(--accent);color:#fff}
.btn.solid:hover{background:#83704f;border-color:#83704f}
.btn.dark{background:var(--text);color:#fff;border-color:var(--text)}
.btn.dark:hover{background:var(--accent);border-color:var(--accent)}
.btn.ghost{border-color:#fff;color:#fff}
.btn.ghost:hover{background:#fff;color:var(--text)}

@media (max-width:1180px){.nav{display:none}.nav-phone{display:none}}

/* ---------- Hero (homepage) ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:140px 0 100px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
/* Hero overlay removed - image shows cleanly. Text legibility comes from stronger text-shadows below. */
.hero-bg::before,
.hero-bg::after{display:none}
.hero-inner{position:relative;z-index:3;color:#fff}
.hero-inner h1{color:#fff}
.hero-inner em{color:var(--accent-soft)}
.hero-locale{font-family:var(--sans);font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-soft);margin-bottom:28px}
.hero h1{max-width:15ch;margin-bottom:32px;text-shadow:0 2px 24px rgba(0,0,0,.7), 0 1px 3px rgba(0,0,0,.5)}
.hero-lede{max-width:560px;color:#fff;font-size:17px;line-height:1.65;margin-bottom:40px;text-shadow:0 1px 8px rgba(0,0,0,.7), 0 1px 2px rgba(0,0,0,.5)}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:32px;right:32px;z-index:3;font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85);display:flex;align-items:center;gap:12px}
.scroll-cue::after{content:"";display:inline-block;width:1px;height:40px;background:var(--accent-soft);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6) translateY(0)}50%{opacity:1;transform:scaleY(1) translateY(4px)}}

/* ---------- Section base ---------- */
section{padding:120px 0;position:relative}
.section-head{max-width:760px;margin-bottom:60px}
.section-head h2{margin-bottom:20px}
.section-head p{color:var(--text-dim);font-size:17.5px;line-height:1.65;max-width:60ch}

/* ---------- About (homepage) ---------- */
.about{background:var(--bg)}
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:90px;align-items:center}
.about-img{position:relative}
.about-img img{aspect-ratio:4/5;object-fit:cover;width:100%;filter:grayscale(.05)}
.about-img::before{content:"";position:absolute;inset:18px -18px -18px 18px;border:1px solid var(--accent);z-index:-1}
.about-copy p{color:var(--text-mid);font-size:17px;line-height:1.7;margin-bottom:1.2em}
.about-copy .eyebrow{margin-bottom:22px}
.about-copy h2{margin-bottom:32px}
.about-sign{font-family:var(--display);font-style:italic;font-size:26px;color:var(--accent);margin:24px 0 32px;line-height:1.2}
.about-meta{display:flex;gap:32px;flex-wrap:wrap;padding:20px 0 0;margin:32px 0 0;border-top:1px solid var(--line)}
.about-meta-item{display:flex;flex-direction:column;gap:4px}
.about-meta-name{font-family:var(--serif);font-size:18px;color:var(--text);font-weight:600}
.about-meta-role{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mute)}
@media (max-width:960px){.about-grid{grid-template-columns:1fr;gap:56px}section{padding:80px 0}}

/* ---------- Neighborhoods ---------- */
.neighborhoods{background:var(--bg-alt)}
.hood-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.hood-card{position:relative;aspect-ratio:4/5;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:32px;cursor:pointer;color:#fff}
.hood-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1), filter .5s ease}
.hood-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,0) 25%, rgba(0,0,0,.78) 100%)}
.hood-card:hover img{transform:scale(1.06)}
.hood-card-content{position:relative;z-index:1}
.hood-card-sub{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-soft);margin-bottom:10px}
.hood-card-name{font-family:var(--serif);font-size:32px;line-height:1;color:#fff;font-weight:400}
.hood-card-arrow{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#fff;opacity:.7;transform:translateX(-6px);transition:all .35s ease}
.hood-card:hover .hood-card-arrow{opacity:1;transform:translateX(0)}
@media (max-width:960px){.hood-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.hood-grid{grid-template-columns:1fr}}

/* ---------- Track Record ---------- */
.track{background:var(--bg)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:50px 0;margin:60px 0 80px}
.stat-num{font-family:var(--serif);font-size:48px;line-height:1;color:var(--text);margin-bottom:10px;font-weight:400}
.stat-num em{color:var(--accent)}
.stat-label{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:30px}}

.timeline{display:flex;flex-direction:column;gap:0;margin-bottom:80px}
.timeline-row{display:grid;grid-template-columns:140px 1fr;gap:40px;padding:26px 0;border-top:1px solid var(--line);align-items:baseline}
.timeline-row:last-child{border-bottom:1px solid var(--line)}
.timeline-year{font-family:var(--display);font-style:italic;font-size:24px;color:var(--accent)}
.timeline-body{font-size:15.5px;color:var(--text-dim);line-height:1.6;font-family:var(--sans)}
.timeline-body strong{color:var(--text);font-weight:500;display:block;margin-bottom:4px;font-family:var(--serif);font-size:18px}

.divider-rule{display:flex;align-items:center;gap:18px;margin:80px 0 40px;color:var(--accent);font-family:var(--sans);font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500}
.divider-rule::before,.divider-rule::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}

.listings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.listing{display:flex;flex-direction:column}
.listing-img{aspect-ratio:4/3;overflow:hidden;margin-bottom:20px;position:relative}
.listing-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.listing:hover .listing-img img{transform:scale(1.04)}
.listing-price{font-family:var(--serif);font-size:26px;color:var(--text);margin-bottom:8px;font-weight:500}
.listing-desc{font-family:var(--sans);font-size:14.5px;color:var(--text-dim);line-height:1.55;margin-bottom:10px}
.listing-loc{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mute)}
@media (max-width:860px){.listings-grid{grid-template-columns:1fr}}

/* ---------- Active Listings ---------- */
.active-listings{background:var(--bg-alt)}
.al-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.al-card{background:#fff;border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:border-color .3s ease, transform .3s ease, box-shadow .3s ease}
.al-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.06)}
.al-img{position:relative;aspect-ratio:16/10;overflow:hidden}
.al-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.al-card:hover .al-img img{transform:scale(1.04)}
.al-tag{position:absolute;top:18px;left:18px;padding:7px 16px;background:#fff;color:var(--accent);font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.al-body{padding:28px 30px 32px}
.al-loc{font-family:var(--sans);font-size:11px;letter-spacing:.20em;text-transform:uppercase;color:var(--text-mute);margin-bottom:10px}
.al-title{font-family:var(--serif);font-size:26px;margin-bottom:14px;color:var(--text)}
.al-price{font-family:var(--serif);font-size:22px;color:var(--accent);margin-bottom:18px;font-weight:500}
.al-specs{display:flex;gap:24px;font-family:var(--sans);font-size:13px;color:var(--text-dim);padding-top:18px;border-top:1px solid var(--line)}
.al-specs span strong{color:var(--text);font-weight:500;margin-right:4px}
@media (max-width:860px){.al-grid{grid-template-columns:1fr}}

/* ---------- Testimonials ---------- */
.testimonials{background:var(--bg)}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.test-card{background:var(--bg-soft);border:1px solid var(--line);padding:40px 36px}
.test-quote{font-family:var(--serif);font-style:italic;font-size:19px;line-height:1.55;color:var(--text);margin-bottom:24px}
.test-author{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:500}
.test-role{font-family:var(--sans);font-size:11.5px;color:var(--text-mute);margin-top:4px;letter-spacing:.08em}
@media (max-width:960px){.test-grid{grid-template-columns:1fr}}

/* ---------- CTA ---------- */
.cta{background:#0e0d0b;color:#fff;position:relative;overflow:hidden;text-align:center}
.cta::before{content:"";position:absolute;inset:0;background:url('../images/hero.jpg') center/cover no-repeat;filter:brightness(.35) saturate(.9);z-index:0}
.cta .container{position:relative;z-index:1;max-width:780px}
.cta h2{color:#fff;margin-bottom:28px}
.cta h2 em{color:var(--accent-soft)}
.cta .eyebrow{color:var(--accent-soft);margin-bottom:24px}
.cta p{color:rgba(255,255,255,.85);font-size:17px;line-height:1.65;margin-bottom:40px}
.cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------- Footer ---------- */
footer{background:#fff;padding:80px 0 32px;border-top:1px solid var(--line)}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:60px;border-bottom:1px solid var(--line)}
.foot-logo img{height:44px;width:auto;margin-bottom:24px}
.foot-tag{margin:0 0 28px;color:var(--text-dim);font-size:15px;line-height:1.6;max-width:38ch}
.foot-badges{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.foot-badge{font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-mute);padding:8px 14px;border:1px solid var(--line)}
.foot-col h5{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:0 0 22px;font-weight:500}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.foot-col li a{font-family:var(--sans);font-size:14.5px;color:var(--text-mid)}
.foot-contact p{margin:0 0 8px;font-family:var(--sans);font-size:14.5px;color:var(--text-mid);line-height:1.5}
.foot-contact strong{color:var(--text);font-weight:500;font-family:var(--serif);font-size:15px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;padding-top:32px;font-family:var(--sans);font-size:12px;color:var(--text-mute)}
.foot-bottom .social{display:flex;gap:18px}
.foot-bottom .social a{color:var(--text-mute);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.foot-bottom .social a:hover{color:var(--accent)}
@media (max-width:860px){.foot-top{grid-template-columns:1fr 1fr;gap:40px}}
@media (max-width:560px){.foot-top{grid-template-columns:1fr}}

/* ============================================================
   Community Page Styles
   ============================================================ */

/* Smaller, name-overlay hero for community pages */
.c-hero{position:relative;min-height:72vh;display:flex;flex-direction:column;justify-content:flex-end;padding:160px 0 80px;overflow:hidden;color:#fff}
.c-hero-bg{position:absolute;inset:0;z-index:0}
.c-hero-bg img{width:100%;height:100%;object-fit:cover}
.c-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.15) 35%, rgba(0,0,0,.80) 100%)}
.c-hero-inner{position:relative;z-index:1}
.c-hero .crumbs{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-soft);margin-bottom:24px}
.c-hero .crumbs a{color:rgba(255,255,255,.7)}
.c-hero .crumbs a:hover{color:#fff}
.c-hero h1{color:#fff;max-width:14ch;font-size:clamp(56px,8vw,108px);margin-bottom:20px;text-shadow:0 2px 36px rgba(0,0,0,.45)}
.c-hero .c-sub{font-family:var(--display);font-style:italic;font-size:clamp(22px,2.4vw,30px);color:var(--accent-soft);margin-bottom:14px;line-height:1.3}
.c-hero .c-meta{font-family:var(--sans);font-size:13px;letter-spacing:.06em;color:rgba(255,255,255,.85);max-width:50ch;line-height:1.6}

/* Quick facts strip */
.qfacts{background:#fff;border-bottom:1px solid var(--line)}
.qfacts-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:32px 0}
.qfact{padding:8px 24px;border-left:1px solid var(--line)}
.qfact:first-child{border-left:none;padding-left:0}
.qfact-label{font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-mute);margin-bottom:8px}
.qfact-value{font-family:var(--serif);font-size:22px;color:var(--text);line-height:1.2}
.qfact-value em{color:var(--accent);font-size:18px}
@media (max-width:860px){.qfacts-row{grid-template-columns:repeat(2,1fr);gap:24px}.qfact{padding:8px 16px}.qfact:nth-child(odd){border-left:none;padding-left:0}}

/* AEO content sections */
.aeo{background:#fff;padding:96px 0}
.aeo-grid{display:grid;grid-template-columns:1fr 320px;gap:80px;align-items:start}
.aeo-body h2{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3.4vw,40px);line-height:1.15;margin:56px 0 18px;color:var(--text);letter-spacing:-.01em}
.aeo-body h2:first-child{margin-top:0}
.aeo-body h2 em{color:var(--accent)}
.aeo-body h3{font-family:var(--serif);font-weight:500;font-size:22px;line-height:1.3;margin:36px 0 14px;color:var(--text);letter-spacing:-.005em}
.aeo-body p{font-family:var(--sans);font-size:16.5px;line-height:1.75;color:var(--text-mid);margin:0 0 18px;max-width:64ch}
.aeo-body .answer{font-family:var(--serif);font-size:21px;line-height:1.55;color:var(--text);font-weight:400;margin:0 0 28px;padding:0 0 0 20px;border-left:2px solid var(--accent);max-width:62ch}
.aeo-body ul,.aeo-body ol{padding-left:22px;margin:0 0 24px;color:var(--text-mid);font-family:var(--sans);font-size:16.5px;line-height:1.75;max-width:64ch}
.aeo-body li{margin-bottom:10px}
.aeo-body strong{color:var(--text);font-weight:500}

.aeo-aside{position:sticky;top:120px;display:flex;flex-direction:column;gap:24px}
.aside-card{background:var(--bg-alt);border:1px solid var(--line);padding:32px 28px}
.aside-card h4{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500;margin:0 0 18px}
.aside-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-family:var(--sans);font-size:14.5px;color:var(--text-mid)}
.aside-card li{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding-bottom:10px;border-bottom:1px dashed var(--line)}
.aside-card li:last-child{border-bottom:none}
.aside-card li span:last-child{color:var(--text);font-weight:500;text-align:right}

.aside-cta{background:#0e0d0b;color:#fff;padding:36px 30px}
.aside-cta h4{color:var(--accent-soft);margin-bottom:14px}
.aside-cta p{font-family:var(--serif);font-size:18px;color:#fff;line-height:1.45;margin:0 0 22px}
.aside-cta .btn{border-color:var(--accent-soft);color:var(--accent-soft);width:100%;justify-content:center}
.aside-cta .btn:hover{background:var(--accent-soft);color:#0e0d0b}

@media (max-width:960px){.aeo-grid{grid-template-columns:1fr;gap:48px}.aeo-aside{position:static}}

/* Sub-neighborhoods grid */
.subs{background:var(--bg-alt);padding:96px 0}
.subs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.sub-card{background:#fff;border:1px solid var(--line);padding:32px 30px;transition:border-color .3s ease, transform .3s ease}
.sub-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.sub-card-name{font-family:var(--serif);font-size:24px;color:var(--text);margin:0 0 8px}
.sub-card-zip{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.sub-card p{font-family:var(--sans);font-size:14.5px;line-height:1.6;color:var(--text-dim);margin:0}
@media (max-width:860px){.subs-grid{grid-template-columns:1fr}}

/* FAQ accordion */
.faq{background:#fff;padding:96px 0}
.faq-list{max-width:880px;margin:48px auto 0}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;background:none;border:none;text-align:left;cursor:pointer;
  padding:28px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--serif);font-size:20px;color:var(--text);font-weight:400;line-height:1.35;
  transition:color .25s ease;
}
.faq-q:hover{color:var(--accent)}
.faq-q::after{
  content:"+";font-family:var(--sans);font-size:24px;font-weight:300;color:var(--accent);
  flex-shrink:0;transition:transform .3s ease;
}
.faq-item.open .faq-q::after{content:"−"}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .4s ease, padding .3s ease;
  padding:0 0 0 0;font-family:var(--sans);color:var(--text-mid);font-size:16px;line-height:1.7;max-width:68ch;
}
.faq-item.open .faq-a{max-height:600px;padding:0 0 28px}
.faq-a p{margin:0 0 14px;color:var(--text-mid)}
.faq-a p:last-child{margin:0}

/* Lifestyle band */
.lifestyle{background:var(--bg);padding:96px 0;border-top:1px solid var(--line)}
.lifestyle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:40px}
.life-item{padding:28px 0}
.life-item h4{margin-bottom:14px;color:var(--accent);font-size:11px;letter-spacing:.22em}
.life-item h3{font-family:var(--serif);font-size:22px;color:var(--text);margin:0 0 12px;line-height:1.3;font-weight:500}
.life-item p{font-family:var(--sans);font-size:15px;line-height:1.65;color:var(--text-dim)}
@media (max-width:860px){.lifestyle-grid{grid-template-columns:1fr;gap:8px}}

/* ============================================================
   Blog Styles
   ============================================================ */

/* Blog landing hero (lighter, content-led) */
.blog-hero{padding:180px 0 80px;background:var(--bg);border-bottom:1px solid var(--line);text-align:center}
.blog-hero .eyebrow{margin-bottom:24px}
.blog-hero h1{font-size:clamp(56px,7vw,96px);margin:0 auto 24px;max-width:18ch}
.blog-hero p{max-width:60ch;margin:0 auto;color:var(--text-dim);font-size:18px;line-height:1.6}

.blog-cats{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin:48px auto 0;max-width:880px}
.blog-cat{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-mid);padding:10px 20px;border:1px solid var(--line);transition:all .25s ease;cursor:pointer}
.blog-cat:hover,.blog-cat.active{border-color:var(--accent);color:var(--accent)}

/* Featured post (large card) */
.blog-featured{background:#fff;padding:96px 0 32px}
.feat-card{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.feat-img{position:relative;aspect-ratio:5/4;overflow:hidden}
.feat-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.feat-card:hover .feat-img img{transform:scale(1.04)}
.feat-cat{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:18px;font-weight:500}
.feat-title{font-family:var(--serif);font-size:clamp(30px,3.6vw,46px);line-height:1.12;margin:0 0 22px;color:var(--text)}
.feat-title em{color:var(--accent)}
.feat-excerpt{font-family:var(--sans);font-size:17px;line-height:1.65;color:var(--text-mid);margin:0 0 28px;max-width:46ch}
.feat-meta{font-family:var(--sans);font-size:12px;letter-spacing:.06em;color:var(--text-mute);margin-bottom:28px}
@media (max-width:960px){.feat-card{grid-template-columns:1fr;gap:32px}}

/* Blog grid */
.blog-grid-section{background:#fff;padding:64px 0 120px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 36px}
.post-card{display:flex;flex-direction:column}
.post-card-img{aspect-ratio:4/3;overflow:hidden;margin-bottom:22px}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.post-card:hover .post-card-img img{transform:scale(1.04)}
.post-card-cat{font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;font-weight:500}
.post-card-title{font-family:var(--serif);font-size:23px;line-height:1.2;margin:0 0 12px;color:var(--text);font-weight:500}
.post-card-excerpt{font-family:var(--sans);font-size:15px;line-height:1.6;color:var(--text-dim);margin:0 0 14px}
.post-card-meta{font-family:var(--sans);font-size:11.5px;color:var(--text-mute);letter-spacing:.04em;margin-top:auto}
@media (max-width:960px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.blog-grid{grid-template-columns:1fr}}

/* ----- Article (single post) ----- */
.article-hero{position:relative;min-height:64vh;display:flex;flex-direction:column;justify-content:flex-end;padding:160px 0 70px;overflow:hidden;color:#fff}
.article-hero-bg{position:absolute;inset:0;z-index:0}
.article-hero-bg img{width:100%;height:100%;object-fit:cover}
.article-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.18) 35%, rgba(0,0,0,.82) 100%)}
.article-hero-inner{position:relative;z-index:1;max-width:880px}
.article-hero .crumbs{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-soft);margin-bottom:22px}
.article-hero .crumbs a{color:rgba(255,255,255,.7)}
.article-hero .crumbs a:hover{color:#fff}
.article-hero .a-cat{font-family:var(--sans);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent-soft);margin-bottom:18px;font-weight:500}
.article-hero h1{color:#fff;font-size:clamp(40px,5.4vw,68px);line-height:1.1;margin:0 0 24px;max-width:22ch;text-shadow:0 2px 32px rgba(0,0,0,.45)}
.article-hero .a-meta{font-family:var(--sans);font-size:13px;color:rgba(255,255,255,.85);letter-spacing:.04em;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.article-hero .a-meta span::after{content:"·";margin-left:16px;color:rgba(255,255,255,.4)}
.article-hero .a-meta span:last-child::after{content:""}

.article{background:#fff;padding:96px 0}
.article-grid{display:grid;grid-template-columns:1fr 280px;gap:80px;align-items:start;max-width:1180px;margin:0 auto}
.article-body{max-width:720px;margin:0 auto}
.article-body .lede{font-family:var(--serif);font-size:24px;line-height:1.45;color:var(--text);font-weight:400;margin:0 0 36px;padding:0 0 0 22px;border-left:3px solid var(--accent)}
.article-body h2{font-family:var(--serif);font-size:clamp(28px,3.2vw,38px);line-height:1.18;margin:56px 0 18px;font-weight:400;color:var(--text)}
.article-body h2 em{color:var(--accent)}
.article-body h3{font-family:var(--serif);font-size:22px;line-height:1.3;margin:40px 0 14px;color:var(--text);font-weight:600}
.article-body p{font-family:var(--sans);font-size:17px;line-height:1.8;color:var(--text-mid);margin:0 0 20px}
.article-body p strong{color:var(--text);font-weight:500}
.article-body ul,.article-body ol{padding-left:24px;margin:0 0 24px;color:var(--text-mid);font-family:var(--sans);font-size:17px;line-height:1.8}
.article-body li{margin-bottom:10px}
.article-body li strong{color:var(--text);font-weight:500}
.article-body blockquote{
  margin:36px 0;padding:6px 0 6px 28px;border-left:3px solid var(--accent);
  font-family:var(--display);font-style:italic;font-size:24px;line-height:1.4;color:var(--text);
}
.article-body table{width:100%;border-collapse:collapse;margin:28px 0;font-family:var(--sans);font-size:15.5px}
.article-body th,.article-body td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line)}
.article-body th{font-family:var(--sans);font-weight:500;color:var(--text);background:var(--bg-alt);letter-spacing:.02em}
.article-body td{color:var(--text-mid)}
.article-body .pullbox{
  background:var(--bg-alt);border:1px solid var(--line);padding:28px 32px;margin:32px 0;
}
.article-body .pullbox h4{margin:0 0 12px;font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500}
.article-body .pullbox p{margin:0;font-family:var(--serif);font-size:19px;line-height:1.5;color:var(--text)}

.article-aside{position:sticky;top:110px;display:flex;flex-direction:column;gap:24px}
.article-aside .aside-card h4{margin-top:0}
.article-aside .aside-author{display:flex;flex-direction:column;gap:8px;padding:24px 26px;background:var(--bg-alt);border:1px solid var(--line)}
.aside-author-eyebrow{font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500}
.aside-author-name{font-family:var(--serif);font-size:18px;color:var(--text);font-weight:600;margin-top:6px}
.aside-author-role{font-family:var(--sans);font-size:11.5px;color:var(--text-mute);letter-spacing:.06em}
.aside-author-bio{font-family:var(--sans);font-size:14px;line-height:1.6;color:var(--text-mid);margin-top:10px}

@media (max-width:960px){
  .article-grid{grid-template-columns:1fr;gap:40px}
  .article-aside{position:static;flex-direction:row;flex-wrap:wrap}
  .article-aside > *{flex:1;min-width:240px}
}

/* Related posts */
.related{background:var(--bg-alt);padding:96px 0}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
@media (max-width:960px){.related-grid{grid-template-columns:1fr;gap:24px}}

/* ============================================================
   Portfolio / Reviews Page Styles
   ============================================================ */

/* Page header (lighter than full hero) */
.page-header{padding:180px 0 80px;background:#fff;border-bottom:1px solid var(--line);text-align:center}
.page-header .eyebrow{margin-bottom:24px}
.page-header h1{font-size:clamp(56px,7vw,96px);margin:0 auto 24px;max-width:18ch}
.page-header p{max-width:62ch;margin:0 auto;color:var(--text-dim);font-size:18px;line-height:1.6}

/* Portfolio area section */
.portfolio-section{background:#fff;padding:80px 0}
.portfolio-section + .portfolio-section{border-top:1px solid var(--line)}
.portfolio-section-head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:16px;margin-bottom:40px}
.portfolio-section-head h2{font-family:var(--serif);font-size:clamp(28px,3.4vw,40px);margin:0;color:var(--text);font-weight:400}
.portfolio-section-head h2 em{color:var(--accent)}
.portfolio-section-count{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-mute);font-weight:500}

.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.port-card{display:flex;flex-direction:column;color:inherit;text-decoration:none}
.port-card-img{aspect-ratio:4/3;overflow:hidden;margin-bottom:18px;background:var(--bg-alt)}
.port-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.port-card:hover .port-card-img img{transform:scale(1.04)}
.port-card-tag{position:absolute;top:14px;left:14px;background:#fff;color:var(--accent);font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:6px 12px;font-weight:500;z-index:1}
.port-card-imgwrap{position:relative}
.port-card-price{font-family:var(--serif);font-size:24px;color:var(--text);margin-bottom:6px;font-weight:500}
.port-card-addr{font-family:var(--sans);font-size:14.5px;color:var(--text-mid);line-height:1.4;margin-bottom:8px}
.port-card-specs{font-family:var(--sans);font-size:12px;letter-spacing:.06em;color:var(--text-mute)}
.port-card-specs strong{color:var(--text);font-weight:500}
@media (max-width:960px){.port-grid{grid-template-columns:repeat(2,1fr);gap:24px}}
@media (max-width:640px){.port-grid{grid-template-columns:1fr}}

/* Reviews layout */
.reviews-section{background:#fff;padding:80px 0}
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.review-card{
  background:var(--bg-soft);border:1px solid var(--line);
  padding:40px 36px;display:flex;flex-direction:column;
}
.review-stars{color:var(--accent);font-size:16px;letter-spacing:.18em;margin-bottom:18px}
.review-quote{font-family:var(--serif);font-style:italic;font-size:19px;line-height:1.55;color:var(--text);margin:0 0 28px;flex-grow:1}
.review-author{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:500}
.review-role{font-family:var(--sans);font-size:11.5px;color:var(--text-mute);margin-top:4px;letter-spacing:.08em}
@media (max-width:760px){.reviews-grid{grid-template-columns:1fr}}

/* Stats bar (for portfolio header) */
.stats-bar{background:var(--bg-alt);padding:48px 0;border-bottom:1px solid var(--line)}
.stats-bar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stats-bar-item{text-align:center}
.stats-bar-num{font-family:var(--serif);font-size:42px;color:var(--text);line-height:1;margin-bottom:8px;font-weight:400}
.stats-bar-num em{color:var(--accent)}
.stats-bar-label{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}
@media (max-width:760px){.stats-bar-grid{grid-template-columns:repeat(2,1fr);gap:24px}}

