/* mauroleitao.com — main.css */

/* Self-hosted fonts — Playfair Display (headings) + Outfit (body) */
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:400 700;font-display:swap;src:url('/fonts/playfair-display-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:400 700;font-display:swap;src:url('/fonts/playfair-display-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Outfit';font-style:normal;font-weight:400 600;font-display:swap;src:url('/fonts/outfit-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Outfit';font-style:normal;font-weight:400 600;font-display:swap;src:url('/fonts/outfit-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Outfit,system-ui,sans-serif;color:#1B263B;background:#F8F9FA;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:#1B263B}
a:hover{color:#C2A878}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;line-height:1.25;margin:0 0 .75rem;color:#1B263B}
p{margin:0 0 1rem}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.narrow-container{max-width:760px}
.skip-link{position:absolute;left:-9999px}.skip-link:focus{left:1rem;top:1rem;z-index:9999;background:#fff;padding:.5rem 1rem}

/* Header */
.site-header{background:#1B263B;color:#fff;padding:.75rem 0}
.header-inner{display:flex;align-items:center;gap:1rem;justify-content:space-between}
.site-logo{color:#C2A878;text-decoration:none}
.logo-name{display:block;font-weight:700;font-size:2rem;letter-spacing:.01em}
.logo-ami{display:block;font-size:.75rem;opacity:.7}
.main-nav .nav-list{display:flex;list-style:none;margin:0;padding:0;gap:1.25rem}
.nav-link{color:#fff;text-decoration:none;font-size:.9rem}
.nav-link.is-active,.nav-link:hover{color:#C2A878}
.header-actions{display:flex;align-items:center;gap:.75rem}
.lang-switcher{display:flex;gap:.5rem}
.lang-option{color:#C2A878;text-decoration:none;font-size:.8rem}
.lang-option--current{color:#fff}
.nav-dropdown-btn{background:none;border:none;color:#fff;cursor:pointer;font:inherit;display:flex;align-items:center;gap:.3rem}
.nav-dropdown{display:none;list-style:none;padding:.5rem 0;margin:0}
.nav-item--has-dropdown{position:relative}
.nav-item--has-dropdown:hover .nav-dropdown,
.nav-item--has-dropdown:focus-within .nav-dropdown{display:block;position:absolute;background:#243552;color:#fff;min-width:200px;box-shadow:0 8px 24px rgba(0,0,0,.3);border-radius:4px;border-top:2px solid #C2A878;top:100%;left:0;z-index:100}
.nav-dropdown-link{display:block;padding:.6rem 1.1rem;color:#fff;text-decoration:none;font-size:.9rem}
.nav-dropdown-link:hover{background:#1B263B;color:#C2A878}
.nav-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer}

/* Buttons */
.btn{display:inline-block;padding:.65rem 1.4rem;border-radius:4px;text-decoration:none;cursor:pointer;border:1px solid transparent;font-family:inherit;font-size:.95rem;font-weight:600;transition:background .2s,color .2s,border-color .2s}
.btn--primary{background:#C2A878;color:#1B263B;border-color:#C2A878}
.btn--primary:hover{background:#b2976a;border-color:#b2976a;color:#1B263B}
.btn--ghost{background:transparent;border-color:currentColor;color:#1B263B}
.btn--ghost:hover{background:#1B263B;color:#fff}
.btn--sm{font-size:.85rem;padding:.4rem 1rem}
.btn--lg{font-size:1.1rem;padding:.85rem 2rem}
.btn--full{width:100%;text-align:center}

/* Section scaffolding */
.section{padding:4rem 0}
.section--muted{background:#F3F0EB}
.section-header{margin-bottom:2.5rem}
.section-header--centered{text-align:center}
.section-eyebrow{display:block;color:#C2A878;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:600;margin-bottom:.5rem}
.section-heading{font-size:2rem;margin:0 0 .75rem}
.section-subheading{color:#5C6B7A;max-width:640px;margin:0 auto}
.section-lead{font-size:1.15rem;color:#3a4a5a}
.section-empty{color:#5C6B7A;font-style:italic;text-align:center;padding:2rem 0}
.page-heading{font-size:2rem;margin:0 0 1rem}

/* Page hero (inner pages) */
.page-hero{background:#1B263B;color:#fff;padding:5rem 0 4rem}
.page-hero h1,.page-hero-heading{color:#fff;font-size:2.5rem;margin:0 0 .75rem}
.page-hero-eyebrow{display:block;color:#C2A878;text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;font-weight:600;margin-bottom:.75rem}
.page-hero-subheading{font-size:1.1rem;opacity:.85;max-width:720px;margin:0}

/* Home hero */
.home-hero{position:relative;background:#1B263B;color:#fff;padding:6rem 0 5rem;overflow:hidden}
.home-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center top;opacity:.55;z-index:0}
.home-hero .container{position:relative;z-index:1}
.home-hero-eyebrow{display:block;color:#C2A878;text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;font-weight:600;margin-bottom:1rem}
.home-hero-title{font-size:3rem;color:#fff;margin:0 0 1rem;max-width:20ch}
.home-hero-subtitle{font-size:1.15rem;opacity:.85;max-width:60ch;margin:0 0 2rem}
.home-hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.home-hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:2rem;margin:0;padding-top:2rem;border-top:1px solid rgba(255,255,255,.15);max-width:720px}
.home-hero-stats div{text-align:left}
.home-hero-stats dt{color:#C2A878;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.35rem}
.home-hero-stats dd{margin:0;font-size:1.5rem;font-weight:700;font-family:'Playfair Display',Georgia,serif}

/* Home services grid */
.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.service-card{background:#fff;padding:2rem;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06);transition:transform .2s,box-shadow .2s}
.service-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(27,38,59,.1)}
.service-card-icon{width:56px;height:56px;background:#F3F0EB;color:#C2A878;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.service-card-title{font-size:1.25rem;margin:0 0 .75rem}
.service-card-body{color:#5C6B7A;margin:0 0 1rem}
.service-card-link{color:#C2A878;text-decoration:none;font-weight:600;font-size:.9rem}
.service-card-link:hover{color:#b2976a}

/* Home about teaser */
.about-teaser{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.about-teaser-image img{border-radius:6px}
.about-teaser-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.about-teaser-media{border-radius:6px;overflow:hidden;max-height:480px}
.about-teaser-media img{width:100%;height:100%;max-height:480px;object-fit:cover;object-position:center top;border-radius:6px;display:block}
.about-teaser-eyebrow{display:block;color:#C2A878;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:600;margin-bottom:.5rem}

/* Facts bar */
.facts-bar{background:#1B263B;color:#fff;padding:2.5rem 0}
.facts-bar-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center}
.facts-bar-item{display:flex;flex-direction:column;gap:.3rem}
.facts-bar-value{font-family:'Playfair Display',Georgia,serif;font-size:2.5rem;font-weight:700;color:#C2A878;line-height:1}
.facts-bar-label{font-size:.9rem;opacity:.8;max-width:20ch;margin:0 auto}
@media(max-width:640px){.facts-bar-inner{grid-template-columns:1fr;gap:1.5rem}.facts-bar-value{font-size:2rem}}

/* Seller CTA (prominent) */
.btn--seller{background:#C2A878;color:#1B263B;border:2px solid #C2A878;font-weight:700;letter-spacing:.02em;text-transform:uppercase;font-size:.95rem}
.btn--seller:hover{background:#b2976a;border-color:#b2976a;color:#fff}
.section--seller-cta{background:linear-gradient(135deg,#C2A878 0%,#b2976a 100%);padding:3.5rem 0;color:#1B263B}
.seller-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.seller-cta-heading{font-size:1.6rem;font-weight:700;margin:0 0 .5rem;font-family:'Playfair Display',Georgia,serif}
.seller-cta-text p{margin:0;max-width:55ch;font-size:1rem;opacity:.85}
.section--seller-cta .btn--seller{background:#1B263B;color:#fff;border-color:#1B263B;font-size:1rem;padding:.75rem 2rem}
.section--seller-cta .btn--seller:hover{background:#2D3A52;border-color:#2D3A52}
.section--seller-cta-bottom{background:linear-gradient(135deg,#1B263B 0%,#2D3A52 100%);color:#fff}
.section--seller-cta-bottom .seller-cta-heading{color:#C2A878}
.section--seller-cta-bottom .seller-cta-text p{color:rgba(255,255,255,.8)}
.section--seller-cta-bottom .btn--seller{background:#C2A878;color:#1B263B;border-color:#C2A878}
.section--seller-cta-bottom .btn--seller:hover{background:#b2976a;border-color:#b2976a}
@media(max-width:640px){.seller-cta-inner{flex-direction:column;text-align:center}.seller-cta-heading{font-size:1.3rem}}

/* Market context (property detail) */
.market-context{background:#F3F0EB;border:1px solid #e5e2db;border-radius:6px;padding:1.25rem 1.5rem;margin-top:2rem}
.market-context-heading{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:#1B263B}
.market-context-row{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap;font-size:.95rem}
.market-context-avg{font-weight:700;color:#C2A878;font-size:1.1rem}
.market-context-position{font-size:.88rem;color:#6B7280;margin-top:.5rem}

/* Home final CTA */
.section--cta{background:#1B263B;color:#fff;padding:5rem 0;text-align:center}
.section--cta h2{color:#fff}
.section--cta p{max-width:640px;margin:0 auto 2rem;opacity:.85}
.section--cta .btn--ghost{color:#fff;border-color:#fff}
.section--cta .btn--ghost:hover{background:#fff;color:#1B263B}

/* Property grid + card */
.property-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.75rem}
.property-card{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 2px 8px rgba(27,38,59,.06);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.property-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(27,38,59,.1)}
.property-card-media{position:relative;display:block;aspect-ratio:4/3;background:#E9ECEF;overflow:hidden}
.property-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.property-card:hover .property-card-media img{transform:scale(1.05)}
.property-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#C2A878;background:#F3F0EB}
.property-card-status{position:absolute;top:.75rem;left:.75rem;background:#1B263B;color:#fff;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:.3rem .6rem;border-radius:3px;font-weight:600}
.property-card-status--reserved{background:#c8881b}
.property-card-status--sold{background:#6c757d}
.property-card-body{padding:1.25rem;display:flex;flex-direction:column;flex:1}
.property-card-type{color:#5C6B7A;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}
.property-card-title{font-size:1.1rem;margin:0 0 .5rem}
.property-card-title a{text-decoration:none;color:#1B263B}
.property-card-title a:hover{color:#C2A878}
.property-card-location{color:#5C6B7A;font-size:.85rem;margin:0 0 .75rem}
.property-card-facts{list-style:none;margin:0 0 1rem;padding:0;display:flex;gap:1rem;font-size:.8rem;color:#5C6B7A}
.property-card-facts li{display:flex;align-items:center;gap:.25rem}
.property-card-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-top:.75rem;border-top:1px solid #F3F0EB}
.property-card-price{font-weight:700;color:#1B263B;font-size:1.05rem;font-family:'Playfair Display',Georgia,serif}
.property-card-link{color:#C2A878;text-decoration:none;font-size:.85rem;font-weight:600}

/* Featured section */
.section--featured .section-header{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:2rem}
.section--featured .section-header .section-heading{margin:0}
.section--featured .section-header-link{color:#C2A878;text-decoration:none;font-weight:600;font-size:.9rem;white-space:nowrap}

/* Listing (properties) */
.listing-layout{display:grid;grid-template-columns:280px 1fr;gap:2.5rem;align-items:start}
.listing-filters{background:#fff;padding:1.5rem;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06);position:sticky;top:1rem}
.filter-form h2{font-size:1rem;text-transform:uppercase;letter-spacing:.06em;color:#1B263B;margin:0 0 1rem}
.filter-form .field{margin-bottom:1rem}
.filter-form label{display:block;font-size:.8rem;color:#5C6B7A;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem;font-weight:600}
.filter-form select,.filter-form input{width:100%;padding:.55rem .75rem;border:1px solid #D4DBE2;border-radius:4px;background:#fff;font:inherit;color:#1B263B}
.filter-form select:focus,.filter-form input:focus{outline:none;border-color:#C2A878;box-shadow:0 0 0 3px rgba(194,168,120,.15)}
.filter-form .field-row,.filter-form .filter-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.filter-form-actions,.filter-actions{display:flex;gap:.5rem;flex-direction:column;margin-top:1rem}
.filter-reset{color:#5C6B7A;text-decoration:none;font-size:.85rem;text-align:center;padding:.3rem}
.filter-reset:hover{color:#C2A878}
.filter-heading{font-size:1rem;text-transform:uppercase;letter-spacing:.06em;color:#1B263B;margin:0 0 1rem}
.btn--outline{background:transparent;border:1px solid #C2A878;color:#C2A878}
.btn--outline:hover{background:#C2A878;color:#1B263B}
.btn--md{font-size:.95rem;padding:.6rem 1.4rem}
.listing-empty svg{margin:0 auto 1rem;display:block;color:#C2A878;opacity:.6}
.property-fact{display:flex;flex-direction:column}
.property-facts-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.25rem;margin:0;list-style:none;padding:0}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.property-gallery{display:grid;grid-template-columns:2fr 1fr;gap:.5rem}
.property-gallery-main{display:block;aspect-ratio:4/3;background:#E9ECEF;border-radius:6px;overflow:hidden}
.property-gallery-main img{width:100%;height:100%;object-fit:cover;cursor:zoom-in}
.property-gallery-thumbs{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;align-content:start}
.property-gallery-thumb{position:relative;display:block;aspect-ratio:1;background:#E9ECEF;border-radius:4px;overflow:hidden}
.property-gallery-thumb img{width:100%;height:100%;object-fit:cover;cursor:zoom-in}
.property-gallery-more{position:absolute;inset:0;background:rgba(27,38,59,.6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem}
.listing-results{min-width:0}
.listing-results-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.listing-results-count{color:#5C6B7A;font-size:.95rem;margin:0}
.listing-empty{background:#fff;padding:3rem 2rem;text-align:center;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06)}
.listing-empty p{color:#5C6B7A;margin:0 0 1.25rem}
.property-grid--listing{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}

/* Property detail */
.property-detail{padding:3rem 0 4rem}
.breadcrumbs{font-size:.85rem;color:#5C6B7A;margin-bottom:1.5rem}
.breadcrumbs ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}
.breadcrumbs li:not(:last-child)::after{content:'›';margin-left:.5rem;color:#C2A878}
.breadcrumbs a{color:#5C6B7A;text-decoration:none}
.breadcrumbs a:hover{color:#C2A878}
.breadcrumbs [aria-current]{color:#1B263B;font-weight:600}
.property-detail-title-row{margin-bottom:2rem}
.property-detail-meta{color:#5C6B7A;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}
.property-detail-title{font-size:2.25rem;margin:0 0 .75rem}
.property-detail-ref{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.property-detail-ref-code{color:#5C6B7A;font-size:.85rem}
.property-detail-status-badge{background:#1B263B;color:#fff;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;padding:.3rem .7rem;border-radius:3px;font-weight:600}
.property-detail-price{font-size:1.75rem;font-weight:700;color:#1B263B;font-family:'Playfair Display',Georgia,serif}

.property-gallery{margin-bottom:2.5rem}
.property-gallery-main{aspect-ratio:16/9;background:#E9ECEF;border-radius:6px;overflow:hidden;position:relative}
.property-gallery-main img{width:100%;height:100%;object-fit:cover;cursor:none}
/* Custom "Ver" cursor circle — CSS only */
.property-gallery-main::after{content:attr(data-cursor-label);position:absolute;pointer-events:none;width:60px;height:60px;border-radius:50%;background:rgba(194,168,120,.92);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;justify-content:center;opacity:0;transform:translate(-50%,-50%) scale(.6);transition:opacity .2s,transform .2s;top:50%;left:50%;z-index:5}
.property-gallery-main:hover::after{opacity:1;transform:translate(-50%,-50%) scale(1)}
.property-gallery-thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem;margin-top:.5rem}
.property-gallery-thumbs button{padding:0;border:none;background:none;cursor:pointer;aspect-ratio:1;border-radius:4px;overflow:hidden}
.property-gallery-thumbs img{width:100%;height:100%;object-fit:cover}
.property-gallery-thumbs button.is-active{outline:2px solid #C2A878;outline-offset:2px}

.property-detail-grid{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start}
.property-detail-main>*+*{margin-top:2.5rem}
.property-facts{background:#fff;padding:1.5rem;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06)}
.property-facts dl{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.25rem;margin:0}
.property-facts dt{font-size:.75rem;color:#5C6B7A;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}
.property-facts dd{margin:0;font-size:1.05rem;font-weight:600;color:#1B263B}
.property-description h2{font-size:1.35rem;margin-bottom:1rem}
.property-description p{color:#3a4a5a}
.property-features h2{font-size:1.35rem;margin-bottom:1rem}
.property-features-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem .75rem}
.property-features-list li{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#3a4a5a}
.property-features-list svg{color:#C2A878;flex-shrink:0}
.property-video{background:#F3F0EB;padding:2rem;border-radius:6px;text-align:center;color:#5C6B7A}
.property-video button{margin-top:1rem}
/* Video facade placeholder */
.video-placeholder{position:relative;aspect-ratio:16/9;background:#1B263B;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;cursor:pointer}
.video-placeholder.video-loaded{padding:0}
.video-placeholder.video-loaded iframe{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:6px}
.video-play-btn{background:none;border:none;cursor:pointer;color:#C2A878;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem}
.video-play-btn svg{transition:transform .2s}
.video-play-btn:hover svg{transform:scale(1.1)}
.video-play-btn span{font-size:.85rem;font-weight:600;letter-spacing:.04em;color:#fff}
.video-consent{font-size:.75rem;color:rgba(255,255,255,.5);max-width:28ch;margin:0 auto;line-height:1.4}
/* Property detail — no image gallery placeholder */
.property-gallery-empty{background:#F3F0EB;aspect-ratio:16/7;display:flex;align-items:center;justify-content:center;border-radius:4px;margin-bottom:2rem}
.property-gallery-empty img{width:180px;height:auto;opacity:.6}
.property-location h2{font-size:1.35rem;margin-bottom:1rem}
.property-location-notice{background:#F3F0EB;padding:1rem;border-radius:4px;font-size:.85rem;color:#5C6B7A}

.property-contact-card{background:#fff;padding:1.5rem;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06);position:sticky;top:1rem}
.property-contact-card h2{font-size:1.15rem;margin:0 0 .5rem}
.property-contact-card p{color:#5C6B7A;font-size:.9rem;margin-bottom:1rem}

/* Services pages (buyers/sellers/international/investors) */
.section--service-intro{padding:3rem 0 1rem}
.process-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;counter-reset:step}
.process-grid--three{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.process-step{background:#fff;padding:2rem 1.5rem;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06);position:relative}
.process-step-number{position:absolute;top:-18px;left:1.5rem;width:40px;height:40px;background:#C2A878;color:#1B263B;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Playfair Display',Georgia,serif;font-size:1.2rem}
.process-step-title{font-size:1.1rem;margin:1rem 0 .5rem}
.process-step-body{color:#5C6B7A;font-size:.9rem;margin:0}

.included-list{list-style:none;margin:1.5rem 0 0;padding:0;display:grid;gap:.75rem}
.included-list li{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;background:#fff;border-radius:4px;box-shadow:0 1px 4px rgba(27,38,59,.05)}
.included-list svg{color:#C2A878;flex-shrink:0;margin-top:.15rem}
.included-list span{color:#3a4a5a}

.flag-list{list-style:none;margin:1.5rem 0 0;padding:0;display:flex;flex-wrap:wrap;gap:.75rem}
.flag-list li{display:flex;align-items:center;gap:.5rem;background:#fff;padding:.5rem 1rem;border-radius:4px;box-shadow:0 1px 4px rgba(27,38,59,.05);font-size:.9rem}
.flag-code{display:inline-block;background:#1B263B;color:#C2A878;font-size:.7rem;font-weight:700;padding:.2rem .4rem;border-radius:2px;letter-spacing:.05em}

/* Investors market table */
.market-table-wrap{overflow-x:auto;background:#fff;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06)}
.market-table{width:100%;border-collapse:collapse;min-width:640px}
.market-table th,.market-table td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid #F3F0EB}
.market-table th{background:#F3F0EB;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#5C6B7A;font-weight:600}
.market-table tbody tr:last-child td{border-bottom:none}
.market-table tbody tr:hover{background:#fafafa}

/* About page */
.about-layout{display:grid;grid-template-columns:1fr 320px;gap:3rem;align-items:start}
.about-main h2{margin-top:2rem}
.about-main h2:first-child{margin-top:0}
.about-sidebar{background:#fff;padding:1.5rem;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06);position:sticky;top:1rem}
.about-sidebar-portrait{aspect-ratio:1;background:#F3F0EB;border-radius:6px;overflow:hidden;margin-bottom:1.25rem}
.about-sidebar-portrait img{width:100%;height:100%;object-fit:cover}
.about-portrait{border-radius:6px;overflow:hidden;margin-bottom:1.25rem;max-height:360px}
.about-portrait img{width:100%;height:100%;max-height:360px;object-fit:cover;object-position:center top;display:block}
.about-credentials{margin:0 0 1.5rem}
.about-credentials dt{font-size:.7rem;color:#5C6B7A;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem}
.about-credentials dd{margin:0 0 .75rem;font-size:.9rem;color:#1B263B;font-weight:600}
.about-sidebar-actions{display:flex;flex-direction:column;gap:.5rem}

/* Contact page */
.contact-layout{display:grid;grid-template-columns:1fr 360px;gap:3rem;align-items:start}
.contact-info-card{background:#fff;padding:1.75rem;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06)}
.contact-info-card h2{font-size:1.1rem;margin:0 0 1rem}
.contact-info-list{list-style:none;margin:0 0 1.5rem;padding:0}
.contact-info-list li{padding:.6rem 0;border-bottom:1px solid #F3F0EB;font-size:.9rem}
.contact-info-list li:last-child{border-bottom:none}
.contact-info-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#5C6B7A;margin-bottom:.15rem}
.contact-info-list a{color:#1B263B;text-decoration:none;font-weight:600}
.contact-info-list a:hover{color:#C2A878}
.contact-hours h3{font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;color:#5C6B7A;margin:0 0 .5rem}

/* Static map */
.section--map{background:#F3F0EB;padding:3rem 0 4rem}
.contact-map{background:#fff;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06);padding:1.5rem;margin-top:1.5rem;max-width:640px;margin-left:auto;margin-right:auto}
.contact-map-svg{width:100%;height:auto}
.contact-hours p{font-size:.9rem;margin:0 0 .3rem}

/* Lead form / contact-form partial */
.lead-form{background:#fff;padding:1.75rem;border-radius:6px;box-shadow:0 2px 8px rgba(27,38,59,.06)}
.lead-form .field{margin-bottom:1rem}
.lead-form label{display:block;font-size:.8rem;color:#1B263B;margin-bottom:.35rem;font-weight:600}
.lead-form .required-indicator{color:#C2A878}
.lead-form input[type=text],.lead-form input[type=email],.lead-form input[type=tel],.lead-form input[type=number],.lead-form select,.lead-form textarea{width:100%;padding:.65rem .85rem;border:1px solid #D4DBE2;border-radius:4px;background:#fff;font:inherit;color:#1B263B}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:none;border-color:#C2A878;box-shadow:0 0 0 3px rgba(194,168,120,.15)}
.lead-form textarea{min-height:120px;resize:vertical}
.lead-form .field-row,.lead-form .lead-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.lead-form .lead-form-row .field{margin-bottom:1rem}
.lead-form .field--honeypot,.lead-form-honeypot{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.lead-form .field-req{color:#C2A878}
.lead-form .field--checkbox{display:flex;align-items:flex-start;gap:.6rem;margin:1rem 0}
.lead-form .field--checkbox input{width:auto;margin-top:.2rem}
.lead-form .field--checkbox label{margin:0;font-weight:400;font-size:.85rem;color:#5C6B7A}
.lead-form .field-error{display:block;color:#b00020;font-size:.8rem;margin-top:.3rem;min-height:1em}
.lead-form-actions{margin-top:1.25rem}
.lead-form-feedback{margin-top:1rem;padding:.75rem 1rem;border-radius:4px;font-size:.9rem}
.lead-form-feedback[hidden]{display:none}
.lead-form-feedback.is-success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}
.lead-form-feedback.is-error{background:#fce4e4;color:#b00020;border:1px solid #f4b7b7}
.lead-form-feedback-inner{margin:0}
.lead-form button[aria-busy="true"]{opacity:.7;cursor:wait}
.btn-spinner{display:none}
.field-error[hidden]{display:none}

.section--cta-form{background:#F3F0EB;padding:4rem 0}
.cta-form-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:start}
.cta-form-text h2{margin-top:0}
.cta-form-text p{color:#5C6B7A}

/* Blog grid / list */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}
.blog-card{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 2px 8px rgba(27,38,59,.06);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.blog-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(27,38,59,.1)}
.blog-card-media{display:block;aspect-ratio:16/9;background:#E9ECEF;overflow:hidden}
.blog-card-media img{width:100%;height:100%;object-fit:cover}
.blog-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#C2A878;background:#F3F0EB}
.blog-card-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;flex:1}
.blog-card-date{font-size:.75rem;color:#5C6B7A;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}
.blog-card-title{font-size:1.2rem;margin:0 0 .5rem}
.blog-card-title a{color:#1B263B;text-decoration:none}
.blog-card-title a:hover{color:#C2A878}
.blog-card-excerpt{color:#5C6B7A;font-size:.9rem;margin:0 0 1rem}
.blog-card-link{margin-top:auto;color:#C2A878;text-decoration:none;font-weight:600;font-size:.85rem}

/* Blog article */
.blog-article{padding:3rem 0 0}
.blog-article-header{padding-bottom:2rem}
.blog-article-meta{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}
.blog-article-date{color:#5C6B7A;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}
.blog-article-reading-time{color:#5C6B7A;font-size:.82rem;padding:.2rem .6rem;background:#F3F0EB;border-radius:3px}
.blog-article-title{font-size:2.5rem;line-height:1.2;margin:0 0 1rem}
.blog-article-lead{font-size:1.15rem;color:#3a4a5a;margin:0}
.blog-article-cover{margin:0 0 2rem}
.blog-article-cover img{width:100%;max-height:480px;object-fit:cover;border-radius:6px}
.blog-article-body{padding:0 0 3rem}
.prose{font-size:1.05rem;line-height:1.75;color:#3a4a5a}
.prose h2{font-size:1.6rem;margin:2rem 0 1rem}
.prose h3{font-size:1.25rem;margin:1.5rem 0 .75rem}
.prose p{margin-bottom:1.25rem}
.prose ul,.prose ol{margin:0 0 1.25rem;padding-left:1.5rem}
.prose li{margin-bottom:.35rem}
.prose img{margin:1.5rem 0;border-radius:4px}
.prose blockquote{border-left:3px solid #C2A878;padding:.5rem 0 .5rem 1.25rem;margin:1.5rem 0;color:#5C6B7A;font-style:italic}
.prose a{color:#C2A878;text-decoration:underline}
.blog-article-footer{padding:0 0 3rem}

/* Footer */
.site-footer{background:#1B263B;color:#F8F9FA;padding:3rem 0 0;margin-top:0}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem}
.footer-heading{color:#C2A878;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem}
.footer-heading--spaced{margin-top:1.5rem}
.footer-brand-name{font-size:1.2rem;font-weight:700;margin:0 0 .5rem;color:#fff}
.footer-tagline,.footer-ami,.footer-areas{font-size:.85rem;opacity:.75;margin:0 0 .5rem}
.footer-nav-list,.footer-contact-list{list-style:none;margin:0;padding:0}
.footer-nav-list li,.footer-contact-list li{margin-bottom:.4rem}
.footer-nav-list a,.footer-contact-list a{color:#F8F9FA;text-decoration:none;font-size:.85rem;opacity:.8}
.footer-nav-list a:hover,.footer-contact-list a:hover{opacity:1;color:#C2A878}
.footer-contact-link{display:flex;align-items:center;gap:.5rem}
.footer-contact-icon{flex-shrink:0;opacity:.7}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:2.5rem;padding:1rem 0}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.footer-copyright{font-size:.8rem;opacity:.6;margin:0}
.footer-bottom-lang{display:flex;gap:.5rem}

/* Cookie banner */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#1B263B;color:#fff;padding:1rem 0;z-index:1000}
.cookie-banner-inner{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.cookie-banner-text{flex:1}
.cookie-banner-title{display:block;margin-bottom:.25rem;font-weight:600}
.cookie-banner-body{margin:0;font-size:.85rem;opacity:.8}
.cookie-banner-actions{display:flex;gap:.5rem}
.cookie-more-link{color:#C2A878}

/* Gallery lightbox */
.gallery-lightbox{position:fixed;inset:0;background:rgba(10,15,25,.92);display:none;align-items:center;justify-content:center;z-index:2000;padding:2rem}
.gallery-lightbox.is-open{display:flex}
.gallery-lightbox-inner{position:relative;max-width:90vw;max-height:90vh}
.gallery-lightbox-inner img{max-width:90vw;max-height:90vh;object-fit:contain;display:block}
.gallery-lightbox-close,.gallery-lightbox-prev,.gallery-lightbox-next{position:absolute;background:rgba(0,0,0,.5);color:#fff;border:none;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.gallery-lightbox-close{top:-3rem;right:0}
.gallery-lightbox-prev{left:-3.5rem;top:50%;transform:translateY(-50%)}
.gallery-lightbox-next{right:-3.5rem;top:50%;transform:translateY(-50%)}

/* Error / 404 */
.section--error{text-align:center;padding:8rem 0}
.legal-body{max-width:72ch;line-height:1.7}
.legal-page h1{margin-bottom:2rem}
.placeholder-notice{color:#888;font-style:italic}

/* Legal article page */
.section--legal{padding:3rem 0 5rem}
.legal-layout{max-width:760px}
.legal-updated{font-size:.82rem;color:#5C6B7A;margin:1rem 0 2rem;padding:.5rem 0;border-bottom:1px solid #E9ECEF}
.legal-article{line-height:1.8;color:#1B263B}
.legal-article h2{font-size:1.2rem;margin:2.5rem 0 .75rem;padding-top:.5rem;border-top:1px solid #E9ECEF;color:#1B263B}
.legal-article h2:first-child{border-top:none;margin-top:0}
.legal-article h3{font-size:1rem;font-weight:700;margin:1.5rem 0 .5rem;color:#1B263B}
.legal-article p{margin:0 0 1rem;color:#3D4B5C}
.legal-article ul,.legal-article ol{margin:0 0 1rem 1.5rem;color:#3D4B5C}
.legal-article li{margin-bottom:.4rem}
.legal-article a{color:#C2A878;text-decoration:underline}
.legal-article a:hover{color:#1B263B}
.legal-article strong{color:#1B263B;font-weight:600}
.legal-article table{width:100%;border-collapse:collapse;font-size:.88rem;margin:1.5rem 0}
.legal-article th{background:#1B263B;color:#fff;padding:.6rem .75rem;text-align:left;font-weight:600}
.legal-article td{padding:.55rem .75rem;border-bottom:1px solid #E9ECEF;vertical-align:top}
.legal-article tr:last-child td{border-bottom:none}
.legal-manage-cookies{margin-top:3rem;padding:1.5rem;background:#F3F0EB;border-radius:6px;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.legal-manage-cookies p{margin:0;flex:1;min-width:200px;font-size:.9rem;color:#5C6B7A}

/* ==========================================================================
   Scroll-reveal animation
   Elements marked [data-reveal] fade up from 20px when entering the viewport.
   IntersectionObserver in main.js adds .is-visible to trigger the transition.
   ========================================================================== */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
[data-reveal].is-visible{opacity:1;transform:none}
/* Staggered children inside a [data-reveal] parent */
[data-reveal-stagger]>*{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
[data-reveal-stagger].is-visible>*{opacity:1;transform:none}
[data-reveal-stagger].is-visible>*:nth-child(2){transition-delay:.1s}
[data-reveal-stagger].is-visible>*:nth-child(3){transition-delay:.2s}
[data-reveal-stagger].is-visible>*:nth-child(4){transition-delay:.3s}
[data-reveal-stagger].is-visible>*:nth-child(5){transition-delay:.4s}

/* Hero scroll indicator */
.home-hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.35rem;opacity:.5;animation:hero-bounce 2s ease-in-out infinite}
.home-hero-scroll-text{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:#fff}
.home-hero-scroll-chevron{color:#C2A878}
@keyframes hero-bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* Mobile sticky CTA — property detail (visible only on small screens) */
.property-sticky-cta{display:none}
@media(max-width:767px){
  .property-sticky-cta{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #E9ECEF;padding:.75rem 1rem;gap:.75rem;z-index:500;box-shadow:0 -4px 16px rgba(27,38,59,.1)}
  .property-sticky-cta .btn{flex:1;text-align:center;padding:.7rem 1rem;font-size:.9rem}
  .property-sticky-cta-phone{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1rem;background:#F3F0EB;border-radius:4px;color:#1B263B;text-decoration:none;font-weight:600;font-size:.9rem;flex:1}
  /* Add bottom padding so last content isn't hidden behind sticky bar */
  .property-detail{padding-bottom:6rem}
}

/* Related properties */
.property-related{margin-top:3rem;padding-top:3rem;border-top:1px solid #E9ECEF}
.property-related-heading{font-size:1.4rem;margin:0 0 1.5rem}

/* Blog social share */
.blog-share{padding:1.5rem 0;border-top:1px solid #E9ECEF;margin-top:2rem}
.blog-share-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#5C6B7A;font-weight:600;display:block;margin-bottom:.75rem}
.blog-share-links{display:flex;flex-wrap:wrap;gap:.5rem}
.blog-share-link{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;border-radius:4px;text-decoration:none;font-size:.82rem;font-weight:600;transition:opacity .2s}
.blog-share-link:hover{opacity:.85}
.blog-share-link--twitter{background:#000;color:#fff}
.blog-share-link--facebook{background:#1877F2;color:#fff}
.blog-share-link--linkedin{background:#0A66C2;color:#fff}
.blog-share-link--whatsapp{background:#25D366;color:#fff}
.blog-share-link--email{background:#F3F0EB;color:#1B263B;border:1px solid #D4DBE2}

/* Homepage blog teaser */
.section--blog-teaser{padding:4rem 0}
.blog-teaser-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:2rem}
.blog-card--teaser{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 2px 8px rgba(27,38,59,.06);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.blog-card--teaser:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(27,38,59,.1)}
.blog-card--teaser .blog-card-media{display:block;aspect-ratio:16/9;background:#F3F0EB;overflow:hidden}
.blog-card--teaser .blog-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.blog-card--teaser:hover .blog-card-media img{transform:scale(1.04)}
.blog-card--teaser .blog-card-body{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;flex:1}
@media(max-width:640px){.blog-teaser-grid{grid-template-columns:1fr}}

/* Related blog posts section */
.section--related-posts{padding:3rem 0 4rem;background:#F3F0EB}
.blog-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}
.blog-card--related{background:#fff}
.blog-card-desc{color:#5C6B7A;font-size:.9rem;margin:0 0 1rem}
.blog-card-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:auto;color:#C2A878;text-decoration:none;font-weight:600;font-size:.85rem}
.blog-card-link svg{flex-shrink:0;transition:transform .2s}
.blog-card-link:hover svg{transform:translateX(3px)}

/* Load More button on listing */
.listing-load-more{text-align:center;margin-top:2.5rem}
.listing-load-more[hidden]{display:none}

/* Cookie Personalizar modal */
.cookie-modal{position:fixed;inset:0;background:rgba(10,15,25,.7);z-index:2000;display:flex;align-items:flex-end;justify-content:center;padding:0}
.cookie-modal[hidden]{display:none}
.cookie-modal-panel{background:#fff;width:100%;max-width:540px;border-radius:12px 12px 0 0;padding:2rem 1.75rem;max-height:90vh;overflow-y:auto}
@media(min-width:540px){.cookie-modal-panel{border-radius:12px;margin-bottom:2rem}}
.cookie-modal-title{font-size:1.2rem;margin:0 0 .5rem}
.cookie-modal-desc{font-size:.88rem;color:#5C6B7A;margin:0 0 1.5rem}
.cookie-section{border:1px solid #E9ECEF;border-radius:6px;padding:1rem;margin-bottom:.75rem}
.cookie-section-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}
.cookie-section-title{font-size:.95rem;font-weight:600;color:#1B263B;margin:0}
.cookie-section-body{font-size:.82rem;color:#5C6B7A;margin:0}
/* Toggle switch */
.cookie-toggle{position:relative;width:44px;height:24px;flex-shrink:0}
.cookie-toggle input{opacity:0;width:0;height:0;position:absolute}
.cookie-toggle-track{display:block;width:44px;height:24px;background:#D4DBE2;border-radius:12px;cursor:pointer;transition:background .2s}
.cookie-toggle input:checked+.cookie-toggle-track{background:#1B263B}
.cookie-toggle-track::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.cookie-toggle input:checked~.cookie-toggle-track::after{transform:translateX(20px)}
.cookie-toggle-track--fixed{background:#C2A878;cursor:not-allowed}
.cookie-modal-actions{display:flex;gap:.75rem;margin-top:1.25rem;flex-wrap:wrap}
.cookie-modal-actions .btn{flex:1}
/* Footer manage-cookies link */
.footer-manage-cookies{color:#F8F9FA;text-decoration:none;font-size:.8rem;opacity:.6}
.footer-manage-cookies:hover{opacity:1;color:#C2A878}

/* Skeleton loader */
.skeleton{background:linear-gradient(90deg,#E9ECEF 25%,#F3F0EB 50%,#E9ECEF 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}
@keyframes skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-block{height:200px;background:linear-gradient(90deg,#E9ECEF 25%,#F3F0EB 50%,#E9ECEF 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px 4px 0 0}
.property-card--skeleton .property-card-media{height:220px}
.property-card--skeleton .property-card-body{gap:.75rem;padding:1rem}
.skeleton-line{height:.9rem;border-radius:3px;margin-bottom:.5rem;background:linear-gradient(90deg,#E9ECEF 25%,#F3F0EB 50%,#E9ECEF 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}
.skeleton-line--short{width:60%}
.skeleton-line--long{width:90%}
.skeleton-line--price{width:40%;height:1.3rem}

/* Responsive */
@media (max-width: 960px) {
  .home-hero-title{font-size:2.25rem}
  .home-hero{padding:4rem 0}
  .listing-layout,.about-layout,.contact-layout,.property-detail-grid,.cta-form-layout,.about-teaser,.about-teaser-grid{grid-template-columns:1fr}
  .listing-filters,.about-sidebar,.property-contact-card{position:static}
  .page-hero{padding:3.5rem 0 3rem}
  .page-hero h1,.page-hero-heading{font-size:2rem}
  .section{padding:3rem 0}
  .section--featured .section-header{flex-direction:column;align-items:flex-start}
  .gallery-lightbox-prev{left:.5rem}
  .gallery-lightbox-next{right:.5rem}
  .gallery-lightbox-close{top:.5rem;right:.5rem}
}
@media (max-width: 640px) {
  .main-nav .nav-list{display:none}
  .nav-toggle{display:flex;align-items:center;justify-content:center;padding:.4rem}
  .nav-toggle[aria-expanded="true"]+.main-nav .nav-list,
  .main-nav[data-mobile-open="true"] .nav-list{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:#1B263B;padding:1rem;z-index:10}
  .home-hero-title{font-size:1.85rem}
  .home-hero-actions{flex-direction:column;align-items:stretch}
  .home-hero-actions .btn{text-align:center}
  .filter-form .field-row{grid-template-columns:1fr}
  .property-detail-title{font-size:1.6rem}
  .blog-article-title{font-size:1.85rem}
  .property-features-list{grid-template-columns:1fr}

  /* Featured properties — horizontal scroll on mobile */
  .property-grid--featured{
    display:flex;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    gap:1rem;
    padding-bottom:.75rem;
    margin-left:-.5rem;
    margin-right:-.5rem;
    padding-left:.5rem;
    padding-right:.5rem;
  }
  .property-grid--featured .property-card{
    flex:0 0 85%;
    max-width:320px;
    scroll-snap-align:start;
  }
  /* Hide scrollbar but keep it functional */
  .property-grid--featured::-webkit-scrollbar{height:4px}
  .property-grid--featured::-webkit-scrollbar-track{background:transparent}
  .property-grid--featured::-webkit-scrollbar-thumb{background:#C2A878;border-radius:2px}
}
