/*
Theme Name: Duffy Real Estate
Theme URI: https://www.duffyrealestate.com/
Author: Custom Build
Author URI: https://www.duffyrealestate.com/
Description: A luxury real estate theme for Duffy Real Estate, Inc. Fuses an elegant, editorial full-bleed layout with Duffy's forest-green and gold branding. Built for IDX Broker (IMPress) integration with customizable Agent profiles and native WordPress menus.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: duffy-realestate
Tags: real-estate, idx, custom-menu, custom-logo, featured-images, full-width-template, footer-widgets, block-styles
*/

/* ==========================================================================
   1. DESIGN TOKENS  —  edit these to re-brand the whole site
   ========================================================================== */
:root {
  /* Brand colors (Duffy) */
  --duffy-green:        #1e5631;  /* primary forest green */
  --duffy-green-dark:   #143f24;  /* footer / deep sections */
  --duffy-green-darker: #0f2b1c;  /* darkest bar */
  --duffy-gold:         #c4a96a;  /* champagne gold accent */
  --duffy-gold-dark:    #a88c4d;

  /* Neutrals (Campion-inspired warm palette) */
  --cream:        #f5f1ea;  /* warm parchment section bg */
  --cream-alt:    #efe9df;
  --ink:          #1a1a17;  /* near-black warm body text */
  --ink-soft:     #4a4a44;
  --white:        #ffffff;
  --line:         #e2dcd0;  /* hairline borders on cream */
  --overlay:      rgba(15, 25, 18, 0.42); /* photo overlay */

  /* Typography */
  --font-display: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --font-sans:    "Manrope", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* Layout */
  --container:    1280px;
  --container-narrow: 860px;
  --gutter:       clamp(20px, 5vw, 60px);
  --section-y:    clamp(60px, 9vw, 130px);

  /* Motion */
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* ==========================================================================
   2. RESET / BASE
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--duffy-green); text-decoration: none; transition: color .3s var(--ease); }
a:hover { color: var(--duffy-gold-dark); }
button { font-family: inherit; cursor: pointer; }

h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 600; line-height: 1.12; color: var(--ink); margin: 0 0 .5em; }
h1 { font-size: clamp(2.6rem, 6vw, 5rem); }
h2 { font-size: clamp(2rem, 4.2vw, 3.4rem); }
h3 { font-size: clamp(1.4rem, 2.4vw, 2rem); }
p  { margin: 0 0 1.2em; }

/* Utility text style used for labels/eyebrows/nav */
.eyebrow, .label-caps {
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: .78rem;
  font-weight: 600;
  color: var(--duffy-gold-dark);
}

/* ==========================================================================
   3. LAYOUT HELPERS
   ========================================================================== */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.container--narrow { max-width: var(--container-narrow); }
.section { padding: var(--section-y) 0; }
.section--cream { background: var(--cream); }
.section--green { background: var(--duffy-green); color: var(--white); }
.section--green h1,.section--green h2,.section--green h3 { color: var(--white); }
.text-center { text-align: center; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

.section-head { max-width: 720px; margin: 0 auto clamp(36px, 5vw, 60px); text-align: center; }
.section-head .eyebrow { display: block; margin-bottom: 14px; }
.section-head p { color: var(--ink-soft); font-size: 1.05rem; }
.section--green .section-head p { color: rgba(255,255,255,.82); }

/* Ornamental divider (Campion-style) */
.ornament { display:flex; align-items:center; justify-content:center; gap:14px; margin: 18px auto; }
.ornament::before, .ornament::after { content:""; height:1px; width:60px; background: var(--duffy-gold); opacity:.6; }
.ornament span { color: var(--duffy-gold); font-size: 1rem; }

/* ==========================================================================
   4. BUTTONS  (zero-radius, uppercase, wide tracking — Campion style)
   ========================================================================== */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-size: .8rem;
  font-weight: 600;
  padding: 16px 34px;
  border: 1px solid transparent;
  border-radius: 0;
  transition: all .35s var(--ease);
  cursor: pointer;
  line-height: 1;
}
.btn--primary { background: var(--duffy-green); color: var(--white); border-color: var(--duffy-green); }
.btn--primary:hover { background: var(--duffy-gold-dark); border-color: var(--duffy-gold-dark); color: var(--white); }
.btn--gold { background: var(--duffy-gold); color: var(--ink); border-color: var(--duffy-gold); }
.btn--gold:hover { background: var(--duffy-gold-dark); color: var(--white); border-color: var(--duffy-gold-dark); }
.btn--outline { background: transparent; color: var(--ink); border-color: currentColor; }
.btn--outline:hover { background: var(--ink); color: var(--white); }
.btn--outline-light { background: transparent; color: var(--white); border-color: rgba(255,255,255,.7); }
.btn--outline-light:hover { background: var(--white); color: var(--duffy-green); border-color:var(--white); }
.btn--ghost-dark { background: rgba(15,25,18,.55); color:#fff; border-color: rgba(255,255,255,.4); }
.btn--ghost-dark:hover { background: var(--duffy-green); border-color: var(--duffy-green); }

/* ==========================================================================
   5. TOP BAR + HEADER / NAV
   ========================================================================== */
.topbar {
  background: var(--duffy-green-darker);
  color: rgba(255,255,255,.85);
  font-family: var(--font-sans);
  font-size: .75rem;
  letter-spacing: .06em;
}
.topbar .container { display:flex; justify-content:space-between; align-items:center; min-height: 40px; padding-top:8px; padding-bottom:8px; }
.topbar a { color:#fff; text-transform:uppercase; letter-spacing:.12em; font-weight:600; }
.topbar a:hover { color: var(--duffy-gold); }
.topbar__right { display:flex; gap:16px; align-items:center; }
.topbar__sep { opacity:.4; }

/* Header wrapper. Transparent-over-hero on the front page, solid elsewhere. */
.site-header {
  position: relative;
  z-index: 100;
  background: var(--white);
  border-bottom: 1px solid var(--line);
  transition: background .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header .container { display:flex; align-items:center; justify-content:space-between; gap: 24px; min-height: 96px; }

/* Transparent header variant (front page hero) */
body.transparent-header .site-header {
  position: absolute; left:0; right:0; top: 0;
  background: transparent;
  border-bottom: 1px solid rgba(255,255,255,.18);
}
/* push topbar+header over hero on front page */
body.transparent-header .topbar { position: relative; z-index: 101; background: rgba(15,25,18,.55); }

/* Sticky state (added by JS) */
.site-header.is-stuck {
  position: fixed; top:0; left:0; right:0;
  background: var(--white);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 4px 24px rgba(0,0,0,.08);
  animation: slideDown .4s var(--ease);
}
@keyframes slideDown { from { transform: translateY(-100%);} to { transform: translateY(0);} }

/* Logo */
.site-branding { display:flex; align-items:center; gap:14px; }
.site-branding img { max-height: 66px; width:auto; }
.site-title-text { font-family: var(--font-display); font-size: 1.7rem; font-weight:600; color: var(--duffy-green); line-height:1; }
.site-tagline-text { font-family: var(--font-sans); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color: var(--ink-soft); margin-top:4px; }
body.transparent-header .site-title-text { color:#fff; }
body.transparent-header .site-tagline-text { color: rgba(255,255,255,.85); }

/* Primary nav */
.main-nav ul { list-style:none; margin:0; padding:0; display:flex; align-items:center; gap: clamp(14px, 1.6vw, 30px); }
.main-nav li { position: relative; }
.main-nav a {
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .8rem;
  font-weight: 600;
  color: var(--ink);
  padding: 12px 0;
  display:inline-block;
}
.main-nav a:hover, .main-nav .current-menu-item > a { color: var(--duffy-gold-dark); }
body.transparent-header .site-header:not(.is-stuck) .main-nav a { color:#fff; }
body.transparent-header .site-header:not(.is-stuck) .main-nav a:hover { color: var(--duffy-gold); }

/* Dropdown submenus */
.main-nav .sub-menu {
  position:absolute; top:100%; left:0; min-width: 220px;
  background: var(--white);
  border-top: 2px solid var(--duffy-gold);
  box-shadow: 0 18px 40px rgba(0,0,0,.14);
  padding: 8px 0;
  display:block;
  opacity:0; visibility:hidden; transform: translateY(10px);
  transition: all .3s var(--ease);
  flex-direction: column; gap:0;
}
.main-nav li:hover > .sub-menu { opacity:1; visibility:visible; transform: translateY(0); }
.main-nav .sub-menu li { width:100%; }
.main-nav .sub-menu a { display:block; padding: 10px 22px; color: var(--ink); letter-spacing:.08em; font-size:.76rem; }
.main-nav .sub-menu a:hover { background: var(--cream); color: var(--duffy-green); }
.main-nav .menu-item-has-children > a::after { content:"›"; margin-left:6px; font-size:.9em; opacity:.7; }

/* Header CTA (phone/search) */
.header-actions { display:flex; align-items:center; gap:18px; }
.header-phone { font-family: var(--font-sans); font-weight:700; letter-spacing:.04em; font-size:.95rem; color: var(--duffy-green); white-space:nowrap; }
body.transparent-header .site-header:not(.is-stuck) .header-phone { color:#fff; }

/* Mobile toggle */
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:8px; }
.nav-toggle span { width:26px; height:2px; background: var(--ink); transition: all .3s var(--ease); }
body.transparent-header .site-header:not(.is-stuck) .nav-toggle span { background:#fff; }

/* ==========================================================================
   6. HERO  (full-bleed, Campion-style)
   ========================================================================== */
.hero {
  position: relative;
  min-height: 92vh;
  display:flex; align-items:flex-end;
  background-size: cover; background-position: center;
  color:#fff;
}
.hero::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(15,25,18,.35) 0%, rgba(15,25,18,.15) 45%, rgba(15,25,18,.72) 100%); }
.hero__inner { position: relative; z-index:2; width:100%; padding-bottom: clamp(48px, 8vw, 100px); }
.hero__eyebrow { color: var(--duffy-gold); letter-spacing:.28em; }
.hero h1 { color:#fff; max-width: 14ch; margin:.2em 0 .3em; text-shadow: 0 2px 30px rgba(0,0,0,.35); }
.hero__sub { font-size: 1.25rem; max-width: 42ch; color: rgba(255,255,255,.92); margin-bottom: 28px; }

/* Hero search bar */
.hero-search { background: rgba(255,255,255,.96); padding: 10px; display:flex; gap:8px; max-width: 680px; box-shadow: 0 20px 50px rgba(0,0,0,.25); }
.hero-search input[type="text"], .hero-search input[type="search"] {
  flex:1; border:none; padding: 16px 18px; font-family: var(--font-body); font-size:1rem; color: var(--ink); background:transparent; outline:none;
}
.hero-search button { border:none; background: var(--duffy-green); color:#fff; padding: 0 26px; border-radius:0; text-transform:uppercase; letter-spacing:.12em; font-family:var(--font-sans); font-weight:600; font-size:.8rem; transition: background .3s var(--ease); }
.hero-search button:hover { background: var(--duffy-gold-dark); }
.hero__searchlabel { font-family: var(--font-display); font-size: 1.6rem; margin-bottom: 12px; color:#fff; }

/* ==========================================================================
   7. PROPERTY / LISTING CARDS  (for IDX featured widgets + manual cards)
   ========================================================================== */
.grid { display:grid; gap: clamp(20px, 2.4vw, 34px); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }

.property-card { background:#fff; overflow:hidden; border:1px solid var(--line); transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
.property-card:hover { transform: translateY(-6px); box-shadow: 0 22px 50px rgba(0,0,0,.13); }
.property-card__media { position:relative; overflow:hidden; aspect-ratio: 3/2; }
.property-card__media img { width:100%; height:100%; object-fit:cover; transition: transform .7s var(--ease); }
.property-card:hover .property-card__media img { transform: scale(1.06); }
.property-card__price { position:absolute; left:0; bottom:0; background: var(--duffy-green); color:#fff; font-family: var(--font-sans); font-weight:700; padding: 8px 16px; letter-spacing:.03em; }
.property-card__body { padding: 20px 22px 24px; }
.property-card__addr { font-family: var(--font-display); font-size:1.2rem; color: var(--ink); margin-bottom:6px; }
.property-card__meta { font-family: var(--font-sans); font-size:.82rem; letter-spacing:.05em; color: var(--ink-soft); text-transform:uppercase; }

/* Quick links row (Recently Sold / Open Houses / etc) */
.quicklinks { display:flex; flex-wrap:wrap; justify-content:center; gap: 14px 40px; margin-top: 44px; }
.quicklinks a { font-family:var(--font-sans); text-transform:uppercase; letter-spacing:.16em; font-size:.8rem; font-weight:600; color: var(--white); border-bottom:1px solid var(--duffy-gold); padding-bottom:4px; }
.quicklinks a:hover { color: var(--duffy-gold); }

/* ==========================================================================
   8. NEIGHBORHOODS  (zero-gap image tile grid — Campion signature)
   ========================================================================== */
.neighborhood-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:0; }
.neighborhood-tile { position:relative; min-height: 320px; display:flex; align-items:center; justify-content:center; overflow:hidden; background:#333; }
.neighborhood-tile img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition: transform .8s var(--ease); }
.neighborhood-tile::after { content:""; position:absolute; inset:0; background: var(--overlay); transition: background .4s var(--ease); }
.neighborhood-tile:hover img { transform: scale(1.08); }
.neighborhood-tile:hover::after { background: rgba(15,25,18,.6); }
.neighborhood-tile__content { position:relative; z-index:2; text-align:center; color:#fff; }
.neighborhood-tile__content .eyebrow { color: var(--duffy-gold); display:block; margin-bottom:6px; }
.neighborhood-tile__content .name { font-family: var(--font-display); font-size: 1.9rem; color:#fff; }

/* Plain community text-link grid (fallback / footer style) */
.community-links { columns: 4; column-gap: 30px; list-style:none; padding:0; margin:0; }
.community-links li { margin-bottom: 12px; break-inside: avoid; }
.community-links a { font-family: var(--font-sans); letter-spacing:.04em; color:#fff; font-size:.95rem; }
.community-links a:hover { color: var(--duffy-gold); }

/* ==========================================================================
   9. ABOUT / INTRO BLOCK
   ========================================================================== */
.intro-block { max-width: var(--container-narrow); margin:0 auto; text-align:center; }
.intro-block p { font-size: 1.12rem; color: var(--ink-soft); }
.stats-row { display:flex; flex-wrap:wrap; justify-content:center; gap: clamp(30px, 6vw, 80px); margin-top: 40px; }
.stat { text-align:center; }
.stat__num { font-family: var(--font-display); font-size: clamp(2.6rem,5vw,3.8rem); color: var(--duffy-gold); line-height:1; }
.stat__label { font-family: var(--font-sans); text-transform:uppercase; letter-spacing:.16em; font-size:.78rem; color: var(--ink-soft); margin-top:8px; }
.section--green .stat__label { color: rgba(255,255,255,.8); }
.section--green .stat__num { color: var(--duffy-gold); }

/* ==========================================================================
   10. AGENTS
   ========================================================================== */
.agent-card { text-align:center; background:#fff; transition: transform .4s var(--ease); }
.agent-card:hover { transform: translateY(-5px); }
.agent-card__photo { aspect-ratio: 4/5; overflow:hidden; background: var(--cream-alt); margin-bottom:18px; }
.agent-card__photo img { width:100%; height:100%; object-fit:cover; transition: transform .7s var(--ease); }
.agent-card:hover .agent-card__photo img { transform: scale(1.05); }
.agent-card__name { font-family: var(--font-display); font-size: 1.4rem; margin-bottom:2px; }
.agent-card__title { font-family: var(--font-sans); text-transform:uppercase; letter-spacing:.14em; font-size:.72rem; color: var(--duffy-gold-dark); }
.agent-card__phone { display:block; margin-top:8px; font-family:var(--font-sans); font-size:.9rem; color: var(--ink-soft); }

/* Single agent profile */
.agent-single { display:grid; grid-template-columns: 380px 1fr; gap: clamp(30px,5vw,70px); align-items:start; }
.agent-single__photo img { width:100%; object-fit:cover; aspect-ratio: 4/5; }
.agent-single__meta { list-style:none; padding:0; margin: 18px 0 0; font-family: var(--font-sans); }
.agent-single__meta li { padding: 10px 0; border-bottom:1px solid var(--line); display:flex; gap:10px; align-items:center; font-size:.95rem; }
.agent-single__meta .label-caps { color: var(--ink-soft); min-width: 90px; }
.agent-single h1 { margin-bottom: 6px; }
.agent-single__role { font-family:var(--font-sans); text-transform:uppercase; letter-spacing:.16em; color: var(--duffy-gold-dark); font-weight:600; font-size:.85rem; margin-bottom: 24px; }

/* ==========================================================================
   11. CONTENT / PAGE DEFAULTS
   ========================================================================== */
.page-hero { background: var(--duffy-green); color:#fff; text-align:center; padding: clamp(80px,12vw,150px) 0 clamp(50px,7vw,80px); position:relative; }
.page-hero h1 { color:#fff; }
.page-hero .breadcrumb { font-family:var(--font-sans); text-transform:uppercase; letter-spacing:.16em; font-size:.72rem; color: rgba(255,255,255,.7); margin-bottom: 16px; }
.page-hero .breadcrumb a { color: var(--duffy-gold); }
.page-hero--image { background-size:cover; background-position:center; }
.page-hero--image::after { content:""; position:absolute; inset:0; background: var(--overlay); }
.page-hero--image .container { position:relative; z-index:2; }

.entry-content { font-size: 1.05rem; }
.entry-content h2 { margin-top: 1.4em; }
.entry-content ul, .entry-content ol { padding-left: 1.4em; }
.entry-content img { margin: 1.5em 0; }
.entry-content blockquote { border-left: 3px solid var(--duffy-gold); padding-left: 24px; margin: 1.5em 0; font-family: var(--font-display); font-size:1.4rem; font-style:italic; color: var(--ink-soft); }

/* Forms */
input, select, textarea { font-family: var(--font-body); font-size:1rem; }
.wpcf7 input:not([type=submit]), .wpcf7 select, .wpcf7 textarea,
.contact-form input:not([type=submit]), .contact-form select, .contact-form textarea {
  width:100%; padding: 14px 16px; border:1px solid var(--line); border-radius:0; background:#fff; margin-bottom:16px;
}
.wpcf7 input:focus, .contact-form input:focus { outline:none; border-color: var(--duffy-green); }

/* ==========================================================================
   12. IDX BROKER WRAPPER SUPPORT
   IDX pages inherit header/footer via the dynamic wrapper. These rules make
   IDX Broker's default markup match the theme.
   ========================================================================== */
#idxwrapper, .idx-wrapper, #IDX-main { padding: 40px 0 var(--section-y); }
.idx-content-wrapper { max-width: var(--container); margin:0 auto; padding: 0 var(--gutter); }
/* Style IDX buttons to match theme */
.IDX-showcaseTitle, .idx-omnibar-form, #IDX-main a.btn,
.IDX-detailsPrice { font-family: var(--font-sans); }
.IDX-searchButton, input.IDX-searchButton, .idx-search-btn {
  background: var(--duffy-green) !important; color:#fff !important; border-radius:0 !important; border:none !important;
  text-transform:uppercase; letter-spacing:.1em;
}
.IDX-searchButton:hover { background: var(--duffy-gold-dark) !important; }
/* IDX omnibar / quick search widget spacing */
.idx-omnibar-wrap, .widget_impress_omnibar_widget { margin-bottom: 24px; }

/* ==========================================================================
   13. FOOTER
   ========================================================================== */
.site-footer { background: var(--duffy-green-dark); color: rgba(255,255,255,.86); }
.footer-communities { background: var(--duffy-green); padding: var(--section-y) 0; }
.footer-communities h2 { color:#fff; text-align:center; margin-bottom: 40px; }
.footer-main { padding: clamp(50px,7vw,80px) 0; }
.footer-grid { display:grid; grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: clamp(30px,4vw,60px); }
.footer-col h4 { font-family:var(--font-sans); text-transform:uppercase; letter-spacing:.18em; font-size:.82rem; color: var(--duffy-gold); margin-bottom: 20px; }
.footer-col img.footer-logo { max-height: 90px; margin-bottom: 18px; }
.footer-col ul { list-style:none; padding:0; margin:0; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { color: rgba(255,255,255,.86); font-size:.95rem; }
.footer-col a:hover { color: var(--duffy-gold); }
.footer-office { margin-bottom: 22px; font-size:.95rem; line-height:1.6; }
.footer-office strong { color:#fff; display:block; font-family:var(--font-sans); letter-spacing:.08em; text-transform:uppercase; font-size:.8rem; margin-bottom:4px; }
.footer-social { display:flex; gap:14px; margin-top: 18px; }
.footer-social a { width:40px; height:40px; border:1px solid rgba(255,255,255,.3); display:flex; align-items:center; justify-content:center; border-radius:50%; color:#fff; transition: all .3s var(--ease); }
.footer-social a:hover { background: var(--duffy-gold); border-color: var(--duffy-gold); color: var(--duffy-green-dark); }

.footer-bottom { background: var(--duffy-green-darker); padding: 22px 0; font-family:var(--font-sans); font-size:.78rem; letter-spacing:.04em; color: rgba(255,255,255,.6); }
.footer-bottom .container { display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:16px; }
.footer-bottom a { color: rgba(255,255,255,.75); }
.footer-bottom a:hover { color: var(--duffy-gold); }
.footer-legal-links { display:flex; flex-wrap:wrap; gap: 6px 18px; }
.footer-trust { display:flex; gap:14px; align-items:center; }
.footer-trust img { height: 34px; width:auto; opacity:.9; }

/* ==========================================================================
   14. SCROLL REVEAL
   ========================================================================== */
.reveal { opacity:0; transform: translateY(30px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-visible { opacity:1; transform: none; }

/* ==========================================================================
   15. RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
  .grid--4 { grid-template-columns: repeat(2, 1fr); }
  .neighborhood-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .community-links { columns: 3; }
  .agent-single { grid-template-columns: 1fr; }
  .agent-single__photo img { max-width: 380px; }
}
@media (max-width: 860px) {
  .topbar { display:none; }
  .nav-toggle { display:flex; }
  .main-nav {
    position: fixed; inset: 0 0 0 auto; width: min(84vw, 360px);
    background: var(--duffy-green); padding: 100px 30px 40px;
    transform: translateX(100%); transition: transform .4s var(--ease);
    overflow-y:auto; z-index: 200; box-shadow: -20px 0 50px rgba(0,0,0,.3);
  }
  .main-nav.is-open { transform: translateX(0); }
  .main-nav ul { flex-direction:column; align-items:flex-start; gap:0; }
  .main-nav li { width:100%; border-bottom:1px solid rgba(255,255,255,.12); }
  .main-nav a { color:#fff !important; display:block; padding:16px 0; width:100%; }
  .main-nav .sub-menu { position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; background:transparent; border-top:none; padding: 0 0 8px 16px; }
  .main-nav .sub-menu a { color: rgba(255,255,255,.8) !important; padding:10px 0; }
  .nav-open { overflow:hidden; }
  .nav-overlay { position:fixed; inset:0; background:rgba(0,0,0,.5); opacity:0; visibility:hidden; transition:.3s; z-index:150; }
  .nav-overlay.is-open { opacity:1; visibility:visible; }
}
@media (max-width: 640px) {
  .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
  .neighborhood-grid { grid-template-columns: 1fr; }
  .community-links { columns: 2; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero { min-height: 82vh; }
  .hero-search { flex-direction:column; }
  .hero-search button { padding:16px; }
}
