:root {
  --sage-deep: #052d30;
  --sage: #0f6868;
  --sage-grey: #5aa9a3;
  --sage-soft: #f59a23;
  --mist: #f5efe2;
  --cream: #fff8ea;
  --brass: #f59a23;
  --ink: #09272a;
  --glass: rgba(5, 45, 48, .78);
  --line: rgba(255, 248, 234, .3);
  --shadow: 0 24px 80px rgba(0, 0, 0, .34);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  scroll-behavior: smooth;
  font-family: "Helvetica Neue", Arial, sans-serif;
  color: var(--cream);
  background: var(--sage-deep);
}

body {
  overflow-x: hidden;
}

a {
  color: inherit;
}

.page {
  position: relative;
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto auto auto auto;
  background: var(--sage-deep);
}

.urgency {
  position: relative;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 16px;
  color: var(--cream);
  background: #052d30;
  border-bottom: 1px solid rgba(245, 154, 35, .5);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: .13em;
  text-align: center;
  text-transform: uppercase;
}

.urgency a {
  margin: 0 .35em;
  color: #ffb347;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

.urgency-mobile {
  display: none;
}

.hero {
  position: relative;
  width: 100%;
  min-height: 0;
  isolation: isolate;
  overflow: hidden;
  background: #052d30;
}

.hero::after {
  content: none;
}

.plan {
  position: relative;
  width: 100%;
  max-width: 100%;
  aspect-ratio: 968 / 595;
  overflow: hidden;
  background: #0d595b;
}

.plan img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  filter: none;
}

.topbar {
  position: relative;
  z-index: 3;
  min-height: 92px;
  padding: 12px clamp(18px, 4vw, 48px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  border-bottom: 1px solid var(--line);
  background: rgba(5, 45, 48, .86);
  backdrop-filter: blur(12px);
}

.logo-link,
.brand-script,
.lot-brand {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  text-decoration: none;
}

.brand-script,
.lot-brand {
  color: var(--cream);
  font-family: Verdana, Geneva, Tahoma, sans-serif;
  font-size: clamp(18px, 2.4vw, 30px);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: .02em;
  text-shadow: 0 8px 24px rgba(0, 0, 0, .28);
}

.lot-brand {
  font-size: clamp(18px, 2.2vw, 28px);
}

.site-logo {
  display: block;
  width: min(260px, 48vw);
  max-height: 78px;
  object-fit: contain;
  filter: drop-shadow(0 8px 22px rgba(0, 0, 0, .28));
}

.top-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.lot-select-label {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 12px;
  border: 1px solid rgba(247, 241, 223, .32);
  border-radius: 4px;
  color: var(--cream);
  background: rgba(5, 45, 48, .36);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  white-space: nowrap;
}

.lot-select {
  min-height: 32px;
  border: 1px solid rgba(247, 241, 223, .24);
  border-radius: 4px;
  padding: 0 8px;
  color: var(--cream);
  background: #0f6868;
  font-weight: 800;
}

.pill,
.button {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .1em;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.pill {
  padding: 0 14px;
  border: 1px solid rgba(247, 241, 223, .38);
  color: var(--cream);
  background: rgba(247, 241, 223, .08);
}

.button {
  padding: 0 18px;
  border: 1px solid var(--brass);
  color: #09272a;
  background: var(--brass);
}

.button.secondary {
  color: var(--cream);
  background: #0f6868;
  border-color: #5ec7bd;
}

.lot-overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.image-blurb {
  position: absolute;
  top: clamp(14px, 2.8vw, 34px);
  left: clamp(14px, 3.4vw, 44px);
  z-index: 4;
  width: min(460px, calc(100% - 28px));
  padding: clamp(18px, 2.6vw, 28px);
  border: 1px solid rgba(255, 248, 234, .56);
  border-radius: 8px;
  color: #09272a;
  background:
    linear-gradient(135deg, rgba(255, 248, 234, .92), rgba(245, 239, 226, .82)),
    linear-gradient(90deg, rgba(94, 199, 189, .24), rgba(245, 154, 35, .18));
  box-shadow: 0 22px 64px rgba(0, 0, 0, .32);
  backdrop-filter: blur(10px);
}

.hero-logo {
  display: block;
  width: min(350px, 90%);
  max-height: clamp(150px, 22vw, 230px);
  margin: 0 auto clamp(12px, 2vw, 18px);
  object-fit: contain;
  filter: drop-shadow(0 10px 24px rgba(5, 45, 48, .22));
}

.image-blurb h1 {
  margin: 0 0 10px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(19px, 2.35vw, 32px);
  font-weight: 500;
  line-height: 1.04;
  letter-spacing: 0;
  text-align: center;
}

.image-blurb h1 span {
  display: block;
}

.image-blurb h1 span:nth-child(2) {
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: 0;
  line-height: inherit;
}

.image-blurb p {
  margin: 0;
  color: rgba(9, 39, 42, .74);
  font-size: 12px;
  line-height: 1.45;
  text-align: center;
}

.concept-disclaimer {
  position: absolute;
  right: clamp(12px, 2.5vw, 28px);
  bottom: clamp(12px, 2.5vw, 28px);
  z-index: 4;
  max-width: min(360px, calc(100% - 24px));
  margin: 0;
  padding: 9px 12px;
  border: 1px solid rgba(247, 241, 223, .24);
  border-radius: 4px;
  color: #fff;
  background: rgba(5, 45, 48, .62);
  font-size: 11px;
  line-height: 1.35;
  box-shadow: 0 10px 28px rgba(0, 0, 0, .22);
  backdrop-filter: blur(6px);
}

.hero-links {
  margin-top: 16px;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.mobile-hero-actions {
  display: none;
}

.mobile-concept-disclaimer {
  display: none;
}

.hero-link {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 14px;
  border: 1px solid rgba(247, 241, 223, .38);
  border-radius: 4px;
  color: var(--cream);
  background: rgba(5, 45, 48, .58);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .1em;
  text-decoration: none;
  text-transform: uppercase;
}

.listing-dropdown {
  position: relative;
  display: inline-flex;
}

.listing-dropdown .mls-link {
  cursor: pointer;
}

.listing-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 8;
  min-width: 190px;
  padding: 8px;
  border: 1px solid rgba(247, 241, 223, .2);
  border-radius: 6px;
  background: rgba(5, 45, 48, .96);
  box-shadow: 0 18px 44px rgba(0, 0, 0, .38);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
}

.listing-dropdown:hover .listing-menu,
.listing-dropdown:focus-within .listing-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.listing-option {
  min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 4px;
  color: var(--cream);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-decoration: none;
  text-transform: uppercase;
}

.listing-option:hover,
.listing-option:focus {
  background: rgba(247, 241, 223, .12);
}

.listing-option.disabled {
  color: rgba(255, 255, 255, .68);
  background: rgba(118, 125, 118, .34);
  cursor: not-allowed;
}

.mls-link {
  border-color: #d71920;
  color: #fff;
  background: #d71920;
}

.mls-button {
  border-color: #d71920;
  color: #fff;
  background: #d71920;
}

.mls-button.disabled {
  border-color: rgba(118, 125, 118, .78);
  color: rgba(255, 255, 255, .78);
  background: #767d76;
  cursor: not-allowed;
  pointer-events: none;
}

.icon-link svg {
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
}

.lot-link {
  cursor: pointer;
  outline: none;
  pointer-events: auto;
}

.lot {
  opacity: 0;
  fill: rgba(255, 255, 255, .001);
  stroke: rgba(255, 255, 255, .96);
  stroke-width: 2;
  vector-effect: non-scaling-stroke;
  transition: opacity .22s ease, fill .22s ease, stroke-width .22s ease, filter .22s ease;
}

.lot-link:focus .lot,
.lot-link:hover .lot {
  opacity: 1;
  fill: rgba(255, 255, 255, .18);
  stroke-width: 2;
  filter: drop-shadow(0 8px 18px rgba(0, 0, 0, .55));
}

.lot-label {
  pointer-events: none;
  font-family: "EB Garamond", "Bodoni 72", Didot, Georgia, serif;
  font-size: 24px;
  font-weight: 500;
  fill: #fff;
  letter-spacing: .03em;
  opacity: 0;
  text-anchor: middle;
  dominant-baseline: middle;
  text-shadow: 0 2px 10px rgba(0, 0, 0, .68);
  transition: opacity .22s ease;
}

.lot-unavailable-label {
  pointer-events: none;
  font-family: Arial, sans-serif;
  font-size: 6px;
  font-weight: 900;
  fill: #fff;
  letter-spacing: .1em;
  opacity: 0;
  text-anchor: middle;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .82);
  transition: opacity .22s ease;
}

.lot-link:focus .lot-label,
.lot-link:hover .lot-label,
.lot-link:focus .lot-unavailable-label,
.lot-link:hover .lot-unavailable-label {
  opacity: 1;
}

.lot-info-panel {
  position: absolute;
  top: clamp(14px, 2.8vw, 34px);
  right: clamp(14px, 3.4vw, 44px);
  z-index: 4;
  width: min(340px, calc(100% - 28px));
  padding: clamp(16px, 2.4vw, 24px);
  border: 1px solid rgba(255, 248, 234, .56);
  border-radius: 8px;
  color: #09272a;
  background:
    linear-gradient(135deg, rgba(255, 248, 234, .94), rgba(245, 239, 226, .84)),
    linear-gradient(90deg, rgba(94, 199, 189, .22), rgba(245, 154, 35, .16));
  box-shadow: 0 22px 64px rgba(0, 0, 0, .28);
  backdrop-filter: blur(10px);
}

.lot-info-panel h2 {
  margin: 0 0 8px;
  font-family: "EB Garamond", "Bodoni 72", Didot, Georgia, serif;
  font-size: clamp(38px, 4vw, 58px);
  font-weight: 500;
  line-height: .9;
  letter-spacing: .02em;
}

.lot-info-kicker,
.lot-info-type {
  margin: 0 0 10px;
  color: #0f6868;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.lot-info-type {
  color: #f59a23;
}

.lot-info-panel p:not(.lot-info-kicker):not(.lot-info-type) {
  margin: 0;
  color: rgba(9, 39, 42, .76);
  font-size: 13px;
  line-height: 1.5;
}

.lot-info-panel ul {
  margin: 12px 0;
  padding: 0;
  display: grid;
  gap: 7px;
  list-style: none;
}

.lot-info-panel li {
  padding: 8px 10px;
  border-left: 2px solid #f59a23;
  color: rgba(9, 39, 42, .86);
  background: rgba(94, 199, 189, .16);
  font-size: 13px;
  font-weight: 700;
}

.home-info {
  padding: clamp(18px, 4vw, 42px);
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, .8fr);
  gap: clamp(20px, 4vw, 48px);
  align-items: start;
  background: var(--sage-deep);
}

.intro,
.contact,
.contact-copy,
.contact-form {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--glass);
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
}

.intro {
  max-width: 620px;
  padding: 22px 24px;
}

.intro h1 {
  margin: 0 0 8px;
  color: var(--cream);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0;
}

.intro p {
  margin: 0;
  max-width: 560px;
  color: rgba(247, 241, 223, .82);
  font-size: 15px;
  line-height: 1.6;
}

.contact {
  min-width: min(360px, 100%);
  padding: 18px;
}

.contact-copy {
  padding: clamp(22px, 4vw, 42px);
}

.section-kicker {
  margin: 0 0 12px;
  color: var(--brass);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.contact-copy h2,
.contact-form h2 {
  margin: 0 0 16px;
  color: var(--cream);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(30px, 4vw, 52px);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: 0;
}

.contact-copy p:not(.section-kicker) {
  margin: 0 0 14px;
  max-width: 720px;
  color: rgba(247, 241, 223, .82);
  font-size: 16px;
  line-height: 1.68;
}

.contact-form {
  padding: clamp(20px, 3vw, 32px);
}

.contact-form h2 {
  font-size: clamp(28px, 3vw, 38px);
}

.contact-form label {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
  color: rgba(247, 241, 223, .82);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  border: 1px solid rgba(247, 241, 223, .22);
  border-radius: 4px;
  padding: 12px;
  color: var(--cream);
  background: rgba(5, 45, 48, .72);
  font: inherit;
}

.contact-form textarea {
  resize: vertical;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: 2px solid rgba(245, 154, 35, .72);
  outline-offset: 2px;
}

.contact-form .button {
  width: 100%;
  border: 0;
  cursor: pointer;
}

.thank-you {
  position: fixed;
  inset: 0;
  z-index: 20;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(8, 18, 14, .62);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
}

.thank-you.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.thank-you > div {
  position: relative;
  width: min(460px, 100%);
  padding: 28px;
  border: 1px solid rgba(247, 241, 223, .28);
  border-radius: 8px;
  color: var(--cream);
  background: linear-gradient(135deg, #052d30, #0f6868);
  box-shadow: var(--shadow);
}

.thank-you button {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(247, 241, 223, .26);
  border-radius: 4px;
  color: var(--cream);
  background: transparent;
  cursor: pointer;
  font-size: 24px;
}

.thank-you h2 {
  margin: 0 0 8px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 34px;
  font-weight: 500;
}

.thank-you p {
  margin: 0;
  color: rgba(247, 241, 223, .8);
  line-height: 1.5;
}

.contact strong {
  display: block;
  margin-bottom: 6px;
  color: var(--brass);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.contact a {
  color: var(--cream);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 26px;
  line-height: 1.05;
  text-decoration: none;
}

.hint {
  margin-top: 12px;
  color: rgba(247, 241, 223, .72);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.lot-page {
  min-height: 100vh;
  color: var(--ink);
  background:
    radial-gradient(circle at 18% 10%, rgba(113, 147, 137, .38), transparent 34%),
    linear-gradient(135deg, #d7e4dd 0%, #c0d2cb 46%, #e9ecd8 100%);
}

.lots-gallery-page {
  min-height: 100vh;
  color: var(--cream);
  background:
    radial-gradient(circle at 10% 0%, rgba(245, 154, 35, .18), transparent 34%),
    linear-gradient(135deg, #052d30 0%, #0f6868 52%, #f5efe2 100%);
}

.gallery-topbar {
  position: sticky;
  top: 0;
}

.gallery-main {
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(28px, 5vw, 64px) 18px 70px;
}

.gallery-intro {
  margin-bottom: 26px;
}

.gallery-intro h1 {
  margin: 0 0 10px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(38px, 6vw, 76px);
  font-weight: 500;
  line-height: .95;
  letter-spacing: 0;
}

.gallery-intro p:last-child {
  max-width: 680px;
  margin: 0;
  color: rgba(247, 241, 223, .78);
  font-size: 17px;
  line-height: 1.55;
}

.lot-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.lot-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(247, 241, 223, .2);
  border-radius: 8px;
  color: var(--cream);
  background: rgba(5, 45, 48, .78);
  box-shadow: 0 18px 52px rgba(0, 0, 0, .24);
  text-decoration: none;
  transition: transform .16s ease, border-color .16s ease;
}

.lot-card:hover,
.lot-card:focus {
  border-color: rgba(245, 154, 35, .72);
  transform: translateY(-3px);
}

.lot-card img {
  width: 100%;
  aspect-ratio: 16 / 10;
  display: block;
  object-fit: contain;
  padding: 10px;
  background: #fff;
}

.card-image-wrap {
  position: relative;
  display: block;
}

.card-unavailable-banner {
  position: absolute;
  left: 0;
  right: 0;
  top: 42%;
  padding: 8px 10px;
  color: #fff;
  background: rgba(5, 45, 48, .58);
  font-size: clamp(18px, 2.8vw, 34px);
  font-weight: 900;
  letter-spacing: .12em;
  text-align: center;
  text-shadow: 0 3px 14px rgba(0, 0, 0, .55);
  pointer-events: none;
}

.lot-card div {
  padding: 18px;
}

.lot-card-kicker {
  margin: 0 0 8px;
  color: var(--brass);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.lot-card h2 {
  margin: 0 0 12px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 34px;
  font-weight: 500;
  letter-spacing: 0;
}

.lot-card ul {
  margin: 0;
  padding: 0;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  list-style: none;
}

.lot-card li {
  padding: 7px 9px;
  border-radius: 4px;
  color: rgba(247, 241, 223, .86);
  background: rgba(247, 241, 223, .08);
  font-size: 13px;
  font-weight: 700;
}

.image-manager-page {
  min-height: 100vh;
  color: var(--cream);
  background: linear-gradient(135deg, #052d30, #0f6868);
}

.image-manager {
  max-width: 1120px;
  margin: 0 auto;
  padding: clamp(28px, 5vw, 64px) 18px;
}

.manager-panel {
  padding: clamp(22px, 4vw, 42px);
  border: 1px solid rgba(247, 241, 223, .22);
  border-radius: 8px;
  background: rgba(5, 45, 48, .76);
  box-shadow: var(--shadow);
}

.manager-panel h1 {
  margin: 0 0 12px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(40px, 6vw, 72px);
  font-weight: 500;
  letter-spacing: 0;
}

.manager-copy {
  max-width: 760px;
  color: rgba(247, 241, 223, .78);
  line-height: 1.6;
}

.manager-controls,
.manager-preview {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 24px;
}

.manager-controls label {
  display: grid;
  gap: 8px;
  color: rgba(247, 241, 223, .8);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.manager-controls select,
.manager-preview input {
  min-height: 42px;
  border: 1px solid rgba(247, 241, 223, .24);
  border-radius: 4px;
  padding: 10px;
  color: var(--cream);
  background: rgba(5, 45, 48, .72);
}

.manager-preview > div,
.manager-output {
  padding: 16px;
  border: 1px solid rgba(247, 241, 223, .18);
  border-radius: 8px;
  background: rgba(247, 241, 223, .06);
}

.manager-preview h2,
.manager-output h2 {
  margin: 0 0 12px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 26px;
  font-weight: 500;
}

.manager-preview img {
  width: 100%;
  aspect-ratio: 16 / 10;
  display: block;
  margin-top: 12px;
  object-fit: cover;
  background: #052d30;
}

.manager-output {
  margin-top: 18px;
}

#destination {
  padding: 12px;
  border-radius: 4px;
  color: #fff;
  background: rgba(0, 0, 0, .24);
  font-family: Consolas, "Courier New", monospace;
}

.lot-main {
  transition: transform .24s ease, opacity .24s ease;
}

.lot-main.slide-left {
  opacity: .82;
  transform: translateX(-7vw);
}

.lot-main.slide-right {
  opacity: .82;
  transform: translateX(7vw);
}

.page-arrow {
  position: fixed;
  top: 50%;
  z-index: 12;
  width: 52px;
  height: 72px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(247, 241, 223, .38);
  border-radius: 6px;
  color: var(--cream);
  background: rgba(5, 45, 48, .78);
  box-shadow: 0 12px 32px rgba(5, 45, 48, .24);
  backdrop-filter: blur(8px);
  font-size: 30px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  transform: translateY(-50%);
  transition: background .16s ease, transform .16s ease;
}

.page-arrow:hover,
.page-arrow:focus {
  background: #0f6868;
  transform: translateY(-50%) scale(1.05);
}

.page-arrow-left {
  left: 16px;
}

.page-arrow-right {
  right: 16px;
}

.lot-header {
  position: sticky;
  top: 0;
  z-index: 4;
  min-height: 92px;
  padding: 12px clamp(18px, 4vw, 48px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  background: rgba(63, 75, 67, .95);
  box-shadow: 0 12px 34px rgba(5, 45, 48, .18);
}

.lot-main {
  max-width: 1120px;
  margin: 0 auto;
  padding: clamp(28px, 5vw, 64px) 18px 56px;
}

.lot-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, .75fr);
  gap: clamp(22px, 4vw, 48px);
  align-items: start;
}

.carousel {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: var(--sage);
  box-shadow: 0 18px 60px rgba(5, 45, 48, .22);
}

.slides {
  display: flex;
  transition: transform .25s ease;
}

.slide {
  flex: 0 0 100%;
  width: 100%;
  height: clamp(360px, 48vw, 620px);
  min-height: 0;
  display: grid;
  place-items: center;
  padding: 28px;
  color: var(--cream);
  text-align: center;
  background:
    linear-gradient(rgba(5, 45, 48, .58), rgba(5, 45, 48, .44)),
    url("assets/simple-plan.jpg") center / cover;
}

.slide:nth-child(2) {
  background:
    linear-gradient(rgba(5, 45, 48, .62), rgba(5, 45, 48, .5)),
    url("assets/warkdale-site-plan.jpg") center / cover;
}

.slide:nth-child(3) {
  background:
    linear-gradient(135deg, rgba(5, 45, 48, .95), rgba(245, 154, 35, .5));
}

.slide span {
  display: inline-flex;
  padding: 12px 16px;
  border: 1px solid rgba(247, 241, 223, .42);
  border-radius: 4px;
  color: var(--cream);
  background: rgba(5, 45, 48, .62);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.slide.has-image {
  padding: 0;
  background: #052d30;
}

.slide.has-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  background: #052d30;
}

.slide.site-plan-slide {
  background: #fff;
}

.slide.site-plan-slide img {
  object-fit: contain;
  padding: 16px;
  background: #fff;
}

.carousel-controls {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  background: var(--sage-deep);
}

.unavailable-banner {
  position: absolute;
  left: 0;
  right: 0;
  top: 42%;
  z-index: 3;
  padding: clamp(12px, 2vw, 22px);
  color: #fff;
  background: rgba(5, 45, 48, .58);
  font-size: clamp(23px, 4.5vw, 59px);
  font-weight: 900;
  letter-spacing: .12em;
  text-align: center;
  text-transform: uppercase;
  text-shadow: 0 4px 18px rgba(0, 0, 0, .55);
  pointer-events: none;
}

.carousel-controls button {
  min-width: 44px;
  min-height: 38px;
  border: 1px solid rgba(247, 241, 223, .28);
  border-radius: 4px;
  color: var(--cream);
  background: rgba(247, 241, 223, .08);
  cursor: pointer;
  font-size: 20px;
}

.counter {
  color: rgba(247, 241, 223, .72);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.lot-image-disclaimer {
  grid-column: 1;
  margin: -28px 0 0;
  padding: 9px 12px;
  border: 1px solid rgba(247, 241, 223, .2);
  border-radius: 4px;
  color: #fff;
  background: rgba(5, 45, 48, .46);
  font-size: 11px;
  line-height: 1.35;
}

.lot-copy {
  grid-column: 2;
  grid-row: 1 / span 2;
  padding: clamp(20px, 3vw, 34px);
  border: 1px solid rgba(5, 45, 48, .16);
  border-radius: 8px;
  background: rgba(247, 241, 223, .78);
  box-shadow: 0 18px 50px rgba(5, 45, 48, .12);
}

.lot-kicker {
  margin: 0 0 10px;
  color: var(--sage);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.lot-copy h1 {
  margin: 0 0 14px;
  color: var(--sage-deep);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(42px, 6vw, 70px);
  font-weight: 500;
  line-height: .95;
  letter-spacing: 0;
}

.lot-copy p {
  margin: 0 0 18px;
  color: #475249;
  font-size: 16px;
  line-height: 1.65;
}

.facts {
  margin: 0 0 22px;
  padding: 0;
  display: grid;
  gap: 10px;
  list-style: none;
}

.facts li {
  padding: 12px 14px;
  border-left: 3px solid var(--brass);
  color: #334037;
  background: rgba(94, 199, 189, .18);
}

.lot-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

@media (max-width: 840px) {
  body {
    background: #052d30;
  }

  .page-arrow {
    display: none;
  }

  .urgency {
    padding: 9px 12px;
    font-size: 10px;
    letter-spacing: .08em;
  }

  .topbar,
  .lot-header {
    align-items: stretch;
    flex-direction: column;
    gap: 12px;
    min-height: 0;
  }

  .brand-script,
  .lot-brand {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .top-actions {
    width: 100%;
    flex-wrap: wrap;
  }

  .pill,
  .button {
    flex: 1 1 0;
    min-width: 0;
    padding-inline: 10px;
    text-align: center;
    white-space: normal;
  }

  .home-info,
  .lot-grid,
  .lot-card-grid {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .lot-copy,
  .lot-image-disclaimer {
    grid-column: 1;
    grid-row: auto;
  }

  .plan {
    aspect-ratio: 968 / 595;
    min-height: 0;
    overflow: hidden;
  }

  .plan > img {
    height: 100%;
    object-fit: cover;
    background: #052d30;
  }

  .image-blurb {
    display: none;
  }

  .lot-info-panel {
    display: none;
  }

  .concept-disclaimer {
    display: none;
  }

  .mobile-concept-disclaimer {
    display: block;
    margin: 0;
    padding: 9px 12px;
    border: 1px solid rgba(247, 241, 223, .24);
    color: #fff;
    background: rgba(5, 45, 48, .88);
    font-size: 11px;
    line-height: 1.35;
  }

  .mobile-hero-actions {
    padding: 12px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    background: #052d30;
  }

  .slide {
    height: clamp(300px, 72vw, 500px);
  }

  .gallery-main {
    padding-inline: 14px;
  }

  .gallery-intro h1 {
    font-size: clamp(34px, 10vw, 54px);
  }

  .lot-card-grid {
    gap: 14px;
  }

  .intro,
  .contact {
    padding: 16px;
  }

  .contact a {
    font-size: 22px;
  }
}

@media (max-width: 560px) {
  .urgency {
    display: grid;
    gap: 2px;
    justify-items: center;
    padding: 10px 12px;
    font-size: 11px;
    line-height: 1.25;
  }

  .urgency-desktop {
    display: none;
  }

  .urgency-mobile {
    display: block;
  }

  .urgency-mobile:first-of-type {
    font-size: 10px;
  }

  .urgency a.urgency-mobile {
    margin: 0;
    color: #d71920;
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
  }

  .hero {
    min-height: 0;
  }

  .plan {
    width: 100vw;
    min-height: 0;
  }

  .plan > img {
    height: 100%;
    object-position: center;
  }

  .brand-script {
    font-size: clamp(17px, 5.4vw, 24px);
  }

  .top-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .topbar,
  .lot-header {
    padding: 12px;
  }

  .mobile-concept-disclaimer {
    font-size: 10px;
  }

  .hero-link {
    min-height: 38px;
    padding-inline: 10px;
    font-size: 11px;
  }

  .listing-option {
    min-height: 34px;
    font-size: 11px;
  }

  .lot-overlay {
    display: block;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
  }

  .plan.mobile-lots-visible .lot-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .plan.mobile-lots-visible .lot,
  .plan.mobile-lots-visible .lot-label {
    opacity: 1;
  }

  .plan.mobile-lots-visible .lot {
    fill: rgba(255, 255, 255, .1);
    stroke-width: 2;
  }

  .mobile-lots-hint {
    display: block;
  }

  .intro h1 {
    font-size: 28px;
  }

  .intro p {
    font-size: 14px;
  }

  .home-info {
    padding: 12px;
    gap: 10px;
  }

  .lot-main,
  .gallery-main {
    padding: 18px 12px 36px;
  }

  .gallery-intro {
    margin-bottom: 18px;
  }

  .gallery-intro h1 {
    font-size: 34px;
    line-height: 1;
  }

  .gallery-intro p:last-child {
    font-size: 14px;
  }

  .lot-card h2 {
    font-size: 28px;
  }

  .lot-card div {
    padding: 14px;
  }

  .lot-card img {
    aspect-ratio: 4 / 3;
    padding: 8px;
  }

  .slide {
    height: 330px;
  }

  .carousel-controls {
    padding: 9px;
  }

  .lot-image-disclaimer {
    margin-top: -18px;
    font-size: 10px;
  }

  .lot-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .lot-select-label {
    width: 100%;
    justify-content: space-between;
    white-space: normal;
  }
}

@media (hover: none) and (pointer: coarse) {
  .lot-overlay {
    opacity: 0;
    pointer-events: none;
  }

  .plan.mobile-lots-visible .lot-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .plan.mobile-lots-visible .lot,
  .plan.mobile-lots-visible .lot-label {
    opacity: 1;
  }

  .plan.mobile-lots-visible .lot {
    fill: rgba(255, 255, 255, .1);
    stroke-width: 2;
  }
}

.mobile-lots-hint {
  display: none;
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 5;
  margin: 0;
  padding: 9px 12px;
  border: 1px solid rgba(247, 241, 223, .24);
  border-radius: 4px;
  color: #fff;
  background: rgba(5, 45, 48, .68);
  font-size: 11px;
  line-height: 1.35;
  text-align: center;
}

@media (hover: none) and (pointer: coarse) {
  .mobile-lots-hint {
    display: block;
  }

  .plan.mobile-lots-visible .mobile-lots-hint {
    display: none;
  }
}
