/* ============================================================
   Porchlight — shared stylesheet
   Used by every page (index, property, signup, dashboards)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400..700&family=Inter:wght@400;500;600;700&family=IBM+Plex+Mono:wght@500&display=swap');

:root{
  --ink:#1B2430; --paper:#FBF6ED; --paper-deep:#F1E8D8;
  --porch:#F4A340; --porch-soft:#FBD9A0; --brick:#C1502E; --sage:#7C9A78;
  --slate:#5C6B7A; --line:rgba(27,36,48,0.12); --line-soft:rgba(27,36,48,0.07);
  --font-display:'Fraunces', serif; --font-body:'Inter', sans-serif; --font-mono:'IBM Plex Mono', monospace;
}

*{ box-sizing:border-box; margin:0; padding:0; }
body{ font-family:var(--font-body); color:var(--ink); background:var(--paper); line-height:1.55; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
.container{ max-width:1180px; margin:0 auto; padding:0 24px; }
.muted{ color:var(--slate); font-size:0.9em; }
.hidden{ display:none !important; }

/* ---------- Icons ---------- */
.icon{ display:inline-block; vertical-align:-3px; flex-shrink:0; }
[data-icon]{ display:inline-flex; align-items:center; }
.amenity svg{ color:var(--sage); }

/* ---------- Buttons ---------- */
.btn{ font-family:var(--font-body); font-weight:600; font-size:14px; padding:11px 20px; border-radius:999px;
  border:1px solid transparent; cursor:pointer; display:inline-flex; align-items:center; gap:8px;
  transition:transform .15s ease, background .15s ease; white-space:nowrap; }
.btn:active{ transform:scale(.97); }
.btn-primary{ background:var(--ink); color:var(--paper); }
.btn-primary:hover{ background:#28344a; }
.btn-outline{ background:transparent; border-color:var(--ink); color:var(--ink); }
.btn-outline:hover{ background:var(--ink); color:var(--paper); }
.btn-sm{ padding:8px 14px; font-size:13px; }
.btn-block{ width:100%; justify-content:center; }

/* ---------- Nav ---------- */
.nav{ position:sticky; top:0; z-index:50; background:rgba(251,246,237,0.92); backdrop-filter:blur(6px); border-bottom:1px solid var(--line); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; padding:16px 24px; max-width:1180px; margin:0 auto; flex-wrap:wrap; gap:12px; position:relative; }
.logo{ display:flex; align-items:center; gap:8px; font-family:var(--font-display); font-weight:700; font-size:22px; color:var(--ink); }
.logo span{ color:var(--porch); }
.nav-links{ display:flex; align-items:center; gap:24px; }
.nav-links a{ font-size:15px; font-weight:500; color:var(--slate); }
.nav-links a:hover{ color:var(--ink); }
.nav-auth{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; color:var(--ink); padding:6px; align-items:center; }

@media (max-width:760px){
  .nav-toggle{ display:inline-flex; }
  .nav-links{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--paper);
    border-bottom:1px solid var(--line);
    flex-direction:column;
    align-items:flex-start;
    padding:16px 24px;
    gap:14px;
    z-index:60;
  }
  .nav-links.open{ display:flex; }
}

/* ---------- Hero ---------- */
.hero{ padding:64px 0 48px; }
.eyebrow{ font-family:var(--font-mono); font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--brick); margin-bottom:10px; }
.hero h1{ font-family:var(--font-display); font-size:clamp(34px,6vw,60px); font-weight:600; line-height:1.05; max-width:760px; }
.hero p{ font-size:18px; color:var(--slate); max-width:560px; margin-top:14px; }
.search-bar{ margin-top:28px; display:flex; gap:0; background:#fff; border:1px solid var(--line); border-radius:16px; padding:8px;
  box-shadow:0 8px 30px rgba(27,36,48,0.06); max-width:600px; flex-wrap:wrap; }
.search-bar .field{ flex:1; display:flex; align-items:center; gap:10px; padding:10px 14px; min-width:160px; }
.search-bar input, .search-bar select{ border:none; outline:none; font-family:var(--font-body); font-size:15px; width:100%; background:none; color:var(--ink); }
.search-bar .divider{ width:1px; background:var(--line); margin:8px 0; }

/* ---------- Filter panel ---------- */
.filter-panel{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:22px;
  margin-top:14px; max-width:960px; max-height:80vh; overflow-y:auto;
  display:grid; grid-template-columns:1fr 1fr; gap:18px; }

/* Top bar spans both columns */
.filter-top-bar{ grid-column:1 / -1; display:flex; flex-wrap:wrap; gap:14px 20px; align-items:flex-end;
  padding-bottom:16px; border-bottom:1px solid var(--line); }
.filter-top-group{ display:flex; flex-direction:column; gap:5px; }
.filter-top-group h5{ font-family:var(--font-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--slate); margin:0; }
.filter-top-group input[type="date"], .filter-top-group select{
  border:1px solid var(--line); border-radius:8px; padding:7px 10px; font-family:var(--font-body);
  font-size:13px; background:var(--paper); }
.filter-top-group .filter-range{ display:flex; align-items:center; gap:6px; }
.filter-top-group .filter-range input{ border:1px solid var(--line); border-radius:8px; padding:7px 10px;
  font-family:var(--font-body); font-size:13px; background:var(--paper); width:80px; }
.filter-top-group label{ display:flex; align-items:center; gap:6px; font-size:13px; cursor:pointer; }
.filter-top-group label input[type="checkbox"]{ width:15px; height:15px; accent-color:var(--porch); }

/* Section heading */
.filter-section h5{ font-family:var(--font-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--slate); margin:0 0 8px; }

/* Vertical stacked checkboxes — Building type, Views */
.filter-vertical{ display:flex; flex-direction:column; gap:6px; }
.filter-vertical label{ display:flex; align-items:center; gap:8px; font-size:13.5px; cursor:pointer; }
.filter-vertical input[type="checkbox"]{ width:15px; height:15px; accent-color:var(--porch); flex-shrink:0; }

/* Amenity icon boxes inside each filter section */
.filter-checks.amenity-boxes{ display:grid; grid-template-columns:repeat(3,1fr); gap:5px; }
.filter-checks .amenity-pick{ padding:7px 4px; font-size:11px; gap:4px; border-radius:8px; }
.filter-checks .amenity-pick svg{ width:16px; height:16px; }

/* filterAmenitiesContainer uses display:contents so its children
   are direct grid cells — giving exactly 2 per row */
#filterAmenitiesContainer{ display:contents; }

/* Sticky Reset/Apply bar */
.filter-actions{ grid-column:1 / -1; display:flex; justify-content:flex-end; gap:10px;
  border-top:1px solid var(--line); position:sticky; bottom:-22px; background:#fff;
  margin:0 -22px -22px; padding:14px 22px; }

@media (max-width:700px){
  .filter-panel{ grid-template-columns:1fr; }
  .filter-top-bar{ flex-direction:column; align-items:stretch; }
}

/* ---------- Section heads ---------- */
section{ padding:40px 0; }
.section-head{ margin-bottom:24px; max-width:640px; }
.section-head h2{ font-family:var(--font-display); font-size:clamp(26px,4vw,38px); font-weight:600; }
.section-head p{ color:var(--slate); margin-top:8px; font-size:16px; }

/* ---------- Map ---------- */
.map-canvas{ position:relative; width:100%; aspect-ratio:2/1; border-radius:24px; overflow:hidden; border:1px solid var(--line);
  box-shadow:0 12px 40px rgba(27,36,48,0.08); background:var(--paper-deep); font-family:var(--font-body); }
.map-canvas-sm{ aspect-ratio:16/7; border-radius:18px; }

/* House-shaped pins rendered inside Leaflet's divIcon markers */
.pin-body{ width:34px; height:34px; border-radius:50% 50% 50% 4px; background:var(--porch); display:flex; align-items:center; justify-content:center;
  color:var(--ink); transform:rotate(45deg); box-shadow:0 6px 16px rgba(244,163,64,0.45); position:relative; }
.pin-body .icon{ transform:rotate(-45deg); }
.pin-body::after{ content:''; position:absolute; inset:-6px; border-radius:50% 50% 50% 4px; border:2px solid var(--porch); opacity:.5; animation:pin-pulse 2.4s ease-out infinite; }
@keyframes pin-pulse{ 0%{ transform:scale(.8); opacity:.6; } 70%{ transform:scale(1.6); opacity:0; } 100%{ opacity:0; } }
.pin-body.dim{ background:var(--slate); opacity:.5; }
.pin-body.dim::after{ display:none; }
.pin-body.active{ background:var(--brick); }
.pin-body.active::after{ border-color:var(--brick); }

/* Leaflet tooltip, restyled to match the site */
.leaflet-tooltip{ background:var(--ink); color:var(--paper); border:none; border-radius:10px; padding:8px 12px;
  font-family:var(--font-body); font-size:13px; box-shadow:0 6px 16px rgba(27,36,48,0.2); }
.leaflet-tooltip strong{ font-family:var(--font-display); font-size:14px; }
.leaflet-tooltip-top:before{ border-top-color:var(--ink); }

/* ---------- Map + featured listings side-by-side ---------- */
.map-listings{ display:grid; grid-template-columns:2.1fr 1fr; gap:20px; align-items:start; }
.map-listings .map-canvas{ height:100%; }
.mini-listings{ display:flex; flex-direction:column; gap:14px; }
@media (min-width:901px){
  /* Map: big, fixed size, and stays in view (via sticky) while the
     listings column — which can be taller — scrolls past it with
     the normal page scroll. No separate inner scrollbar, so nothing
     can get hidden behind it. */
  .map-listings .map-canvas{
    position:sticky;
    top:86px; /* just below the sticky navbar */
    height:min(calc(100vh - 110px), 620px);
  }
}
.mini-card{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease; }
.mini-card:hover{ transform:translateY(-2px); box-shadow:0 10px 26px rgba(27,36,48,0.1); }
.mini-card img{ width:100%; aspect-ratio:16/10; object-fit:cover; display:block; }
.mini-card-body{ display:flex; flex-direction:column; gap:4px; padding:14px; }
.mini-card-body h4{ font-family:var(--font-display); font-size:16px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mini-card-price{ font-family:var(--font-mono); font-size:15px; font-weight:600; }
.mini-card-specs{ font-size:13px; color:var(--slate); display:flex; align-items:center; gap:4px; }
.mini-card-address{ font-size:13px; color:var(--slate); display:flex; align-items:center; gap:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mini-card .badge-static{ font-size:10px; padding:3px 8px; margin:0 0 2px; align-self:flex-start; }
@media (max-width:900px){
  .map-listings{ grid-template-columns:1fr; gap:16px; }
  .map-listings .map-canvas{ height:auto; aspect-ratio:4/3; }
}

/* ---------- Listing cards ---------- */
.listings-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.property-card{ background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden; display:flex; flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease; }
.property-card:hover{ transform:translateY(-4px); box-shadow:0 14px 36px rgba(27,36,48,0.1); }
.card-media{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.card-media img{ width:100%; height:100%; object-fit:cover; }
.badge{ position:absolute; font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; padding:5px 10px; border-radius:999px; top:12px; }
.badge-rent{ left:12px; background:var(--ink); color:var(--paper); }
.badge-sale{ left:12px; background:var(--brick); color:var(--paper); }
.badge-tag{ right:12px; background:rgba(251,246,237,0.92); color:var(--ink); border:1px solid var(--line); }
.badge-static{ display:inline-flex; font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; padding:5px 10px; border-radius:999px; margin-bottom:12px; }
.badge-static.badge-rent{ position:static; background:var(--ink); color:var(--paper); }
.badge-static.badge-sale{ position:static; background:var(--brick); color:var(--paper); }
.card-body{ padding:18px 20px 22px; display:flex; flex-direction:column; gap:8px; }
.card-price{ font-family:var(--font-mono); font-size:20px; font-weight:600; }
.card-body h3{ font-family:var(--font-display); font-size:19px; font-weight:600; }
.card-address{ display:flex; align-items:center; gap:6px; color:var(--slate); font-size:13.5px; }
.card-specs{ display:flex; gap:14px; color:var(--slate); font-size:13.5px; margin:2px 0 6px; flex-wrap:wrap; }

/* ---------- How it works ---------- */
.how-tabs{ display:flex; gap:10px; margin-bottom:24px; flex-wrap:wrap; }
.how-tab{ font-family:var(--font-mono); font-size:13px; letter-spacing:.05em; text-transform:uppercase; padding:10px 18px; border-radius:999px;
  border:1px solid var(--line); background:#fff; cursor:pointer; color:var(--slate); }
.how-tab.active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.how-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.how-step{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:22px; }
.how-step .num{ font-family:var(--font-mono); color:var(--porch); font-size:13px; letter-spacing:.1em; margin-bottom:8px; text-transform:uppercase; }
.how-step h4{ font-family:var(--font-display); font-size:18px; margin-bottom:6px; }
.how-step p{ color:var(--slate); font-size:14.5px; }

/* ---------- CTA ---------- */
.cta{ background:var(--ink); color:var(--paper); border-radius:24px; padding:48px; display:flex; align-items:center; justify-content:space-between;
  gap:24px; flex-wrap:wrap; }
.cta h2{ font-family:var(--font-display); font-size:clamp(24px,4vw,34px); font-weight:600; max-width:480px; }
.cta p{ color:var(--porch-soft); margin-top:6px; }
.cta .btn-primary{ background:var(--porch); color:var(--ink); }

/* ---------- Footer ---------- */
.footer{ background:var(--ink); color:var(--paper); padding:56px 0 24px; margin-top:40px; }
.footer-grid{ display:grid; grid-template-columns:2fr 1fr 1fr; gap:36px; }
.footer-brand{ display:flex; align-items:center; gap:8px; font-family:var(--font-display); font-size:22px; font-weight:700; margin-bottom:10px; }
.footer-brand span{ color:var(--porch); }
.footer-tagline{ color:rgba(251,246,237,0.65); font-size:14px; max-width:280px; }
.footer-col h5{ font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--porch-soft); margin-bottom:12px; }
.footer-col a{ display:block; color:rgba(251,246,237,0.8); font-size:14.5px; margin-bottom:8px; }
.footer-col a:hover{ color:var(--porch); }
.footer-bottom{ border-top:1px solid rgba(251,246,237,0.12); margin-top:36px; padding-top:20px; display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:10px; color:rgba(251,246,237,0.5); font-size:13px; }

/* ---------- Property detail ---------- */
.back-link{ display:inline-flex; align-items:center; gap:6px; color:var(--slate); font-size:14px; margin-bottom:16px; }
.back-link:hover{ color:var(--ink); }
.gallery{ display:grid; grid-template-columns:2fr 1fr; gap:12px; margin-bottom:28px; }
.gallery-main{ grid-row:span 3; aspect-ratio:4/3; overflow:hidden; border-radius:18px; cursor:pointer; }
.gallery-main img{ width:100%; height:100%; object-fit:cover; }
.gallery-thumbs{ display:grid; grid-template-rows:repeat(3,1fr); gap:12px; }
.gallery-thumb{ position:relative; border-radius:14px; overflow:hidden; cursor:pointer; border:2px solid transparent; aspect-ratio:4/3; }
.gallery-thumb.active{ border-color:var(--porch); }
.gallery-thumb img{ width:100%; height:100%; object-fit:cover; }
.gallery-thumb-more{ position:absolute; inset:0; background:rgba(27,36,48,0.6); color:#fff; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:18px; font-weight:600; }

/* ---------- Fullscreen image lightbox/slider ---------- */
.lightbox{ position:fixed; inset:0; background:rgba(27,36,48,0.92); z-index:300; display:flex; align-items:center; justify-content:center; }
.lightbox img{ max-width:88vw; max-height:85vh; object-fit:contain; border-radius:8px; }
.lightbox-close{ position:absolute; top:20px; right:20px; width:44px; height:44px; border-radius:50%; border:none;
  background:rgba(255,255,255,0.12); color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; }
.lightbox-close:hover{ background:rgba(255,255,255,0.25); }
.lightbox-nav{ position:absolute; top:50%; transform:translateY(-50%); width:48px; height:48px; border-radius:50%; border:none;
  background:rgba(255,255,255,0.12); color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; }
.lightbox-nav:hover{ background:rgba(255,255,255,0.25); }
.lightbox-prev{ left:20px; }
.lightbox-next{ right:20px; }
.lightbox-counter{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%); color:#fff; font-family:var(--font-mono); font-size:13px;
  background:rgba(255,255,255,0.12); padding:6px 14px; border-radius:999px; }
@media (max-width:600px){
  .lightbox-nav{ width:40px; height:40px; }
  .lightbox-prev{ left:8px; }
  .lightbox-next{ right:8px; }
}
.detail-layout{ display:grid; grid-template-columns:2fr 1fr; gap:40px; align-items:start; }
.detail-main h1{ font-family:var(--font-display); font-size:clamp(26px,4vw,38px); font-weight:600; }
.detail-address{ display:flex; align-items:center; gap:6px; color:var(--slate); margin-top:8px; }
.detail-price{ font-family:var(--font-mono); font-size:26px; font-weight:600; margin-top:12px; }
.specs-row{ display:flex; gap:22px; margin:18px 0; padding:14px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); flex-wrap:wrap; }
.specs-row span{ display:flex; align-items:center; gap:6px; font-size:15px; }
.detail-section h2{ font-family:var(--font-display); font-size:21px; margin-bottom:10px; margin-top:28px; }
.detail-section p{ color:var(--slate); font-size:15px; line-height:1.7; }
.amenities-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.amenity{ display:flex; align-items:center; gap:8px; font-size:14px; background:#fff; border:1px solid var(--line); border-radius:10px; padding:10px 14px; }

/* ---------- Amenity catalog: display boxes + picker ---------- */
.amenity-category{ margin-bottom:22px; }
.amenity-category h3{ font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--slate); margin-bottom:10px; }
.amenity-boxes{ display:grid; grid-template-columns:repeat(auto-fill, minmax(150px, 1fr)); gap:10px; }
.amenity-box{ display:flex; flex-direction:column; align-items:center; gap:8px; text-align:center; background:#fff; border:1px solid var(--line);
  border-radius:12px; padding:14px 10px; font-size:13px; }
.amenity-box svg{ color:var(--sage); }

/* Selectable version used on the "Add a listing" form */
.amenity-pick{ display:flex; flex-direction:column; align-items:center; gap:8px; text-align:center; border:1px solid var(--line); border-radius:12px;
  padding:12px 8px; font-size:12.5px; cursor:pointer; background:var(--paper); transition:border-color .15s ease, background .15s ease; }
.amenity-pick input{ position:absolute; opacity:0; pointer-events:none; }
.amenity-pick svg{ color:var(--slate); transition:color .15s ease; }
.amenity-pick.selected{ border-color:var(--porch); background:rgba(244,163,64,0.12); }
.amenity-pick.selected svg{ color:var(--brick); }
.contact-card{ position:sticky; top:96px; background:#fff; border:1px solid var(--line); border-radius:18px; padding:22px; display:flex; flex-direction:column; gap:14px; }
.contact-person{ display:flex; align-items:center; gap:12px; }
.contact-person img{ width:50px; height:50px; border-radius:50%; object-fit:cover; }
.contact-person h4{ font-family:var(--font-display); font-size:17px; }
.contact-person span{ color:var(--slate); font-size:13px; }
.contact-row{ display:flex; align-items:center; gap:8px; font-size:14px; color:var(--slate); }
.contact-card hr{ border:none; border-top:1px solid var(--line); width:100%; }
.contact-card textarea{ width:100%; border:1px solid var(--line); border-radius:10px; padding:10px 12px; font-family:var(--font-body); font-size:14px; resize:vertical; min-height:80px; margin-bottom:10px; }
.notice{ border-radius:10px; padding:12px 14px; font-size:13.5px; }
.notice-success{ background:rgba(124,154,120,0.15); border:1px solid var(--sage); }
.notice-warn{ background:rgba(244,163,64,0.15); border:1px solid var(--porch); }
.notice-error{ background:rgba(193,80,46,0.12); border:1px solid var(--brick); color:var(--brick); }

/* ---------- Forms / Auth ---------- */
.auth-wrap{ display:flex; justify-content:center; padding:48px 0 80px; }
.auth-card{ background:#fff; border:1px solid var(--line); border-radius:20px; padding:36px; max-width:480px; width:100%; box-shadow:0 12px 40px rgba(27,36,48,0.06); }
.tab-row{ display:flex; background:var(--paper-deep); border-radius:999px; padding:4px; margin-bottom:24px; }
.tab-row button{ flex:1; padding:10px; border-radius:999px; border:none; background:none; font-weight:600; font-size:14px; cursor:pointer; color:var(--slate); font-family:var(--font-body); }
.tab-row button.active{ background:var(--ink); color:var(--paper); }
.auth-card h2{ font-family:var(--font-display); font-size:26px; margin-bottom:4px; }
.auth-sub{ color:var(--slate); font-size:14px; margin-bottom:20px; }
.form-grid{ display:grid; gap:14px; }
.field label{ display:block; font-size:13px; font-weight:600; margin-bottom:6px; }
.field input, .field select, .field textarea{ width:100%; border:1px solid var(--line); border-radius:10px; padding:11px 14px; font-family:var(--font-body); font-size:14.5px; background:var(--paper); }
.field input[type="checkbox"], .field input[type="radio"]{ width:auto; height:auto; padding:0; border:none; background:none; accent-color:var(--ink); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.radio-row{ display:flex; gap:16px; flex-wrap:wrap; }
.radio-row label{ display:flex; align-items:center; gap:6px; font-size:14px; font-weight:500; }
.checkbox-row{ display:flex; align-items:flex-start; gap:8px; font-size:13px; color:var(--slate); }

/* A checkbox-row label inside a .field (e.g. "Pet friendly") needs to
   override .field label's block/bold/heading styling so the checkbox
   and its text line up on one row, inside the field's box. */
.field label.checkbox-row{ display:flex; align-items:center; gap:8px; font-weight:500; font-size:14px; color:var(--ink); margin-bottom:0; cursor:pointer; }

/* ---------- Dashboards ---------- */
.dash-head{ display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:14px; margin-bottom:24px; }
.dash-head h1{ font-family:var(--font-display); font-size:clamp(24px,4vw,36px); }
.dash-head p{ color:var(--slate); margin-top:6px; }
.stat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:32px; }
.stat-card{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:18px; }
.stat-card .value{ font-family:var(--font-display); font-size:28px; font-weight:600; }
.stat-card .label{ color:var(--slate); font-size:13px; margin-top:4px; }
.dash-section{ margin-bottom:40px; }
.dash-section-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; flex-wrap:wrap; gap:10px; }
.dash-section-head h2{ font-family:var(--font-display); font-size:20px; }
.listing-row{ display:flex; gap:14px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px; margin-bottom:10px; flex-wrap:wrap; }
.listing-row img{ width:64px; height:64px; border-radius:10px; object-fit:cover; }
.listing-row-main{ flex:1; min-width:160px; }
.listing-row-main h4{ font-family:var(--font-display); font-size:16px; }
.listing-row-main span{ color:var(--slate); font-size:13px; }
.listing-row-meta{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.status-pill{ font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; padding:5px 12px; border-radius:999px;
  display:inline-flex; align-items:center; gap:6px; white-space:nowrap; }
.status-active, .status-live, .status-verified{ background:rgba(124,154,120,0.15); color:#3f6b3a; }
.status-pending{ background:rgba(244,163,64,0.18); color:#8a5a14; }
.status-restricted, .status-flagged{ background:rgba(193,80,46,0.13); color:var(--brick); }
.dash-tabs{ display:flex; gap:10px; margin-bottom:18px; flex-wrap:wrap; }
.table-wrap{ background:#fff; border:1px solid var(--line); border-radius:14px; overflow-x:auto; }
table{ width:100%; border-collapse:collapse; font-size:14px; }
th{ text-align:left; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--slate); padding:12px 16px; border-bottom:1px solid var(--line); white-space:nowrap; }
td{ padding:12px 16px; border-bottom:1px solid var(--line-soft); vertical-align:middle; }
tr:last-child td{ border-bottom:none; }
.table-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.table-actions .btn{ padding:6px 12px; font-size:12.5px; }
.add-listing-card{ border:2px dashed var(--line); border-radius:14px; padding:18px; margin-bottom:16px; }
.unit-row{ border:1px solid var(--line); border-radius:12px; padding:14px; margin-bottom:12px; background:var(--paper); }
.unit-row .field-row{ margin-bottom:10px; }
.units-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(180px, 1fr)); gap:14px; }
.unit-card{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px; }
.unit-card h4{ font-family:var(--font-display); font-size:16px; margin-bottom:6px; }
.unit-card .unit-price{ font-family:var(--font-mono); font-size:16px; font-weight:600; margin-bottom:8px; }
.unit-card .unit-specs{ font-size:13px; color:var(--slate); display:flex; flex-direction:column; gap:4px; }
.unit-card .unit-specs span{ display:flex; align-items:center; gap:6px; }
.photo-thumb{ position:relative; border-radius:10px; overflow:hidden; border:1px solid var(--line); background:#fff; }
.photo-thumb img{ width:100%; height:120px; object-fit:cover; display:block; }
.photo-thumb button{ position:absolute; top:6px; right:6px; background:rgba(27,36,48,0.7); color:#fff; border:none;
  border-radius:999px; width:26px; height:26px; display:flex; align-items:center; justify-content:center; cursor:pointer; }
.photo-thumb button:hover{ background:var(--brick); }
.tour-card{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px; margin-bottom:12px; }
.tour-card-head{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; flex-wrap:wrap; margin-bottom:10px; }
.tour-card-head h4{ font-family:var(--font-display); font-size:16px; }
.empty-state{ color:var(--slate); font-size:14px; padding:20px; text-align:center; }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .gallery{ grid-template-columns:1fr; }
  .gallery-main{ grid-row:auto; }
  .gallery-thumbs{ grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .detail-layout{ grid-template-columns:1fr; }
  .contact-card{ position:static; }
}
@media (max-width:900px){
  .listings-grid{ grid-template-columns:1fr; }
  .how-steps{ grid-template-columns:1fr; }
  .stat-grid{ grid-template-columns:1fr 1fr; }
  .amenities-grid{ grid-template-columns:1fr; }
}
@media (max-width:800px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:520px){
  .field-row{ grid-template-columns:1fr; }
  .cta{ padding:32px 20px; }
}

/* ---------- Floating "Need help?" widget (landlords) ---------- */
.help-widget{ position:fixed; bottom:24px; left:24px; z-index:200; display:flex; flex-direction:column; align-items:flex-start; gap:12px; }
.help-fab{ width:54px; height:54px; border-radius:50%; border:none; background:var(--ink); color:var(--paper);
  display:flex; align-items:center; justify-content:center; cursor:pointer; box-shadow:0 10px 26px rgba(27,36,48,0.25); order:2; }
.help-fab:hover{ background:var(--porch); color:var(--ink); }
.help-panel{ order:1; width:320px; max-height:70vh; background:#fff; border:1px solid var(--line); border-radius:16px;
  box-shadow:0 16px 40px rgba(27,36,48,0.18); display:flex; flex-direction:column; overflow:hidden; }
.help-panel-header{ display:flex; align-items:center; justify-content:space-between; gap:8px; padding:14px 16px; border-bottom:1px solid var(--line); }
.help-panel-header h4{ font-family:var(--font-display); font-size:15px; display:flex; align-items:center; gap:8px; }
.help-panel-header button{ background:none; border:none; cursor:pointer; color:var(--slate); display:flex; align-items:center; padding:2px; }
.help-panel-header button:hover{ color:var(--ink); }
.help-back{ background:none; border:none; cursor:pointer; color:var(--slate); display:inline-flex; align-items:center; padding:0; }
.help-panel-body{ padding:14px 16px; overflow-y:auto; }
.help-new-form{ display:flex; flex-direction:column; gap:8px; }
.help-new-form textarea{ border:1px solid var(--line); border-radius:10px; padding:9px 12px; font-family:var(--font-body); font-size:13.5px;
  background:var(--paper); resize:vertical; }
.help-new-form button{ align-self:flex-end; }
.help-ticket-list{ display:flex; flex-direction:column; gap:8px; margin-top:14px; border-top:1px solid var(--line); padding-top:14px; }
.help-ticket-row{ display:flex; align-items:center; gap:8px; text-align:left; border:1px solid var(--line); border-radius:10px;
  padding:8px 10px; background:var(--paper); cursor:pointer; font-size:13px; }
.help-ticket-row:hover{ border-color:var(--porch); }
.help-ticket-num{ font-family:var(--font-mono); font-size:12px; color:var(--slate); flex-shrink:0; }
.help-ticket-preview{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--slate); }
.help-thread{ display:flex; flex-direction:column; gap:10px; margin-bottom:12px; }
.help-message{ max-width:85%; padding:8px 12px; border-radius:12px; font-size:13.5px; }
.help-message p{ margin:0; }
.help-message-time{ display:block; font-size:11px; color:var(--slate); margin-top:4px; }
.help-message-user{ align-self:flex-end; background:var(--porch-soft); }
.help-message-admin{ align-self:flex-start; background:var(--paper-deep); }
@media (max-width:520px){
  .help-widget{ left:12px; bottom:12px; }
  .help-panel{ width:calc(100vw - 24px); max-width:340px; }
}
