[data-theme="dark"]{
  --bg:#100e0c;--bg2:#171412;--bg3:#1e1b17;--surface:#252119;--surface2:#2d2923;
  --border:#3a342c;--border2:#454038;
  --gold:#f7a318;--gold-lt:#ffd256;--gold-dk:#e07810;
  --gold-a08:rgba(247,163,24,.08);--gold-a10:rgba(247,163,24,.1);--gold-a18:rgba(247,163,24,.18);--gold-a22:rgba(247,163,24,.22);--gold-a28:rgba(247,163,24,.28);--gold-a30:rgba(247,163,24,.3);--gold-a40:rgba(247,163,24,.4);--gold-a45:rgba(247,163,24,.45);--gold-a60:rgba(247,163,24,.6);
  --cream:#faf5ed;--muted:#9a9288;--muted2:#7f786f;--text:#f2ebe3;--text2:#c9bfb3;
  --red:#e4311b;--red-lt:#f06a14;--green:#27ae60;
  --shadow:0 8px 40px rgba(0,0,0,.65);
  --header-bg:rgba(16,14,12,.93);--card-foot:#171412;
  --hero-bg:linear-gradient(135deg,#120f0c 0%,#1a1510 42%,#0e0c09 100%);
  --hero-photo:url(https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=2000&q=85);
  --hero-scrim:linear-gradient(105deg,rgba(16,14,12,.94) 0%,rgba(16,14,12,.72) 38%,rgba(16,14,12,.35) 68%,rgba(16,14,12,.2) 100%),linear-gradient(to top,rgba(16,14,12,.82) 0%,transparent 42%);
  --hero-glow:radial-gradient(ellipse 70% 60% at 58% 48%,rgba(247,163,24,.09) 0%,transparent 70%);
  --scrim:rgba(0,0,0,.9);
  --gal-grad:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 55%);
}
[data-theme="light"]{
  --bg:#faf7f3;--bg2:#f3ede6;--bg3:#ebe4db;--surface:#ffffff;--surface2:#f5f0ea;
  --border:#e2dbd4;--border2:#d4cdc3;
  --gold:#e06d10;--gold-lt:#f38c00;--gold-dk:#c2410c;
  --gold-a08:rgba(224,109,16,.08);--gold-a10:rgba(224,109,16,.1);--gold-a18:rgba(224,109,16,.18);--gold-a22:rgba(224,109,16,.22);--gold-a28:rgba(224,109,16,.28);--gold-a30:rgba(224,109,16,.3);--gold-a40:rgba(224,109,16,.4);--gold-a45:rgba(224,109,16,.45);--gold-a60:rgba(224,109,16,.6);
  --cream:#1c1816;--muted:#6f757d;--muted2:#7b8188;--text:#252018;--text2:#4a453d;
  --red:#d43820;--red-lt:#f06a14;--green:#218a50;
  --shadow:0 8px 40px rgba(0,0,0,.1);
  --header-bg:rgba(250,247,243,.94);--card-foot:#f3ede6;
  --hero-bg:linear-gradient(135deg,#faf0e6 0%,#f3e8dc 45%,#faf6f0 100%);
  --hero-photo:url(https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=2000&q=85);
  --hero-scrim:linear-gradient(105deg,rgba(250,247,243,.96) 0%,rgba(250,247,243,.78) 36%,rgba(250,247,243,.48) 62%,rgba(250,247,243,.24) 100%),linear-gradient(to top,rgba(28,24,22,.52) 0%,transparent 48%);
  --hero-glow:radial-gradient(ellipse 70% 60% at 58% 48%,rgba(240,106,20,.1) 0%,transparent 70%);
  --scrim:rgba(20,16,14,.78);
  --gal-grad:linear-gradient(to top,rgba(20,16,14,.72) 0%,transparent 55%);
}
:root{--r:6px;--r-lg:12px;--t:.25s cubic-bezier(.4,0,.2,1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-weight:300;line-height:1.6;min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s}

/* GLOBAL ANIMATIONS */
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes glow{0%,100%{box-shadow:0 0 8px rgba(224,109,16,.15)}50%{box-shadow:0 0 20px rgba(224,109,16,.35)}}
@keyframes borderGlow{0%,100%{border-color:var(--gold-a28)}50%{border-color:var(--gold-a60)}}
@keyframes dotPulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}

/* Stagger delays */
.delay-1{animation-delay:.06s!important}
.delay-2{animation-delay:.12s!important}
.delay-3{animation-delay:.18s!important}
.delay-4{animation-delay:.24s!important}
.delay-5{animation-delay:.3s!important}
.delay-6{animation-delay:.36s!important}
.delay-7{animation-delay:.42s!important}
.delay-8{animation-delay:.48s!important}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;transition:background .3s}
::-webkit-scrollbar-thumb:hover{background:var(--gold-dk)}

/* HEADER */
header{position:sticky;top:0;z-index:100;background:var(--header-bg);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);padding:0 1.5rem;transition:background .3s,border-color .3s;animation:fadeInDown .6s ease both}
.header-inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:66px;gap:1.5rem}
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;line-height:0;animation:fadeInLeft .5s ease .15s both}
.logo:hover .logo-img{filter:brightness(1.08)}
.logo-img{display:block;height:clamp(28px,5vw,46px);width:auto;transition:filter .3s}
nav{display:flex;gap:.1rem;align-items:center;animation:fadeIn .5s ease .2s both}
nav a{font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:.45rem .82rem;border-radius:var(--r);transition:color var(--t),background var(--t);white-space:nowrap}
nav a:hover{color:var(--gold);background:var(--gold-a08)}
nav a.active{color:var(--gold);background:var(--gold-a08)}
.header-actions{display:flex;gap:.55rem;align-items:center;flex-shrink:0;animation:fadeInRight .5s ease .25s both}
.theme-toggle{width:36px;height:36px;border-radius:50%;background:var(--surface);border:1px solid var(--border2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:all var(--t);flex-shrink:0}
.theme-toggle:hover{border-color:var(--gold);transform:rotate(20deg) scale(1.1);box-shadow:0 0 12px var(--gold-a30)}
.btn-fav-count{display:flex;align-items:center;gap:.4rem;background:var(--surface);border:1px solid var(--border2);color:var(--text2);font-size:.78rem;padding:.4rem .82rem;border-radius:100px;cursor:pointer;transition:all var(--t);text-decoration:none;position:relative;overflow:hidden}
.btn-fav-count::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,var(--gold-a10),transparent);transform:translateX(-100%);transition:transform .5s}
.btn-fav-count:hover::before{transform:translateX(100%)}
.btn-fav-count:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-1px);box-shadow:0 4px 16px var(--gold-a15)}
.heart-icon{color:var(--red-lt);font-size:.94rem}
#fav-count-badge{background:var(--gold);color:var(--bg);font-size:.6rem;font-weight:700;font-family:'DM Mono',monospace;min-width:17px;height:17px;border-radius:100px;display:inline-flex;align-items:center;justify-content:center;padding:0 3px;transition:transform .2s}
.btn-fav-count:hover #fav-count-badge{animation:pulse .4s ease}
.mobile-menu-btn{width:36px;height:36px;border-radius:var(--r);background:var(--surface);border:1px solid var(--border2);cursor:pointer;display:none;align-items:center;justify-content:center;color:var(--text);transition:all var(--t);flex-shrink:0}
.mobile-menu-btn:hover{border-color:var(--gold);color:var(--gold)}

/* HERO */
.hero{
  border-bottom:1px solid var(--border);padding:3.5rem 2rem 3rem;position:relative;overflow:hidden;
  background:var(--hero-bg);
  transition:border-color .3s;
}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center 42%;opacity:0;transition:opacity 1.8s ease-in-out}
.hero-slide.active{opacity:1}
.hero::before{content:'';position:absolute;inset:0;background:var(--hero-scrim);pointer-events:none;z-index:1}
.hero::after{content:'';position:absolute;inset:0;background:var(--hero-glow);pointer-events:none;z-index:1}
.hero-progress{position:absolute;top:0;left:0;right:0;height:3px;z-index:3;background:rgba(255,255,255,.12)}
.hero-progress-bar{height:100%;width:0%;background:var(--gold);border-radius:0 2px 2px 0}
.hero-progress-bar.animate{animation:progressFill 13s linear forwards}
@keyframes progressFill{from{width:0%}to{width:100%}}
.hero-inner{max-width:1440px;margin:0 auto;position:relative;z-index:2}
.hero-label{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem;animation:fadeInUp .6s ease .2s both}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.6rem);font-weight:600;line-height:1.1;color:var(--cream);margin-bottom:.45rem;animation:fadeInUp .6s ease .3s both}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-sub{color:var(--muted);font-size:.92rem;max-width:460px;animation:fadeInUp .6s ease .4s both}
[data-theme="light"] .hero-sub{color:var(--text2)}
.hero-stats{display:flex;gap:2.5rem;margin-top:1.75rem}
.stat-item{display:flex;flex-direction:column;gap:.15rem;animation:fadeInUp .5s ease both}
.stat-item:nth-child(1){animation-delay:.5s}
.stat-item:nth-child(2){animation-delay:.6s}
.stat-item:nth-child(3){animation-delay:.7s}
.stat-number{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:700;color:var(--gold-lt);line-height:1;transition:transform .3s}
.stat-item:hover .stat-number{transform:scale(1.08);animation:glow 2s ease infinite}
.stat-label{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-family:'DM Mono',monospace}

/* LAYOUT */
.main-layout{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:295px 1fr}

/* SIDEBAR */
.sidebar{background:var(--bg2);border-right:1px solid var(--border);padding:1.75rem 1.4rem;position:sticky;top:66px;height:calc(100vh - 66px);overflow-y:auto;overflow-x:hidden;transition:background .3s,border-color .3s;animation:fadeInLeft .5s ease .3s both}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.sidebar-title{font-family:'Playfair Display',serif;font-size:.98rem;font-weight:600;color:var(--cream)}
.btn-clear-filters{font-size:.68rem;color:var(--muted);background:none;border:1px solid var(--border2);padding:.28rem .68rem;border-radius:100px;cursor:pointer;transition:all var(--t);font-family:'DM Sans',sans-serif}
.btn-clear-filters:hover{color:var(--gold);border-color:var(--gold-dk);transform:translateY(-1px);box-shadow:0 4px 12px var(--gold-a15)}
.filter-group{margin-bottom:1.35rem;padding-bottom:1.35rem;border-bottom:1px solid var(--border)}
.filter-group:last-child{border-bottom:none}
.filter-label{font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem;display:block}
.op-tabs{display:flex;gap:.45rem}
.op-tab{flex:1;text-align:center;padding:.48rem;cursor:pointer;border:1px solid var(--border2);border-radius:var(--r);font-size:.8rem;color:var(--muted2);transition:all var(--t);background:var(--surface);user-select:none;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:.35rem}
.op-tab svg{display:block;flex-shrink:0}
.op-tab::after{content:'';position:absolute;inset:0;background:var(--gold);opacity:0;transition:opacity .2s}
.op-tab:hover{border-color:var(--border);color:var(--text2)}
.op-tab.active{background:var(--gold);border-color:var(--gold);color:var(--bg);font-weight:500;animation:scaleIn .25s ease}
.type-chips{display:flex;flex-wrap:wrap;gap:.38rem}
.type-chip{padding:.32rem .75rem;border-radius:100px;border:1px solid var(--border2);background:var(--surface);font-size:.76rem;color:var(--muted);cursor:pointer;transition:all var(--t);user-select:none;position:relative}
.type-chip:hover{border-color:var(--border);color:var(--text2);transform:translateY(-1px)}
.type-chip.active{background:var(--gold-a10);border-color:var(--gold);color:var(--gold);animation:scaleIn .2s ease}
.rooms-row{display:flex;gap:.38rem;flex-wrap:wrap;justify-content:center;align-items:center}
.room-btn{min-width:40px;padding:.35rem .7rem;border:1px solid var(--border2);border-radius:var(--r);background:var(--surface);color:var(--muted);font-size:.8rem;cursor:pointer;transition:all var(--t);font-family:'DM Mono',monospace;text-align:center;white-space:nowrap;line-height:1.4;display:flex;align-items:center;justify-content:center}
.room-btn svg{display:block;flex-shrink:0}
.room-btn:hover{border-color:var(--border);color:var(--text2);transform:translateY(-1px)}
.room-btn.active{background:var(--gold-a10);border-color:var(--gold);color:var(--gold);animation:scaleIn .2s ease}
.price-display{display:flex;justify-content:space-between;font-family:'DM Mono',monospace;font-size:.73rem;color:var(--text2);margin-bottom:.7rem}
.price-val{color:var(--gold-lt)}
#price-slider{margin:.9rem .5rem}
.noUi-connect{background:var(--gold)!important}
.noUi-handle{background:var(--gold)!important;border:2px solid var(--bg)!important;box-shadow:0 0 0 2px var(--gold)!important;border-radius:50%!important;cursor:grab!important;width:16px!important;height:16px!important;right:-8px!important;top:-6px!important}
.noUi-handle::before,.noUi-handle::after{display:none!important}
.noUi-target{background:var(--surface2)!important;border:none!important;box-shadow:none!important;height:4px!important}
.zone-select{width:100%;background:var(--surface);border:1px solid var(--border2);color:var(--text2);font-size:.83rem;padding:.58rem .85rem;border-radius:var(--r);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%237a7468' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .85rem center;cursor:pointer;transition:border-color var(--t),box-shadow var(--t),transform var(--t);font-family:'DM Sans',sans-serif}
.zone-select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-a10)}
.zone-select:hover{transform:translateY(-1px);border-color:var(--border)}
.zone-select option{background:var(--surface);color:var(--text)}
.amenity-list{display:flex;flex-direction:column;gap:.45rem}
.amenity-item{display:flex;align-items:center;gap:.65rem;cursor:pointer;user-select:none;padding:.2rem .35rem;border-radius:var(--r);transition:background var(--t)}
.amenity-item:hover{background:var(--gold-a08)}
.amenity-item input[type="checkbox"]{display:none}
.amenity-check{width:17px;height:17px;border:1px solid var(--border2);border-radius:4px;background:var(--surface);display:flex;align-items:center;justify-content:center;transition:all var(--t);flex-shrink:0}
.amenity-item.checked .amenity-check{background:var(--gold);border-color:var(--gold);animation:scaleIn .2s ease}
.amenity-check svg{display:none;animation:scaleIn .2s ease}
.amenity-item.checked .amenity-check svg{display:block}
.amenity-text{font-size:.8rem;color:var(--muted);transition:color var(--t)}
.amenity-item:hover .amenity-text{color:var(--text2)}
.amenity-item.checked .amenity-text{color:var(--text)}

/* CONTENT */
.content-area{padding:1.75rem}
.content-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.85rem}
.results-info{display:flex;align-items:baseline;gap:.5rem}
.results-count{font-family:'Playfair Display',serif;font-size:1.45rem;font-weight:600;color:var(--cream);transition:transform .2s}
.results-count:hover{transform:scale(1.05)}
.results-label{font-size:.78rem;color:var(--muted)}
.top-right{display:flex;gap:.65rem;align-items:center;flex-wrap:wrap}
.search-bar{display:flex;align-items:center;gap:.45rem;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);padding:.48rem .85rem;min-width:200px;max-width:320px;transition:border-color var(--t),box-shadow var(--t),transform var(--t)}
.search-bar:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-a10);transform:translateY(-1px)}
.search-bar svg{color:var(--muted);flex-shrink:0;transition:color var(--t)}
.search-bar:focus-within svg{color:var(--gold)}
.search-bar input{background:none;border:none;outline:none;color:var(--text);font-size:.86rem;width:100%;font-family:'DM Sans',sans-serif}
.search-bar input::placeholder{color:var(--muted2)}
.view-controls{display:flex;gap:.35rem}
.view-btn{width:34px;height:34px;border:1px solid var(--border2);background:var(--surface);border-radius:var(--r);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all var(--t)}
.view-btn:hover{border-color:var(--border);color:var(--text2);transform:translateY(-1px)}
.view-btn.active{background:var(--gold-a10);border-color:var(--gold);color:var(--gold);animation:scaleIn .2s ease}
.sort-select{background:var(--surface);border:1px solid var(--border2);color:var(--text2);font-size:.8rem;padding:.43rem .78rem;border-radius:var(--r);cursor:pointer;font-family:'DM Sans',sans-serif;outline:none;transition:border-color var(--t),box-shadow var(--t),transform var(--t)}
.sort-select:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-a10)}
.sort-select:hover{transform:translateY(-1px);border-color:var(--border)}
.sort-select option{background:var(--surface);color:var(--text)}
.active-filters{display:flex;gap:.38rem;flex-wrap:wrap;margin-bottom:.9rem;min-height:0}
.filter-pill{display:flex;align-items:center;gap:.38rem;background:var(--gold-a08);border:1px solid var(--gold-a28);border-radius:100px;padding:.22rem .65rem;font-size:.72rem;color:var(--gold);animation:pillIn .25s cubic-bezier(.34,1.56,.64,1) both;transition:background var(--t),transform var(--t)}
.filter-pill:hover{background:var(--gold-a18);transform:translateY(-1px)}
@keyframes pillIn{from{opacity:0;transform:scale(.7) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}
.filter-pill button{background:none;border:none;cursor:pointer;color:var(--gold-dk);font-size:.88rem;line-height:1;padding:0;display:flex;align-items:center;transition:color var(--t)}
.filter-pill button:hover{color:var(--red)}

/* GRID */
#props-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:1.35rem}
#props-grid.list-view{grid-template-columns:1fr}

/* CARD */
.prop-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:transform var(--t),box-shadow var(--t),border-color var(--t);animation:cardIn .4s ease both;display:flex;flex-direction:column;position:relative}
.prop-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-lt));transform:scaleX(0);transform-origin:left;transition:transform .35s ease;z-index:5}
.prop-card:hover::before{transform:scaleX(1)}
.prop-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px var(--gold-a18);border-color:var(--gold-a22)}
[data-theme="light"] .prop-card:hover{box-shadow:0 18px 48px rgba(0,0,0,.12),0 0 0 1px var(--gold-a18)}
@keyframes cardIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.card-img-wrap{position:relative;overflow:hidden;aspect-ratio:16/10;background:var(--surface2)}
.card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94),filter .3s;display:block}
.card-img-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.15),transparent 50%);pointer-events:none;opacity:0;transition:opacity .3s}
.prop-card:hover .card-img-wrap::after{opacity:1}
.prop-card:hover .card-img-wrap img{transform:scale(1.06)}
.img-placeholder{position:absolute;inset:0;display:none;align-items:center;justify-content:center;padding:clamp(.6rem,4vw,1.25rem);background:#f7f7f7}
.img-placeholder img{width:min(78%,320px);height:auto;max-height:82%;object-fit:contain;object-position:center}
.card-badge{position:absolute;top:.7rem;left:.7rem;display:flex;gap:.38rem;flex-wrap:wrap;z-index:1}
.badge{font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:.27rem .62rem;border-radius:100px;font-weight:500;backdrop-filter:blur(10px);transition:transform .2s}
.badge:hover{transform:scale(1.05)}
.badge-op{background:rgba(10,9,8,.72);border:1px solid var(--gold-a40);color:var(--gold-lt)}
.badge-new{background:rgba(39,174,96,.15);border:1px solid rgba(39,174,96,.4);color:#2ecc71}
.badge-opp{background:rgba(192,57,43,.15);border:1px solid rgba(192,57,43,.45);color:#e74c3c}
.photo-count{background:rgba(10,9,8,.68);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-family:'DM Mono',monospace;font-size:.6rem;padding:.22rem .55rem;border-radius:100px;display:flex;align-items:center;gap:.3rem;transition:transform .2s}
.photo-count:hover{transform:scale(1.05)}
.btn-fav{position:absolute;top:.7rem;right:.7rem;width:34px;height:34px;border-radius:50%;background:rgba(10,9,8,.68);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t);z-index:2}
.btn-fav:hover{background:rgba(240,106,20,.22);border-color:rgba(240,106,20,.55);transform:scale(1.12)}
.btn-fav:active{transform:scale(.9)}
.btn-fav.active{background:rgba(192,57,43,.28);border-color:var(--red);animation:pulse .4s ease}
.btn-fav.active svg{fill:var(--red-lt);stroke:var(--red-lt)}
.card-body{padding:1rem 1rem .85rem;flex:1;display:flex;flex-direction:column}
.card-price{font-family:'Playfair Display',serif;font-size:1.22rem;font-weight:700;color:var(--gold-lt);margin-bottom:.22rem;line-height:1}
.card-price-period{font-size:.65rem;color:var(--muted);font-family:'DM Mono',monospace}
.card-title{font-size:.86rem;font-weight:500;color:var(--text);margin-bottom:.25rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-location{font-size:.75rem;color:var(--muted);display:flex;align-items:center;gap:.28rem;margin-bottom:.78rem}
.card-stats{display:flex;gap:.75rem;margin-top:auto;padding-top:.78rem;border-top:1px solid var(--border);flex-wrap:wrap}
.stat-chip{display:flex;align-items:center;gap:.28rem;font-size:.74rem;color:var(--muted2);font-family:'DM Mono',monospace}
.stat-chip svg{color:var(--muted)}
.stat-chip span{color:var(--text2)}
.card-footer{padding:.62rem 1rem;border-top:1px solid var(--border);background:var(--card-foot);display:flex;align-items:center;justify-content:space-between;transition:background var(--t)}
.prop-card:hover .card-footer{background:var(--gold-a08)}
.card-agent{display:flex;align-items:center;gap:.45rem}
.agent-avatar{width:24px;height:24px;border-radius:50%;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:600;color:var(--gold);background:var(--surface2);flex-shrink:0;transition:all .3s}
.prop-card:hover .agent-avatar{border-color:var(--gold-a40);box-shadow:0 0 8px var(--gold-a20)}
.agent-name{font-size:.7rem;color:var(--muted)}
.btn-cta{font-size:.7rem;font-weight:500;background:var(--gold-a08);border:1px solid var(--gold-a30);color:var(--gold);padding:.28rem .7rem;border-radius:var(--r);cursor:pointer;transition:all var(--t);font-family:'DM Sans',sans-serif;position:relative;overflow:hidden}
.btn-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,var(--gold-a20),transparent);transform:translateX(-100%);transition:transform .4s}
.btn-cta:hover::before{transform:translateX(100%)}
.btn-cta:hover{background:var(--gold);color:var(--bg);transform:translateY(-1px);box-shadow:0 4px 14px var(--gold-a30)}
#props-grid.list-view .prop-card{flex-direction:row;max-height:195px}
#props-grid.list-view .card-img-wrap{width:235px;flex-shrink:0;aspect-ratio:unset}
#props-grid.list-view .photo-count{display:none}

/* EMPTY */
.empty-state{grid-column:1/-1;text-align:center;padding:5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.9rem;animation:fadeIn .5s ease}
.empty-icon{font-size:2.8rem;opacity:.28;animation:float 4s ease-in-out infinite}
.empty-title{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--text2)}
.empty-text{font-size:.86rem;color:var(--muted)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;z-index:200;background:var(--scrim);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .35s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;max-width:900px;width:100%;max-height:92vh;overflow-y:auto;transform:translateY(28px) scale(.95);transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .3s;opacity:0}
.modal-overlay.open .modal-box{transform:none;opacity:1}
.modal-gallery{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--surface2);user-select:none}
.gallery-main-img{width:100%;height:100%;object-fit:cover;transition:opacity .25s;display:block;position:relative;z-index:1}
.modal-video-wrap{position:absolute;inset:0;z-index:3;background:#0a0908;display:none}
.modal-video-wrap:not([hidden]){display:block}
.modal-video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.gal-grad{position:absolute;inset:0;background:var(--gal-grad);pointer-events:none;z-index:2}
.modal-close{position:absolute;top:.85rem;right:.85rem;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.58);border:1px solid rgba(255,255,255,.18);color:#fff;font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t);z-index:4}
.modal-close:hover{background:rgba(180,30,30,.72);transform:rotate(90deg) scale(1.1)}
.gal-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.52);border:1px solid rgba(255,255,255,.18);color:#fff;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t);z-index:4;line-height:1}
.gal-btn:hover{background:var(--gold-a45);border-color:var(--gold-a60);transform:translateY(-50%) scale(1.1)}
#gal-prev{left:.85rem}
#gal-next{right:.85rem}
.gal-dots{position:absolute;bottom:.75rem;left:50%;transform:translateX(-50%);display:flex;gap:.4rem;z-index:4}
.gal-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.38);cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);flex-shrink:0}
.gal-dot:hover{background:rgba(255,255,255,.7);transform:scale(1.4)}
.gal-dot.active{background:var(--gold);width:18px;border-radius:4px;animation:dotPulse 1.5s ease infinite}
.gal-counter{position:absolute;top:.85rem;left:.85rem;font-family:'DM Mono',monospace;font-size:.62rem;color:rgba(255,255,255,.88);background:rgba(0,0,0,.5);padding:.22rem .62rem;border-radius:100px;z-index:4;transition:opacity .2s}
.gallery-thumbs{display:flex;gap:.5rem;padding:.6rem 1rem;background:var(--bg3);overflow-x:auto;scrollbar-width:none;animation:fadeIn .4s ease .2s both}
.gallery-thumbs::-webkit-scrollbar{display:none}
.modal-media-tabs{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem;padding:.55rem 1rem 1rem;background:var(--bg2);border-bottom:1px solid var(--border)}
.modal-media-tabs[hidden]{display:none!important}
.media-tab{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .85rem;border-radius:100px;border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-size:.74rem;font-family:'DM Sans',sans-serif;cursor:pointer;transition:color var(--t),border-color var(--t),background var(--t),box-shadow var(--t),transform var(--t)}
.media-tab:hover{border-color:var(--gold-dk);color:var(--gold);transform:translateY(-1px)}
.media-tab.active{background:var(--gold-a10);border-color:var(--gold);color:var(--gold);font-weight:500;animation:scaleIn .2s ease}
.media-tab-icon{font-size:.65rem;opacity:.9}
.gal-thumb{width:70px;height:48px;object-fit:cover;border-radius:5px;cursor:pointer;border:2px solid transparent;transition:border-color .2s,opacity .2s,transform .2s;flex-shrink:0;opacity:.55}
.gal-thumb.active{border-color:var(--gold);opacity:1;transform:scale(1.05)}
.gal-thumb:hover{opacity:.85;transform:scale(1.08)}
.modal-content{padding:1.75rem;position:relative}
.modal-content::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-lt));border-radius:2px;opacity:.6}
.modal-price{font-family:'Playfair Display',serif;font-size:1.85rem;font-weight:700;color:var(--gold-lt);margin-bottom:.25rem;animation:fadeInUp .4s ease .1s both}
.modal-title{font-family:'Playfair Display',serif;font-size:1.22rem;color:var(--cream);margin-bottom:.35rem;animation:fadeInUp .4s ease .15s both}
.modal-loc{color:var(--muted);font-size:.86rem;display:flex;align-items:center;gap:.38rem;margin-bottom:1.35rem;animation:fadeInUp .4s ease .2s both}
.modal-stats-grid{display:grid;gap:.9rem;margin-bottom:1.35rem;padding:1.1rem;background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);animation:scaleIn .4s ease .1s both}
.m-stat{display:flex;flex-direction:column;gap:.18rem;align-items:center;text-align:center;transition:transform .2s}
.m-stat:hover{transform:scale(1.05)}
.m-stat-val{font-family:'DM Mono',monospace;font-size:1.05rem;color:var(--gold-lt);font-weight:500}
.m-stat-lbl{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.modal-desc{font-size:.88rem;color:var(--text2);line-height:1.8;margin-bottom:1.35rem;animation:fadeInUp .4s ease .25s both}
.am-title{font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.55rem;animation:fadeInUp .4s ease .3s both}
.modal-ams{display:flex;flex-wrap:wrap;gap:.42rem;margin-bottom:1.65rem;animation:fadeInUp .4s ease .35s both}
.am-tag{background:var(--surface2);border:1px solid var(--border2);color:var(--text2);font-size:.76rem;padding:.26rem .7rem;border-radius:100px;transition:all var(--t)}
.am-tag:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-a08);transform:translateY(-1px)}
.modal-actions{display:flex;gap:.65rem;flex-wrap:wrap;animation:fadeInUp .4s ease .4s both}
.btn-primary{flex:1;min-width:160px;background:var(--gold);color:var(--bg);border:none;padding:.82rem 1.6rem;border-radius:var(--r);font-size:.88rem;font-weight:600;cursor:pointer;transition:all var(--t);font-family:'DM Sans',sans-serif;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.15);border-radius:50%;transform:translate(-50%,-50%);transition:width .5s,height .5s}
.btn-primary:hover::before{width:300px;height:300px}
.btn-primary:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 8px 28px var(--gold-a40)}
.btn-primary:active{transform:translateY(0) scale(.98)}
.btn-outline{padding:.82rem 1.3rem;border:1px solid var(--border2);background:none;color:var(--text2);border-radius:var(--r);font-size:.88rem;cursor:pointer;transition:all var(--t);font-family:'DM Sans',sans-serif;position:relative;overflow:hidden}
.btn-outline::before{content:'';position:absolute;inset:0;background:var(--gold-a08);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.btn-outline:hover::before{transform:scaleX(1)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}

/* FAVS */
#favs-view{display:none;padding:1.75rem;animation:fadeIn .4s ease}
.favs-header{display:flex;align-items:baseline;gap:.65rem;margin-bottom:1.4rem;flex-wrap:wrap}
.favs-title{font-family:'Playfair Display',serif;font-size:1.75rem;font-weight:600;color:var(--cream);animation:fadeInUp .5s ease both}
#favs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:1.35rem}

/* TOAST */
#toast{position:fixed;bottom:1.75rem;right:1.75rem;z-index:300;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);padding:.8rem 1.15rem;display:flex;align-items:center;gap:.7rem;box-shadow:var(--shadow);transform:translateY(120%) scale(.9);opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);max-width:290px}
#toast.show{transform:none;opacity:1}
.toast-icon{font-size:1.05rem;animation:pulse .5s ease}
.toast-text{font-size:.82rem;color:var(--text2)}
.toast-text strong{color:var(--text)}

/* COMERCIAL VIEW */
#comercial-view{display:none;grid-column:2;padding:1.75rem;animation:fadeIn .4s ease}
#comercial-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:1.35rem}

/* DESARROLLO VIEW */
#desarrollo-view{display:none;grid-column:1/-1;padding:1.75rem;animation:fadeIn .4s ease}
.desarrollo-hero{text-align:center;margin-bottom:2.5rem;animation:fadeInUp .6s ease both}
.desarrollo-hero-label{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem}
.desarrollo-hero-title{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3.8vw,2.6rem);font-weight:600;color:var(--cream);margin-bottom:.6rem}
.desarrollo-hero-title em{font-style:italic;color:var(--gold)}
.desarrollo-hero-sub{color:var(--muted);font-size:.9rem;max-width:580px;margin:0 auto;line-height:1.7}
#desarrollo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:1.5rem;margin-top:1rem}

.des-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:transform var(--t),box-shadow var(--t),border-color var(--t);animation:cardIn .4s ease both;display:flex;flex-direction:column;position:relative}
.des-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-lt));transform:scaleX(0);transform-origin:left;transition:transform .35s ease;z-index:5}
.des-card:hover::before{transform:scaleX(1)}
.des-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px var(--gold-a18);border-color:var(--gold-a22)}
.des-card-img-wrap{position:relative;overflow:hidden;aspect-ratio:16/9;background:var(--surface2)}
.des-card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94);display:block}
.des-card:hover .des-card-img-wrap img{transform:scale(1.06)}
.des-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.des-card-tag{display:inline-block;font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;padding:.25rem .6rem;border-radius:100px;margin-bottom:.55rem;width:fit-content}
.des-tag-preventa{background:rgba(247,163,24,.15);border:1px solid var(--gold-a30);color:var(--gold)}
.des-tag-construccion{background:rgba(240,106,20,.12);border:1px solid rgba(240,106,20,.35);color:var(--red-lt)}
.des-tag-entregado{background:rgba(39,174,96,.12);border:1px solid rgba(39,174,96,.35);color:#2ecc71}
.des-card-title{font-size:1.05rem;font-weight:600;color:var(--cream);margin-bottom:.25rem}
.des-card-location{font-size:.78rem;color:var(--muted);display:flex;align-items:center;gap:.28rem;margin-bottom:.65rem}
.des-card-desc{font-size:.82rem;color:var(--text2);line-height:1.6;margin-bottom:.9rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.des-card-stats{display:flex;gap:1rem;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--border)}
.des-stat{display:flex;flex-direction:column;gap:.1rem}
.des-stat-val{font-family:'DM Mono',monospace;font-size:.82rem;color:var(--gold-lt);font-weight:500}
.des-stat-lbl{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* DESARROLLO MODAL (reuse .modal-overlay / .modal-box / .modal-gallery / etc.) */
#des-modal-overlay .modal-stats-grid{margin-bottom:1rem}
#des-modal-overlay .modal-desc{margin-bottom:1.5rem}
#des-modal-overlay .modal-content::before{display:none}

/* MOBILE */
.mobile-filter-btn{display:none;align-items:center;gap:.45rem;background:var(--surface);border:1px solid var(--border2);color:var(--text2);padding:.4rem .8rem;border-radius:var(--r);cursor:pointer;font-size:.8rem;font-family:'DM Sans',sans-serif;transition:all var(--t)}
.mobile-filter-btn:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-1px);box-shadow:0 4px 12px var(--gold-a15)}
@media(max-width:860px){
  header{padding:0 .75rem}
  .header-inner{height:56px;gap:.5rem}
  .logo-img{height:26px}
  .main-layout{grid-template-columns:1fr}
  .sidebar{position:relative;top:0;height:auto;border-right:none;border-bottom:1px solid var(--border);display:none;max-height:80vh}
  .sidebar.mobile-open{display:block}
  .mobile-filter-btn{display:flex!important}
  .mobile-menu-btn{display:flex}
  .mobile-filter-btn span{display:none}
  .fav-label{display:none}
  .btn-fav-count{padding:.4rem}
  nav{position:absolute;top:100%;left:0;right:0;background:var(--header-bg);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);flex-direction:column;padding:.5rem 1rem;gap:0;display:none;animation:slideDown .25s ease;z-index:99}
  nav.open{display:flex}
  nav a{padding:.7rem 1rem;width:100%;text-align:center;border-radius:0;font-size:.82rem}
  nav a:hover,nav a.active{background:var(--gold-a08);border-radius:var(--r)}
  .theme-toggle{width:32px;height:32px;font-size:.85rem}
  .mobile-filter-btn,.mobile-menu-btn{width:32px;height:32px;padding:0;justify-content:center}
  .mobile-filter-btn svg,.mobile-menu-btn svg{width:15px;height:15px;display:block}
  .hero{padding:2.5rem 1.25rem 2rem}
  .hero-stats{gap:1.5rem}
  .stat-number{font-size:1.4rem}
  #props-grid,#comercial-grid,#favs-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
  .content-area,#comercial-view,#favs-view,#desarrollo-view{padding:1.25rem}
  .top-right{width:100%}
  .search-bar{min-width:0;flex:1}
  .sort-select{flex-shrink:0}
  .modal-box{max-width:96vw;max-height:96vh}
  .modal-gallery{aspect-ratio:4/3}
  .modal-content{padding:1.25rem}
  .modal-price{font-size:1.45rem}
  .modal-stats-grid{grid-template-columns:repeat(3,1fr);gap:.6rem;padding:.85rem}
  .modal-actions{flex-direction:column}
  .btn-primary{min-width:unset}
}
@media(max-width:520px){
  .hero{padding:2rem 1rem 1.5rem}
  .hero h1{font-size:1.75rem}
  .hero-sub{font-size:.82rem}
  .hero-stats{flex-wrap:wrap;gap:1.2rem}
  .stat-number{font-size:1.25rem}
  .stat-label{font-size:.58rem}
  #props-grid,#comercial-grid,#favs-grid{grid-template-columns:1fr}
  .content-area,#comercial-view,#favs-view,#desarrollo-view{padding:1rem}
  .content-top{flex-direction:column;align-items:stretch}
  .top-right{flex-direction:column}
  .search-bar{max-width:unset}
  .sort-select{width:100%}
  .view-controls{align-self:flex-end}
  .card-footer{flex-direction:column;gap:.5rem;align-items:flex-start}
  .btn-cta{width:100%;text-align:center;justify-content:center}
  .gal-btn{width:32px;height:32px;font-size:1rem}
  #gal-prev{left:.5rem}
  #gal-next{right:.5rem}
  .modal-close{width:30px;height:30px;font-size:.9rem;top:.5rem;right:.5rem}
  .gallery-thumbs{padding:.4rem .6rem}
  .gal-thumb{width:52px;height:38px}
  #desarrollo-grid{grid-template-columns:1fr}
}

/* VIDEO / MEDIA BADGES ON CARD */
.card-media-badges{position:absolute;bottom:.65rem;right:.65rem;display:flex;gap:.35rem;z-index:1;flex-direction:column;align-items:flex-end}
.video-count{background:rgba(224,109,16,.82);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:#fff;font-family:'DM Mono',monospace;font-size:.6rem;padding:.22rem .55rem;border-radius:100px;display:flex;align-items:center;gap:.3rem;transition:transform .2s}
.video-count:hover{transform:scale(1.05)}
#props-grid.list-view .video-count{display:none}

/* ========================
   CONTACT SECTION
======================== */
.contact-section{background:var(--bg);min-height:100vh}
.contact-inner{max-width:1100px;margin:0 auto;padding:3rem 2rem 2rem}
.contact-hero{text-align:center;margin-bottom:3rem;animation:fadeInUp .6s ease both}
.contact-hero-label{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem}
.contact-hero-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:600;color:var(--cream);margin-bottom:.6rem}
.contact-hero-sub{color:var(--muted);font-size:.92rem;max-width:520px;margin:0 auto;line-height:1.7}

.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:2rem;margin-bottom:3rem}

/* Form Card */
.contact-form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:2rem;transition:border-color .3s,box-shadow .3s,transform .3s;animation:fadeInLeft .6s ease .15s both}
.contact-form-card:hover{border-color:var(--gold-a30);box-shadow:0 8px 32px var(--gold-a10)}
.contact-card-title{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:600;color:var(--cream);margin-bottom:.25rem}
.contact-card-sub{font-size:.82rem;color:var(--muted);margin-bottom:1.5rem}
.contact-form{display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.35rem}
.form-group label{font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}
.form-group input,.form-group select,.form-group textarea{background:var(--bg2);border:1px solid var(--border2);color:var(--text);font-size:.86rem;padding:.65rem .85rem;border-radius:var(--r);font-family:'DM Sans',sans-serif;transition:border-color var(--t),box-shadow var(--t),transform var(--t);outline:none;resize:vertical}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted2)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-a10);transform:translateY(-1px)}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%237a7468' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .85rem center;cursor:pointer}
.form-group select option{background:var(--surface);color:var(--text)}
.contact-submit{width:100%;margin-top:.5rem;font-size:.92rem;padding:.85rem;position:relative;overflow:hidden}
.contact-submit::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.12);border-radius:50%;transform:translate(-50%,-50%);transition:width .5s,height .5s}
.contact-submit:hover::before{width:400px;height:400px}
.contact-submit:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 10px 32px rgba(224,109,16,.35)}
.contact-submit:active{transform:translateY(0) scale(.98)}
.contact-submit{transition:all var(--t)}

/* Info Column */
.contact-info-col{display:flex;flex-direction:column;gap:1.5rem}
.contact-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;transition:border-color .3s,box-shadow .3s,transform .3s;animation:fadeInRight .6s ease .15s both}
.contact-info-card:hover{border-color:var(--gold-a30);box-shadow:0 8px 32px var(--gold-a10);transform:translateY(-2px)}
.contact-info-items{display:flex;flex-direction:column;gap:1.15rem;margin-top:1rem}
.contact-info-item{display:flex;align-items:flex-start;gap:.85rem;padding:.35rem .5rem;border-radius:var(--r);transition:background var(--t),transform var(--t)}
.contact-info-item:hover{background:var(--gold-a08);transform:translateX(4px)}
.contact-info-icon{width:38px;height:38px;border-radius:10px;background:var(--gold-a10);border:1px solid var(--gold-a28);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold)}
.info-label{font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.15rem}
.info-value{font-size:.85rem;color:var(--text2);line-height:1.5}
.info-link{color:var(--gold);text-decoration:none;transition:color var(--t)}
.info-link:hover{color:var(--gold-lt);text-decoration:underline}

/* Services Card */
.contact-services-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;transition:border-color .3s,box-shadow .3s,transform .3s;animation:fadeInRight .6s ease .3s both}
.contact-services-card:hover{border-color:var(--gold-a30)}
.services-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;margin-top:1rem}
.service-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:.85rem .7rem;text-align:center;transition:all var(--t);position:relative;overflow:hidden}
.service-item::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold-a08),transparent);opacity:0;transition:opacity .3s}
.service-item:hover::before{opacity:1}
.service-item:hover{border-color:var(--gold-a40);background:var(--gold-a08);transform:translateY(-4px);box-shadow:0 8px 24px var(--gold-a15)}
.service-icon{font-size:1.4rem;margin-bottom:.3rem;transition:transform .3s}
.service-item:hover .service-icon{transform:scale(1.2) rotate(5deg)}
.service-name{font-size:.68rem;color:var(--text2);font-weight:500;position:relative;z-index:1}

/* Agents */
.contact-agents{margin-bottom:3rem;animation:fadeInUp .6s ease .4s both}
.contact-section-title{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:600;color:var(--cream);margin-bottom:.3rem;text-align:center}
.contact-section-sub{font-size:.86rem;color:var(--muted);text-align:center;margin-bottom:1.5rem}
.agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.25rem}
.agent-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.5rem 1rem;text-align:center;transition:all var(--t);animation:fadeInUp .5s ease both}
.agent-card:nth-child(1){animation-delay:.45s}
.agent-card:nth-child(2){animation-delay:.52s}
.agent-card:nth-child(3){animation-delay:.59s}
.agent-card:nth-child(4){animation-delay:.66s}
.agent-card:nth-child(5){animation-delay:.73s}
.agent-card:hover{border-color:var(--gold-a40);transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.15),0 0 0 1px var(--gold-a18)}
.agent-card-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--gold-a30),var(--gold-a10));border:2px solid var(--gold-a40);display:flex;align-items:center;justify-content:center;margin:0 auto .75rem;font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--gold);transition:all .3s}
.agent-card:hover .agent-card-avatar{transform:scale(1.08);box-shadow:0 0 20px var(--gold-a30);border-color:var(--gold)}
.agent-card-name{font-size:.88rem;font-weight:500;color:var(--text);margin-bottom:.2rem}
.agent-card-role{font-size:.68rem;color:var(--muted);font-family:'DM Mono',monospace;letter-spacing:.08em;text-transform:uppercase}
.agent-card-wa{display:inline-flex;align-items:center;gap:.35rem;margin-top:.8rem;padding:.35rem .7rem;border-radius:100px;background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.3);color:#25d366;font-size:.7rem;text-decoration:none;transition:all var(--t)}
.agent-card-wa:hover{background:rgba(37,211,102,.2);border-color:#25d366;transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.2)}

/* Footer */
.contact-footer{border-top:1px solid var(--border);padding:2.5rem 0 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;animation:fadeIn .6s ease .8s both}
.footer-brand{margin-bottom:.5rem}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--cream);font-style:italic;letter-spacing:.05em;transition:color .3s}
.footer-logo:hover{color:var(--gold)}
.footer-logo span{color:var(--gold)}
.footer-tagline{font-size:.72rem;color:var(--muted);font-family:'DM Mono',monospace;letter-spacing:.15em;text-transform:uppercase;margin-top:.2rem}
.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}
.footer-links a{font-size:.78rem;color:var(--muted);text-decoration:none;transition:color var(--t),transform var(--t)}
.footer-links a:hover{color:var(--gold);transform:translateY(-2px)}
.footer-copy{font-size:.68rem;color:var(--muted2)}

/* ========================
   CONTACT RESPONSIVE
======================== */
@media(max-width:768px){
  .contact-section{min-height:auto}
  .contact-inner{padding:3rem 1.5rem 2rem}
  .contact-hero{margin-bottom:2.5rem}
  .contact-hero-title{font-size:clamp(1.6rem,5vw,2.4rem)}
  .contact-hero-sub{font-size:.86rem}
  .contact-grid{grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem}
  .contact-form-card{padding:1.75rem;animation:fadeInUp .6s ease .15s both}
  .contact-info-col{gap:1.5rem}
  .contact-info-card{padding:1.75rem;animation:fadeInUp .6s ease .2s both}
  .contact-services-card{padding:1.75rem;animation:fadeInUp .6s ease .3s both}
  .services-grid{grid-template-columns:repeat(3,1fr);gap:.75rem}
  .service-item{padding:.85rem .6rem}
  .service-icon{font-size:1.25rem}
  .service-name{font-size:.65rem}
  .contact-agents{margin-bottom:2.5rem}
  .contact-section-title{font-size:1.2rem}
  .contact-section-sub{font-size:.82rem}
  .agents-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}
  .contact-footer{padding:2.5rem 0 1.5rem}
  .footer-links{gap:1rem}
}
@media(max-width:520px){
  .contact-inner{padding:2rem 1.15rem 1.5rem}
  .contact-hero{margin-bottom:1.75rem}
  .contact-hero-label{font-size:.55rem}
  .contact-hero-title{font-size:1.5rem;margin-bottom:.5rem}
  .contact-hero-sub{font-size:.82rem;line-height:1.6;max-width:100%}
  .contact-grid{gap:1.5rem;margin-bottom:2rem}
  .contact-form-card{padding:1.5rem 1.15rem}
  .contact-card-title{font-size:1.05rem;margin-bottom:.3rem}
  .contact-card-sub{font-size:.78rem;margin-bottom:1.5rem}
  .contact-form{gap:1rem}
  .form-row{grid-template-columns:1fr;gap:1rem}
  .form-group{gap:.45rem}
  .form-group input,.form-group select,.form-group textarea{padding:.65rem .85rem;font-size:.84rem}
  .contact-submit{font-size:.88rem;padding:.85rem;margin-top:.75rem}
  .contact-info-card,.contact-services-card{padding:1.5rem 1.15rem}
  .contact-info-items{gap:1.25rem;margin-top:1.25rem}
  .contact-info-item{gap:.75rem;padding:.35rem .5rem}
  .contact-info-icon{width:36px;height:36px;border-radius:8px}
  .contact-info-icon svg{width:17px;height:17px}
  .info-label{font-size:.55rem;margin-bottom:.2rem}
  .info-value{font-size:.82rem}
  .services-grid{grid-template-columns:1fr 1fr;gap:.75rem;margin-top:1.25rem}
  .service-item{padding:.85rem .6rem}
  .service-icon{font-size:1.3rem;margin-bottom:.35rem}
  .service-name{font-size:.68rem}
  .contact-agents{margin-bottom:2rem}
  .contact-section-title{font-size:1.15rem;margin-bottom:.4rem}
  .contact-section-sub{font-size:.8rem;margin-bottom:1.5rem}
  .agents-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}
  .agent-card{padding:1.25rem .85rem}
  .agent-card-avatar{width:52px;height:52px;font-size:1rem;margin-bottom:.75rem}
  .agent-card-name{font-size:.85rem}
  .agent-card-role{font-size:.62rem}
  .agent-card-wa{font-size:.68rem;padding:.35rem .75rem;margin-top:.85rem}
  .contact-footer{padding:2rem 0 1.25rem;gap:1rem}
  .footer-logo{font-size:1.15rem}
  .footer-tagline{font-size:.66rem}
  .footer-links{gap:.85rem;flex-direction:column;align-items:center}
  .footer-links a{font-size:.74rem}
  .footer-copy{font-size:.64rem}
}

