/* ============================================================
   EMERALD DESIGN CUSTOM HOMES — Site-wide Stylesheet
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --white:         #ffffff;
  --cream:         #f7f5f0;
  --cream-border:  #e8e4dc;
  --sage-tint:     #eaf6f0;
  --sage-border:   #c5dfd0;
  --charcoal:      #1c1c1a;
  --charcoal-mid:  #3a3a38;
  --text-muted:    #6b6b68;
  --text-light:    #9a9a96;
  --emerald:       #2d7a4f;
  --emerald-light: #3a9d65;
  --emerald-pale:  #eaf6f0;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Jost', 'Helvetica Neue', Arial, sans-serif;

  --nav-h: 88px;
  --max-w: 1280px;
}

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--cream);
  color: var(--charcoal);
  font-size: 16px;
  line-height: 1.7;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
img { display: block; max-width: 100%; height: auto; }

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 48px;
}

.text-center { text-align: center; }
.text-center .section__lead { margin-left: auto; margin-right: auto; }

/* ── Typography ── */
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 400; line-height: 1.15; }
h1 { font-size: clamp(2.8rem, 5.5vw, 5.2rem); letter-spacing: -0.01em; }
h2 { font-size: clamp(2rem, 3.5vw, 3rem); letter-spacing: -0.005em; }
h3 { font-size: 1.65rem; }
h4 { font-size: 1.25rem; }

.eyebrow {
  font-family: var(--font-body);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--emerald);
  display: block;
  margin-bottom: 0.9rem;
}
.eyebrow--light { color: rgba(255,255,255,0.55); }

/* ── Buttons ── */
.btn {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 14px 34px;
  border: 1px solid transparent;
  transition: background 0.25s, color 0.25s, border-color 0.25s;
  cursor: pointer;
}
.btn--dark  { background: var(--charcoal); color: var(--white); border-color: var(--charcoal); }
.btn--dark:hover { background: var(--charcoal-mid); border-color: var(--charcoal-mid); }
.btn--outline { background: transparent; color: var(--emerald); border-color: var(--emerald); }
.btn--outline:hover { background: var(--emerald); color: var(--white); }
.btn--white { background: var(--white); color: var(--charcoal); border-color: var(--white); }
.btn--white:hover { background: var(--cream); }
.btn--emerald { background: var(--emerald); color: var(--white); border-color: var(--emerald); }
.btn--emerald:hover { background: var(--emerald-light); border-color: var(--emerald-light); }

/* ── Fade-in ── */
.fade-in { opacity: 0; transform: translateY(24px); transition: opacity 0.65s ease, transform 0.65s ease; }
.fade-in.visible { opacity: 1; transform: none; }

/* ── Sections ── */
.section { padding: 96px 0; }
.section--white { background: var(--white); border-top: 1px solid var(--cream-border); border-bottom: 1px solid var(--cream-border); }
.section--cream { background: var(--cream); }
.section--dark  { background: var(--charcoal); }

.section__header { margin-bottom: 60px; }
.section__header h2 { color: var(--charcoal); margin-bottom: 0.75rem; }
.section__header--light h2 { color: var(--white); }
.section__lead { font-size: 1rem; color: var(--text-muted); max-width: 580px; line-height: 1.85; }
.section__lead--light { color: rgba(255,255,255,0.6); }

.divider { width: 36px; height: 1px; background: var(--emerald); margin: 1.5rem 0; }
.divider--light { background: var(--emerald-light); }

/* ── Two-column layout ── */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.two-col--reverse { direction: rtl; }
.two-col--reverse > * { direction: ltr; }

.two-col__img {
  position: relative;
  overflow: hidden;
}
.two-col__img-block {
  width: 100%;
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, #b8d4c4, #8db8a0);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(44,80,60,0.4);
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-family: var(--font-body);
}
.two-col__img-block--dark { background: linear-gradient(135deg, #2a3a30, #1a2820); color: rgba(92,186,126,0.25); }
.two-col__text p { font-size: 0.93rem; color: var(--text-muted); line-height: 1.9; margin-bottom: 1.1rem; }
.two-col__text p:last-of-type { margin-bottom: 0; }
.two-col__text--light p { color: rgba(255,255,255,0.6); }
.two-col__text--light h2 { color: var(--white); }

/* ── CTA Band ── */
.cta-band {
  background: var(--emerald-pale);
  border-top: 1px solid var(--sage-border);
  border-bottom: 1px solid var(--sage-border);
  padding: 96px 0;
  text-align: center;
}
.cta-band h2 { color: var(--charcoal); max-width: 640px; margin: 0 auto 1.25rem; }
.cta-band p { font-size: 1rem; color: var(--text-muted); max-width: 500px; margin: 0 auto 2.5rem; line-height: 1.8; }

/* ── Inner Page Hero ── */
.inner-hero {
  padding-top: calc(var(--nav-h) + 72px);
  padding-bottom: 72px;
  background: var(--white);
  border-bottom: 1px solid var(--cream-border);
}
.inner-hero .container { max-width: var(--max-w); margin: 0 auto; padding: 0 48px; }
.inner-hero h1 { color: var(--charcoal); margin-bottom: 1rem; }
.inner-hero p { font-size: 1.05rem; color: var(--text-muted); max-width: 560px; line-height: 1.85; }

/* ============================================================
   NAVIGATION
   ============================================================ */
#nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-h);
  z-index: 1000;
  background: #000000;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  transition: box-shadow 0.3s;
}
#nav.scrolled { box-shadow: 0 2px 24px rgba(0,0,0,0.5); }

.nav__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 48px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.nav__logo { display: flex; align-items: center; flex-shrink: 0; }
.nav__logo img { height: 68px; width: auto; display: block; }

.nav__links { display: flex; align-items: center; gap: 32px; }

.nav__links > li > a {
  font-size: 0.71rem;
  font-weight: 500;
  letter-spacing: 0.17em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.65);
  transition: color 0.2s;
  position: relative;
}
.nav__links > li > a::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0; right: 100%;
  height: 1px;
  background: var(--emerald-light);
  transition: right 0.3s;
}
.nav__links > li > a:hover { color: var(--white); }
.nav__links > li > a:hover::after,
.nav__links > li > a.active::after { right: 0; }
.nav__links > li > a.active { color: var(--emerald-light); }

.nav__dropdown { position: relative; }
.nav__drop-btn {
  font-size: 0.71rem; font-weight: 500; letter-spacing: 0.17em; text-transform: uppercase;
  color: rgba(255,255,255,0.65); background: none; border: none; cursor: pointer;
  font-family: var(--font-body); display: flex; align-items: center; gap: 6px; padding: 0;
  transition: color 0.2s;
}
.nav__drop-btn:hover { color: var(--white); }
.nav__drop-btn svg { transition: transform 0.2s; }
.nav__dropdown:hover .nav__drop-btn svg { transform: rotate(180deg); }

.nav__drop-menu {
  display: none;
  position: absolute;
  top: calc(100% + 14px); left: 50%;
  transform: translateX(-50%);
  background: #000000;
  border: 1px solid rgba(255,255,255,0.1);
  min-width: 210px; padding: 8px 0;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.nav__dropdown:hover .nav__drop-menu { display: block; }
.nav__drop-menu a {
  display: block; padding: 10px 22px;
  font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.5); transition: color 0.2s, padding-left 0.2s;
}
.nav__drop-menu a:hover { color: var(--white); padding-left: 28px; }

.nav__cta {
  font-size: 0.68rem !important; background: var(--emerald) !important;
  color: var(--white) !important; padding: 10px 22px !important;
  border: 1px solid var(--emerald) !important; letter-spacing: 0.18em !important;
  transition: background 0.25s, border-color 0.25s !important;
}
.nav__cta::after { display: none !important; }
.nav__cta:hover { background: var(--emerald-light) !important; border-color: var(--emerald-light) !important; }

.nav__hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px;
}
.nav__hamburger span { display: block; width: 24px; height: 1.5px; background: rgba(255,255,255,0.8); transition: transform 0.3s, opacity 0.3s; }
.nav__hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav__hamburger.open span:nth-child(2) { opacity: 0; }
.nav__hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.nav__mobile {
  display: none; position: fixed; top: var(--nav-h); left: 0; right: 0;
  background: #000000; border-bottom: 1px solid rgba(255,255,255,0.08);
  padding: 24px 48px 36px; flex-direction: column;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5); z-index: 999;
}
.nav__mobile.open { display: flex; }
.nav__mobile a {
  display: block; padding: 13px 0;
  font-size: 0.75rem; letter-spacing: 0.17em; text-transform: uppercase;
  color: rgba(255,255,255,0.55); border-bottom: 1px solid rgba(255,255,255,0.07);
}
.nav__mobile a:hover { color: var(--emerald-light); }

/* ============================================================
   FOOTER
   ============================================================ */
footer {
  background: #000000;
  padding: 72px 0 36px;
}

.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 56px;
  margin-bottom: 56px;
}

.footer__logo { height: 52px; width: auto; margin-bottom: 1.25rem; }

.footer__tagline {
  font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.3); margin-bottom: 1.5rem;
}

.footer__social { display: flex; gap: 10px; }
.footer__social a {
  width: 34px; height: 34px;
  border: 1px solid rgba(255,255,255,0.15);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.4); font-size: 0.75rem;
  font-family: var(--font-body); transition: border-color 0.25s, color 0.25s;
}
.footer__social a:hover { border-color: var(--emerald-light); color: var(--emerald-light); }

.footer__col-title {
  font-size: 0.62rem; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--emerald-light); margin-bottom: 1.1rem;
}

footer ul { display: flex; flex-direction: column; gap: 8px; }
footer ul a { font-size: 0.82rem; color: rgba(255,255,255,0.4); line-height: 1.6; transition: color 0.2s; }
footer ul a:hover { color: rgba(255,255,255,0.85); }
.footer__contact-info p { font-size: 0.82rem; color: rgba(255,255,255,0.4); line-height: 1.6; margin-bottom: 6px; }
.footer__contact-info a:hover { color: var(--emerald-light); }

.footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.07);
  padding-top: 28px; font-size: 0.73rem; color: rgba(255,255,255,0.25);
}

/* ============================================================
   CARD LINK
   ============================================================ */
.card-link {
  font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--emerald); font-family: var(--font-body); font-weight: 500;
  transition: letter-spacing 0.3s;
}
.card-link:hover { letter-spacing: 0.28em; }

/* ============================================================
   VALUE / BELIEF CARDS
   ============================================================ */
.belief-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.belief-card {
  background: var(--white); border: 1px solid var(--cream-border);
  border-left: 3px solid var(--emerald);
  padding: 36px 32px;
  transition: box-shadow 0.3s, transform 0.3s;
}
.belief-card:hover { box-shadow: 0 8px 40px rgba(45,122,79,0.07); transform: translateY(-3px); }
.belief-card h3 { font-size: 1.5rem; color: var(--charcoal); margin-bottom: 0.75rem; }
.belief-card p { font-size: 0.9rem; color: var(--text-muted); line-height: 1.8; }

/* ============================================================
   PROCESS STEPS (inner page — vertical)
   ============================================================ */
.process-phase { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; margin-bottom: 80px; }
.process-phase:last-child { margin-bottom: 0; }
.process-phase--reverse { direction: rtl; }
.process-phase--reverse > * { direction: ltr; }
.process-phase__num-block {
  width: 100%; aspect-ratio: 4/3;
  background: linear-gradient(135deg, #b8d4c4, #8db8a0);
  display: flex; align-items: center; justify-content: center;
}
.process-phase__num-block span {
  font-family: var(--font-display); font-size: 9rem; font-weight: 300;
  color: rgba(255,255,255,0.35); line-height: 1;
}
.process-phase__text h2 { color: var(--charcoal); margin-bottom: 1rem; }
.process-phase__text p { font-size: 0.93rem; color: var(--text-muted); line-height: 1.9; margin-bottom: 1rem; }

/* ── FAQ ── */
.faq-list { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 0; }
.faq-item { border-bottom: 1px solid var(--cream-border); padding: 28px 0; }
.faq-item h4 { font-family: var(--font-display); font-size: 1.3rem; color: var(--charcoal); margin-bottom: 0.75rem; }
.faq-item p { font-size: 0.9rem; color: var(--text-muted); line-height: 1.8; }

/* ============================================================
   TEAM CARDS
   ============================================================ */
.team-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 36px; }
.team-card__photo {
  width: 100%; aspect-ratio: 3/4;
  background: linear-gradient(135deg, #b8d4c4, #8db8a0);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.5rem; overflow: hidden;
}
.team-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.team-card__initials { font-family: var(--font-display); font-size: 4rem; font-weight: 300; color: rgba(44,80,60,0.3); }
.team-card__name { font-family: var(--font-display); font-size: 1.5rem; color: var(--charcoal); }
.team-card__role { font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--emerald); margin: 0.4rem 0 1rem; }
.team-card__bio { font-size: 0.88rem; color: var(--text-muted); line-height: 1.8; }

/* ============================================================
   PLANS GRID
   ============================================================ */
.plans-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.plan-card {
  background: var(--white); border: 1px solid var(--cream-border); overflow: hidden;
  transition: border-color 0.3s, box-shadow 0.3s, transform 0.3s;
}
.plan-card:hover { border-color: var(--sage-border); box-shadow: 0 8px 40px rgba(45,122,79,0.08); transform: translateY(-4px); }
.plan-card__thumb {
  width: 100%; aspect-ratio: 4/3;
  background: linear-gradient(135deg, #b8d4c4, #8db8a0);
  display: flex; align-items: center; justify-content: center;
  color: rgba(44,80,60,0.4); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; font-family: var(--font-body);
}
.plan-card__body { padding: 28px 28px 32px; }
.plan-card__name { font-family: var(--font-display); font-size: 1.7rem; color: var(--charcoal); margin-bottom: 0.5rem; }
.plan-card__specs { display: flex; gap: 20px; flex-wrap: wrap; margin-bottom: 1rem; }
.plan-card__spec { font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-light); }
.plan-card__spec strong { color: var(--emerald); font-weight: 500; }
.plan-card__desc { font-size: 0.88rem; color: var(--text-muted); line-height: 1.75; margin-bottom: 1.5rem; }

/* ============================================================
   PORTFOLIO GRID (full page)
   ============================================================ */
.portfolio-full { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; }
.pf-card {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, #b8d4c4, #8db8a0);
  cursor: pointer;
}
.pf-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s; }
.pf-card:hover img { transform: scale(1.05); }
.pf-card__inner {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 28px;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.35s;
}
.pf-card:hover .pf-card__inner { opacity: 1; }
.pf-card__name { font-family: var(--font-display); font-size: 1.3rem; color: var(--white); }
.pf-card__meta { font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.7); margin-top: 4px; }
.pf-card--a { background: linear-gradient(135deg,#b8d4c4,#8db8a0); aspect-ratio: 4/3; }
.pf-card--b { background: linear-gradient(135deg,#c8d4cc,#a8bab0); aspect-ratio: 4/3; }
.pf-card--c { background: linear-gradient(135deg,#d4cfc8,#b8b2a8); aspect-ratio: 4/3; }
.pf-card--d { background: linear-gradient(135deg,#c0ccc4,#98aaa0); aspect-ratio: 4/3; }
.pf-card--e { background: linear-gradient(135deg,#b4ccbc,#90b09c); aspect-ratio: 4/3; }
.pf-card--f { background: linear-gradient(135deg,#ccd4c8,#aab8a4); aspect-ratio: 4/3; }
.pf-card--g { background: linear-gradient(135deg,#d0cec8,#b0aea8); aspect-ratio: 4/3; }
.pf-card--h { background: linear-gradient(135deg,#bcccc4,#9ab0a8); aspect-ratio: 4/3; }
.pf-card--i { background: linear-gradient(135deg,#c4d0c8,#a0b4a8); aspect-ratio: 4/3; }

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; }
.contact-info__item { margin-bottom: 2.5rem; }
.contact-info__label { font-size: 0.65rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--emerald); margin-bottom: 0.5rem; }
.contact-info__value { font-family: var(--font-display); font-size: 1.25rem; color: var(--charcoal); line-height: 1.5; }
.contact-info__value a:hover { color: var(--emerald); }

.contact-form { display: flex; flex-direction: column; gap: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { display: flex; flex-direction: column; gap: 7px; }
.form-group label { font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-muted); }
.form-group input,
.form-group select,
.form-group textarea {
  background: var(--white); border: 1px solid var(--cream-border);
  color: var(--charcoal); padding: 13px 16px;
  font-family: var(--font-body); font-size: 0.92rem;
  outline: none; transition: border-color 0.25s; resize: vertical;
}
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--text-light); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--emerald); }
.form-group select { appearance: none; cursor: pointer; 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='%236b6b68' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px; }
.form-success { display: none; background: var(--emerald-pale); border: 1px solid var(--sage-border); padding: 16px 20px; color: var(--emerald); font-size: 0.9rem; }

/* ============================================================
   LOTS MAP
   ============================================================ */
.lots-layout { display: grid; grid-template-columns: 1fr 340px; gap: 28px; align-items: start; }
.lots-map-wrap {
  background: var(--white); border: 1px solid var(--cream-border);
  aspect-ratio: 4/3; overflow: hidden; position: relative;
}
.lots-map-wrap svg { width: 100%; height: 100%; }

.lot-poly { cursor: pointer; transition: filter 0.2s; stroke: rgba(255,255,255,0.6); stroke-width: 1.5; }
.lot-poly.available { fill: rgba(45,122,79,0.4); }
.lot-poly.sold      { fill: rgba(180,60,60,0.35); }
.lot-poly.reserved  { fill: rgba(200,160,60,0.35); }
.lot-poly:hover, .lot-poly.selected { filter: brightness(1.25); stroke-width: 2.5; stroke: var(--white); }
.lot-label { font-family: var(--font-body); font-size: 11px; font-weight: 600; fill: white; text-anchor: middle; dominant-baseline: middle; pointer-events: none; user-select: none; }

.lots-legend { display: flex; gap: 24px; margin-bottom: 16px; flex-wrap: wrap; }
.legend-item { display: flex; align-items: center; gap: 8px; font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); }
.legend-swatch { width: 18px; height: 13px; border: 1px solid var(--cream-border); }
.legend-swatch.available { background: rgba(45,122,79,0.4); }
.legend-swatch.sold      { background: rgba(180,60,60,0.4); }
.legend-swatch.reserved  { background: rgba(200,160,60,0.35); }

.lot-panel { background: var(--white); border: 1px solid var(--cream-border); padding: 32px; position: sticky; top: calc(var(--nav-h) + 20px); }
.lot-panel__placeholder { text-align: center; padding: 40px 0; color: var(--text-light); font-size: 0.85rem; line-height: 1.7; }
.lot-panel__title { font-family: var(--font-display); font-size: 2rem; color: var(--charcoal); margin-bottom: 6px; }
.lot-panel__status { display: inline-block; font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; padding: 4px 12px; margin-bottom: 1.5rem; }
.lot-panel__status.available { background: var(--emerald-pale); color: var(--emerald); }
.lot-panel__status.sold      { background: #fce8e8; color: #b43c3c; }
.lot-panel__status.reserved  { background: #fdf4e0; color: #8a6a10; }
.lot-panel__details { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 20px; margin-bottom: 1.5rem; }
.lot-detail__label { font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 3px; }
.lot-detail__value { font-family: var(--font-display); font-size: 1.25rem; color: var(--charcoal); }
.lot-panel__desc { font-size: 0.88rem; color: var(--text-muted); line-height: 1.8; border-top: 1px solid var(--cream-border); padding-top: 1.25rem; margin-bottom: 1.5rem; }

.lots-list-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 16px; margin-top: 48px; }
.lot-card { background: var(--white); border: 1px solid var(--cream-border); padding: 22px; cursor: pointer; transition: border-color 0.25s, transform 0.25s; }
.lot-card:hover { border-color: var(--emerald); transform: translateY(-3px); }
.lot-card__header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 10px; }
.lot-card__name { font-family: var(--font-display); font-size: 1.3rem; color: var(--charcoal); }
.lot-badge { font-size: 0.6rem; letter-spacing: 0.16em; text-transform: uppercase; padding: 3px 10px; }
.lot-badge.available { background: var(--emerald-pale); color: var(--emerald); }
.lot-badge.sold      { background: #fce8e8; color: #b43c3c; }
.lot-badge.reserved  { background: #fdf4e0; color: #8a6a10; }
.lot-card__specs { font-size: 0.78rem; color: var(--text-muted); display: flex; gap: 14px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
  .two-col { gap: 48px; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .team-grid { grid-template-columns: repeat(2,1fr); }
  .plans-grid { grid-template-columns: repeat(2,1fr); }
  .portfolio-full { grid-template-columns: repeat(2,1fr); }
  .belief-grid { grid-template-columns: repeat(2,1fr); }
  .lots-layout { grid-template-columns: 1fr; }
  .lot-panel { position: static; }
  .process-phase { grid-template-columns: 1fr; gap: 32px; }
  .process-phase--reverse { direction: ltr; }
}

@media (max-width: 768px) {
  :root { --nav-h: 72px; }
  .container { padding: 0 24px; }
  .section { padding: 64px 0; }
  .nav__inner { padding: 0 24px; }
  .nav__logo img { height: 48px; }
  .nav__links { display: none; }
  .nav__hamburger { display: flex; }
  .nav__mobile { padding: 20px 24px 32px; }
  .inner-hero .container { padding: 0 24px; }
  .inner-hero { padding-top: calc(var(--nav-h) + 48px); padding-bottom: 48px; }
  .two-col { grid-template-columns: 1fr; gap: 32px; }
  .two-col--reverse { direction: ltr; }
  .team-grid { grid-template-columns: 1fr; }
  .plans-grid { grid-template-columns: 1fr; }
  .portfolio-full { grid-template-columns: 1fr; }
  .belief-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .form-row { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; gap: 28px; }
  .cta-band { padding: 64px 0; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition-duration: 0.01ms !important; }
}
