/* ─────────────────────────────────────────
   COMMUNITIES.CSS
───────────────────────────────────────── */

.comm-hero { position:relative; padding:140px 0 60px; overflow:hidden; }
.comm-hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 60% 70% at 80% 40%, rgba(107,140,107,0.12) 0%, transparent 70%), var(--cream); z-index:0; }
.comm-hero-inner { position:relative; z-index:1; max-width:680px; }
.comm-hero-inner h1 { font-size:clamp(2rem,4.5vw,3.2rem); color:var(--brown); margin:12px 0 16px; line-height:1.15; }
.comm-hero-inner h1 em { font-style:italic; color:var(--sage-dark); }
.comm-hero-sub { font-size:17px; color:var(--text-mid); line-height:1.7; max-width:540px; }

/* FILTERS */
.filters-bar { background:var(--white); border-bottom:1px solid var(--cream-dark); padding:24px 0; position:sticky; top:68px; z-index:50; box-shadow:0 2px 12px rgba(92,64,51,0.06); }
.filters-grid { display:flex; gap:12px; flex-wrap:wrap; align-items:flex-end; }
.filter-group { display:flex; flex-direction:column; gap:4px; min-width:140px; }
.filter-group label { font-size:11px; font-weight:500; color:var(--text-light); text-transform:uppercase; letter-spacing:.06em; }
.filter-group select, .filter-group input[type="text"] { padding:8px 12px; border:1px solid var(--cream-dark); border-radius:var(--radius-sm); font-family:'DM Sans',sans-serif; font-size:13px; color:var(--text-dark); background:var(--cream); outline:none; transition:border-color 0.15s; appearance:none; }
.filter-group select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238B7B74' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 10px center; padding-right:28px; cursor:pointer; }
.filter-group select:focus, .filter-group input:focus { border-color:var(--sage-dark); background:var(--white); }
.filter-check-group { flex-direction:row; align-items:center; gap:14px; padding-bottom:2px; flex-wrap:wrap; }
.check-label { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--text-mid); cursor:pointer; white-space:nowrap; }
.check-label input[type="checkbox"] { width:15px; height:15px; accent-color:var(--sage-dark); cursor:pointer; }
.filters-meta { display:flex; justify-content:space-between; align-items:center; margin-top:14px; }
#results-count { font-size:13px; color:var(--text-light); }
.clear-btn { font-family:'DM Sans',sans-serif; font-size:12px; color:var(--sage-dark); background:none; border:none; cursor:pointer; text-decoration:underline; }

/* GRID */
.comm-grid-section { padding:48px 0 80px; background:var(--cream); }
.comm-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:20px; }

/* CARD */
.comm-card { background:var(--white); border-radius:var(--radius); border:1px solid var(--cream-dark); overflow:hidden; cursor:pointer; transition:transform 0.2s, box-shadow 0.2s; display:flex; flex-direction:column; }
.comm-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--brown-pale); }
.comm-card-photo { position:relative; width:100%; aspect-ratio:16/9; overflow:hidden; background:var(--sage-pale); }
.comm-card-photo img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.3s; }
.comm-card:hover .comm-card-photo img { transform:scale(1.04); }
.comm-card-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:var(--sage-pale); }
.comm-card-placeholder span { font-family:'Lora',serif; font-size:2rem; font-weight:600; color:var(--sage-dark); }
.comm-card-city { position:absolute; top:10px; left:10px; background:rgba(44,31,26,0.75); color:#fff; font-size:11px; font-weight:500; padding:3px 10px; border-radius:999px; backdrop-filter:blur(4px); }
.comm-card-body { padding:18px 20px 20px; display:flex; flex-direction:column; gap:10px; flex:1; }
.comm-card-body h3 { font-size:1rem; color:var(--brown); line-height:1.3; margin:0; }
.comm-card-pills { display:flex; flex-wrap:wrap; gap:5px; }
.comm-card-meta { display:flex; justify-content:space-between; align-items:center; margin-top:auto; padding-top:10px; border-top:1px solid var(--cream-dark); }
.comm-card-cost { font-size:13px; font-weight:500; color:var(--sage-dark); }
.comm-card-size { font-size:11px; color:var(--text-light); background:var(--cream); padding:2px 8px; border-radius:999px; }

/* PILLS */
.care-pill { font-size:10px; font-weight:500; padding:2px 8px; border-radius:999px; letter-spacing:.03em; }
.tag-green { background:#E8F5E9; color:#2E7D32; }
.tag-purple { background:#F3E5F5; color:#6A1B9A; }
.tag-blue { background:#E3F2FD; color:#1565C0; }
.tag-red { background:#FBE9E7; color:#BF360C; }

/* NO RESULTS */
.no-results { flex-direction:column; align-items:center; text-align:center; padding:80px 24px; gap:12px; }
.no-results-icon { font-size:3rem; }
.no-results h3 { font-size:1.3rem; color:var(--brown); }
.no-results p { font-size:14px; color:var(--text-mid); max-width:400px; line-height:1.6; }
.no-results a { color:var(--sage-dark); }

/* MODAL */
.modal-overlay { position:fixed; inset:0; background:rgba(44,31,26,0.5); z-index:200; backdrop-filter:blur(4px); }
.comm-modal { position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); z-index:201; background:var(--white); border-radius:16px; width:min(680px, 95vw); max-height:90vh; overflow-y:auto; display:flex; flex-direction:column; box-shadow:0 20px 60px rgba(44,31,26,0.25); }
.modal-close { position:sticky; top:12px; align-self:flex-end; margin:12px 12px 0; background:var(--cream); border:none; width:36px; height:36px; border-radius:50%; font-size:14px; color:var(--text-mid); cursor:pointer; transition:background 0.15s; z-index:10; flex-shrink:0; }
.modal-close:hover { background:var(--cream-dark); }
.modal-photo-wrap { width:100%; aspect-ratio:16/7; overflow:hidden; background:var(--sage-pale); position:relative; flex-shrink:0; }
.modal-photo-wrap img { width:100%; height:100%; object-fit:cover; display:block; }
.modal-photo-placeholder { position:absolute; inset:0; display:none; align-items:center; justify-content:center; background:var(--sage-pale); }
.modal-photo-placeholder span { font-family:'Lora',serif; font-size:4rem; font-weight:600; color:var(--sage-dark); }
.modal-body { padding:28px 32px 32px; display:flex; flex-direction:column; gap:14px; }
.modal-body h2 { font-size:1.5rem; color:var(--brown); line-height:1.2; margin:0; }
.modal-address { font-size:13px; color:var(--text-light); margin:0; }
.modal-pills { display:flex; flex-wrap:wrap; gap:6px; }
.modal-details { display:grid; grid-template-columns:1fr 1fr; gap:10px; background:var(--cream); border-radius:var(--radius-sm); padding:16px; }
.modal-detail { display:flex; flex-direction:column; gap:2px; }
.modal-detail-label { font-size:10px; font-weight:500; text-transform:uppercase; letter-spacing:.06em; color:var(--text-light); }
.modal-detail span:last-child { font-size:13px; color:var(--text-dark); }
.modal-features { font-size:13px; color:var(--text-mid); line-height:1.6; font-style:italic; margin:0; }
.modal-actions { display:flex; gap:10px; flex-wrap:wrap; padding-top:4px; }
.modal-actions .btn { font-size:13px; padding:10px 20px; }

.nav-links .active { color:var(--sage-dark) !important; font-weight:500; }

/* RESPONSIVE */
@media (max-width:768px) {
  .filters-grid { flex-direction:column; }
  .filter-group { min-width:100%; }
  .comm-grid { grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); }
  .modal-body { padding:20px; }
  .modal-details { grid-template-columns:1fr; }
  .modal-actions { flex-direction:column; }
  .modal-actions .btn { text-align:center; }
}
@media (max-width:480px) { .comm-grid { grid-template-columns:1fr; } }
