:root {
    color-scheme: light;
    --bg: #f5f7fb;
    --surface-1: #ffffff;
    --surface-2: #f0f4f8;
    --surface-3: #e4ebf5;
    --border: #d6deea;
    --text: #142033;
    --text-muted: #5f6f85;
    --accent: #2563eb;
    --accent-hover: #1d4ed8;
    --success: #15803d;
    --warning: #b45309;
    --danger: #b91c1c;
    --shadow-sm: 0 1px 2px rgba(20, 32, 51, 0.06);
    --shadow-md: 0 14px 34px rgba(20, 32, 51, 0.1);
    --control-bg: #ffffff;
    --control-active-bg: #f0f4f8;
    --brand-border: rgba(37, 99, 235, 0.28);
    --brand-bg: rgba(37, 99, 235, 0.08);
    --success-pill-bg: rgba(21, 128, 61, 0.08);
    --success-pill-border: rgba(21, 128, 61, 0.22);
    --warning-pill-bg: rgba(245, 158, 11, 0.1);
    --warning-pill-border: rgba(180, 83, 9, 0.24);
    --danger-pill-bg: rgba(239, 68, 68, 0.08);
    --danger-pill-border: rgba(185, 28, 28, 0.22);
    --hover-bg: rgba(37, 99, 235, 0.06);
    --hover-border: rgba(37, 99, 235, 0.38);
    --stat-bg: rgba(240, 244, 248, 0.82);
    --floating-panel-bg: rgba(255, 255, 255, 0.9);
    --floating-panel-border: rgba(214, 222, 234, 0.84);
    --overview-bg: #f0f4f8;
    --overview-image-filter: saturate(0.96) brightness(0.96) contrast(1.02);
    --plot-available-fill: rgba(21, 128, 61, 0.24);
    --plot-available-stroke: rgba(20, 32, 51, 0.72);
    --plot-reserved-fill: rgba(245, 158, 11, 0.3);
    --plot-reserved-stroke: rgba(120, 53, 15, 0.78);
    --plot-sold-fill: rgba(185, 28, 28, 0.26);
    --plot-sold-stroke: rgba(127, 29, 29, 0.72);
    --plot-label-main: #142033;
    --plot-label-meta: rgba(20, 32, 51, 0.92);
    --plot-label-stroke: rgba(255, 255, 255, 0.86);
    --map-tile-filter: none;
    --map-control-bg: rgba(255, 255, 255, 0.96);
    --radius-sm: 8px;
    --radius-md: 12px;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) {
        color-scheme: dark;
        --bg: #080c12;
        --surface-1: #0d131c;
        --surface-2: #111a25;
        --surface-3: #172231;
        --border: #243143;
        --text: #f4f7fb;
        --text-muted: #94a3b8;
        --accent: #3b82f6;
        --accent-hover: #60a5fa;
        --success: #86efac;
        --warning: #fcd34d;
        --danger: #fca5a5;
        --shadow-sm: none;
        --shadow-md: 0 0 0 2px rgba(59, 130, 246, 0.14);
        --control-bg: #0d131c;
        --control-active-bg: #172231;
        --brand-border: rgba(96, 165, 250, 0.42);
        --brand-bg: rgba(59, 130, 246, 0.16);
        --success-pill-bg: rgba(34, 197, 94, 0.12);
        --success-pill-border: rgba(34, 197, 94, 0.28);
        --warning-pill-bg: rgba(245, 158, 11, 0.12);
        --warning-pill-border: rgba(245, 158, 11, 0.32);
        --danger-pill-bg: rgba(239, 68, 68, 0.12);
        --danger-pill-border: rgba(239, 68, 68, 0.32);
        --hover-bg: rgba(59, 130, 246, 0.12);
        --hover-border: rgba(96, 165, 250, 0.58);
        --stat-bg: rgba(17, 26, 37, 0.72);
        --floating-panel-bg: rgba(8, 12, 18, 0.82);
        --floating-panel-border: rgba(148, 163, 184, 0.22);
        --overview-bg: #07101a;
        --overview-image-filter: saturate(0.86) brightness(0.68) contrast(1.06);
        --plot-available-fill: rgba(34, 197, 94, 0.25);
        --plot-available-stroke: rgba(226, 232, 240, 0.72);
        --plot-reserved-fill: rgba(15, 23, 42, 0.58);
        --plot-reserved-stroke: rgba(226, 232, 240, 0.7);
        --plot-sold-fill: rgba(15, 23, 42, 0.66);
        --plot-sold-stroke: rgba(226, 232, 240, 0.62);
        --plot-label-main: #f4f7fb;
        --plot-label-meta: rgba(226, 232, 240, 0.94);
        --plot-label-stroke: rgba(8, 12, 18, 0.82);
        --map-tile-filter: invert(0.86) hue-rotate(180deg) saturate(0.58) brightness(0.88) contrast(0.92);
        --map-control-bg: rgba(17, 26, 37, 0.94);
    }
}

:root[data-theme="dark"] {
    color-scheme: dark;
    --bg: #080c12;
    --surface-1: #0d131c;
    --surface-2: #111a25;
    --surface-3: #172231;
    --border: #243143;
    --text: #f4f7fb;
    --text-muted: #94a3b8;
    --accent: #3b82f6;
    --accent-hover: #60a5fa;
    --success: #86efac;
    --warning: #fcd34d;
    --danger: #fca5a5;
    --shadow-sm: none;
    --shadow-md: 0 0 0 2px rgba(59, 130, 246, 0.14);
    --control-bg: #0d131c;
    --control-active-bg: #172231;
    --brand-border: rgba(96, 165, 250, 0.42);
    --brand-bg: rgba(59, 130, 246, 0.16);
    --success-pill-bg: rgba(34, 197, 94, 0.12);
    --success-pill-border: rgba(34, 197, 94, 0.28);
    --warning-pill-bg: rgba(245, 158, 11, 0.12);
    --warning-pill-border: rgba(245, 158, 11, 0.32);
    --danger-pill-bg: rgba(239, 68, 68, 0.12);
    --danger-pill-border: rgba(239, 68, 68, 0.32);
    --hover-bg: rgba(59, 130, 246, 0.12);
    --hover-border: rgba(96, 165, 250, 0.58);
    --stat-bg: rgba(17, 26, 37, 0.72);
    --floating-panel-bg: rgba(8, 12, 18, 0.82);
    --floating-panel-border: rgba(148, 163, 184, 0.22);
    --overview-bg: #07101a;
    --overview-image-filter: saturate(0.86) brightness(0.68) contrast(1.06);
    --plot-available-fill: rgba(34, 197, 94, 0.25);
    --plot-available-stroke: rgba(226, 232, 240, 0.72);
    --plot-reserved-fill: rgba(15, 23, 42, 0.58);
    --plot-reserved-stroke: rgba(226, 232, 240, 0.7);
    --plot-sold-fill: rgba(15, 23, 42, 0.66);
    --plot-sold-stroke: rgba(226, 232, 240, 0.62);
    --plot-label-main: #f4f7fb;
    --plot-label-meta: rgba(226, 232, 240, 0.94);
    --plot-label-stroke: rgba(8, 12, 18, 0.82);
    --map-tile-filter: invert(0.86) hue-rotate(180deg) saturate(0.58) brightness(0.88) contrast(0.92);
    --map-control-bg: rgba(17, 26, 37, 0.94);
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
}

a {
    color: var(--accent);
    text-decoration: none;
}

a:hover {
    color: var(--accent-hover);
}

:focus-visible {
    outline: 2px solid var(--accent-hover);
    outline-offset: 3px;
}

.topbar,
.page,
.footer {
    width: min(76rem, calc(100vw - 2rem));
    margin: 0 auto;
}

.topbar {
    min-height: 4.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid var(--border);
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--text);
    font-weight: 800;
}

.brand span {
    width: 2.15rem;
    height: 2.15rem;
    display: grid;
    place-items: center;
    border: 1px solid var(--brand-border);
    border-radius: var(--radius-sm);
    background: var(--brand-bg);
    color: var(--accent);
}

.brand img {
    width: 2.4rem;
    height: 2.4rem;
    border-radius: var(--radius-sm);
    object-fit: contain;
    background: var(--surface-2);
}

.topbar nav {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
}

.topbar nav a,
.back-link,
.footer {
    color: var(--text-muted);
}

.topbar-dropdown {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.topbar-dropdown > a {
    color: var(--text-muted);
}

.topbar-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 30;
    min-width: 12rem;
    display: none;
    padding: 0.65rem 0.35rem 0.35rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-1);
    background-clip: padding-box;
    box-shadow: var(--shadow);
}

.topbar-dropdown:hover .topbar-dropdown-menu,
.topbar-dropdown:focus-within .topbar-dropdown-menu {
    display: grid;
}

.topbar-dropdown-menu a {
    border-radius: calc(var(--radius-sm) - 2px);
    padding: 0.58rem 0.7rem;
    color: var(--text);
    white-space: nowrap;
}

.topbar-dropdown-menu a:hover,
.topbar-dropdown-menu a:focus-visible {
    background: var(--surface-2);
}

.topbar-call {
    min-height: 2.45rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--accent);
    border-radius: var(--radius-sm);
    padding: 0 0.85rem;
    background: var(--accent);
    color: #fff !important;
    font-weight: 900;
    box-shadow: 0 10px 22px rgba(37, 99, 235, 0.24);
    white-space: nowrap;
}

.topbar-call:hover {
    background: var(--accent-hover);
    color: #fff !important;
}

.install-button {
    min-height: 2.35rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0 0.78rem;
    background: var(--control-bg);
    color: var(--text);
    cursor: pointer;
    font: inherit;
    font-size: 0.88rem;
    font-weight: 800;
}

.install-button:hover {
    background: var(--surface-2);
}

.language-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.18rem;
    background: var(--control-bg);
}

.language-switch a {
    min-width: 2rem;
    border-radius: calc(var(--radius-sm) - 2px);
    padding: 0.3rem 0.45rem;
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-align: center;
}

.language-switch a.active {
    background: var(--control-active-bg);
    box-shadow: var(--shadow-sm);
    color: var(--text);
}

.theme-switch {
    width: 3.6rem;
    height: 2.25rem;
    display: inline-grid;
    place-items: center;
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 0;
    background: var(--control-bg);
    color: var(--text-muted);
    cursor: pointer;
}

.theme-switch-track {
    position: relative;
    width: 3.05rem;
    height: 1.7rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
}

.theme-switch-thumb {
    position: absolute;
    inset: 0.12rem auto 0.12rem 0.12rem;
    width: 1.46rem;
    border-radius: 999px;
    background: var(--accent);
    transition: transform 160ms ease;
}

:root[data-theme="dark"] .theme-switch-thumb {
    transform: translateX(1.35rem);
}

.theme-switch-icon {
    position: relative;
    z-index: 1;
    display: grid;
    place-items: center;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1;
}

.theme-switch-light {
    color: #ffffff;
}

.theme-switch-dark {
    color: var(--text-muted);
}

:root[data-theme="dark"] .theme-switch-light {
    color: var(--text-muted);
}

:root[data-theme="dark"] .theme-switch-dark {
    color: #ffffff;
}

.page {
    display: grid;
    gap: 1.2rem;
    padding: 1.4rem 0 1.8rem;
}

.hero,
.detail-hero,
.contact-band,
.panel,
.offer-card,
.filters {
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--surface-1);
    box-shadow: var(--shadow-sm);
}

.hero,
.detail-hero {
    padding: clamp(1.5rem, 5vw, 3.5rem);
    background: var(--surface-1);
}

.hero-with-banner {
    position: relative;
    overflow: hidden;
    min-height: clamp(26rem, 52vw, 38rem);
    display: flex;
    align-items: end;
    background-image:
        linear-gradient(90deg, rgba(7, 13, 22, 0.9), rgba(7, 13, 22, 0.52) 48%, rgba(7, 13, 22, 0.18)),
        var(--hero-banner-image);
    background-position: center;
    background-size: cover;
}

:root[data-theme="light"] .hero-with-banner {
    background-image:
        linear-gradient(90deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.6) 48%, rgba(255, 255, 255, 0.22)),
        var(--hero-banner-image);
}

.hero-with-banner > div {
    max-width: 44rem;
}

.page-heading {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid var(--border);
    padding: 0.5rem 0 1rem;
}

.page-heading h1 {
    margin: 0.45rem 0 0.45rem;
    font-size: clamp(2rem, 4vw, 3.4rem);
}

.eyebrow,
.type-pill {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border: 1px solid var(--success-pill-border);
    border-radius: 999px;
    padding: 0.24rem 0.65rem;
    background: var(--success-pill-bg);
    color: var(--success);
    font-size: 0.78rem;
    font-weight: 800;
}

h1,
h2,
h3,
p {
    margin-top: 0;
}

h1 {
    max-width: 48rem;
    margin-bottom: 0.8rem;
    font-size: clamp(2.1rem, 5vw, 4.1rem);
    line-height: 1;
    letter-spacing: 0;
}

.hero p,
.detail-hero p,
.muted {
    color: var(--text-muted);
}

.hero-points,
.section-head,
.card-bottom,
.contact-band,
.footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.hero-points {
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-top: 1.25rem;
    color: var(--text-muted);
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.35rem;
}

.contact-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.65rem;
}

.footer > div {
    display: grid;
    gap: 0.2rem;
}

.footer-contact {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.5rem 1rem;
}

.footer-contact a {
    color: var(--text);
    font-weight: 700;
}

.filters {
    display: grid;
    grid-template-columns: minmax(14rem, 1.3fr) repeat(4, minmax(8.5rem, 1fr)) auto;
    gap: 0.75rem;
    align-items: end;
    padding: 0.85rem;
    color: var(--text-muted);
}

.filters label {
    min-width: 0;
    display: grid;
    gap: 0.35rem;
}

.filters span {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.filters input,
.filters select {
    width: 100%;
    min-height: 2.75rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-2);
    color: var(--text);
    padding: 0.65rem 0.75rem;
}

.filter-actions {
    display: flex;
    gap: 0.5rem;
}

.button {
    min-height: 2.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.65rem 1rem;
    color: var(--text);
    font-weight: 800;
}

.button.primary {
    border-color: var(--accent);
    background: var(--accent);
    color: #ffffff;
}

.offer-grid,
.set-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    align-items: stretch;
}

.offer-discovery {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(17rem, 0.8fr);
    gap: 1rem;
    align-items: stretch;
}

.map-browse-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.75fr) minmax(20rem, 0.75fr);
    gap: 1rem;
    align-items: stretch;
}

.map-browse-map,
.map-browse-list {
    align-content: start;
}

.map-browse-map .public-offer-overview-map {
    height: min(68vh, 44rem);
    min-height: 38rem;
}

.map-offer-list {
    display: grid;
    gap: 0.6rem;
    max-height: min(68vh, 44rem);
    overflow: auto;
    padding-right: 0.15rem;
}

.map-offer-link {
    display: grid;
    gap: 0.35rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.8rem;
    background: var(--surface-2);
    color: var(--text);
}

.map-offer-link:hover,
.map-offer-link:focus-visible {
    border-color: var(--hover-border);
    background: var(--hover-bg);
    color: var(--text);
}

.map-offer-link .type-pill {
    font-size: 0.68rem;
}

.map-offer-link strong {
    line-height: 1.25;
}

.map-offer-link small {
    color: var(--text-muted);
}

.map-offer-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    color: var(--text-muted);
}

.map-offer-meta b {
    color: var(--text);
}

.map-offer-meta em {
    font-style: normal;
    font-size: 0.8rem;
}

.compact-discovery {
    grid-template-columns: 1fr;
}

.section-head.compact {
    align-items: start;
    margin-bottom: 0.4rem;
}

.section-head.compact h2 {
    margin-bottom: 0;
}

.discovery-map-card,
.place-list-card {
    align-content: start;
}

.public-offer-overview-map {
    height: min(62vh, 38rem);
    min-height: 34rem;
}

.place-list {
    display: grid;
    gap: 0.55rem;
}

.place-link {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.25rem 0.75rem;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.75rem;
    background: var(--surface-2);
    color: var(--text);
}

.place-link:hover,
.place-link:focus-visible {
    border-color: var(--hover-border);
    background: var(--hover-bg);
    color: var(--text);
}

.place-link span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    font-weight: 800;
    white-space: nowrap;
}

.place-link strong {
    color: var(--accent);
    font-size: 0.86rem;
}

.place-link small {
    grid-column: 1 / -1;
    color: var(--text-muted);
}

.offer-card {
    display: grid;
    grid-template-rows: auto 1fr;
    height: 100%;
    overflow: hidden;
    color: var(--text);
    transition:
        border-color 140ms ease,
        background-color 140ms ease,
        box-shadow 140ms ease,
        transform 140ms ease;
}

.offer-card:hover,
.offer-card:focus-visible {
    border-color: var(--hover-border);
    background: var(--surface-2);
    color: var(--text);
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
}

.offer-card:active {
    transform: translateY(0);
}

.set-card {
    display: grid;
    grid-template-rows: auto 1fr;
    height: 100%;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--surface-1);
    color: var(--text);
    box-shadow: var(--shadow-sm);
}

.set-card:hover,
.set-card:focus-visible {
    border-color: var(--hover-border);
    background: var(--surface-2);
    color: var(--text);
    box-shadow: var(--shadow-md);
}

.set-card img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    background: var(--surface-2);
}

.set-card > div {
    display: grid;
    grid-template-rows: auto auto auto 1fr auto;
    gap: 0.65rem;
    padding: 1rem;
}

.set-card h3,
.set-card p {
    margin: 0;
}

.set-card p,
.set-card small {
    color: var(--text-muted);
    line-height: 1.45;
}

.set-card-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.45rem;
    align-self: end;
}

.set-card-stats span {
    display: grid;
    gap: 0.15rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.5rem;
    background: var(--stat-bg);
    color: var(--text-muted);
    font-size: 0.78rem;
}

.set-card-stats strong {
    color: var(--text);
}

.offer-card:hover .button,
.offer-card:focus-visible .button {
    border-color: var(--hover-border);
    background: var(--hover-bg);
}

.card-photo {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    background: var(--overview-bg);
}

.photo-empty,
.card-photo.empty {
    display: grid;
    place-items: center;
    color: var(--text-muted);
}

.card-body,
.panel {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
}

.offer-card .card-body {
    grid-template-rows: auto auto auto 1fr auto;
}

.card-body h3 {
    margin-bottom: 0;
    line-height: 1.22;
    overflow-wrap: anywhere;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.location {
    color: var(--text-muted);
    margin-bottom: 0;
    overflow-wrap: anywhere;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.card-facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-self: start;
    gap: 0.5rem;
}

.card-facts span {
    display: grid;
    gap: 0.2rem;
    min-width: 0;
    color: var(--text-muted);
    font-size: 0.82rem;
}

.card-facts strong {
    overflow-wrap: anywhere;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.card-facts strong,
.card-bottom strong,
.price-card strong {
    color: var(--text);
}

.card-bottom {
    align-self: end;
}

.detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(19rem, 23rem);
    gap: 1.2rem;
    align-items: start;
}

.detail-main,
.detail-side {
    display: grid;
    gap: 1rem;
    min-width: 0;
}

.set-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 24rem);
    gap: 1rem;
    align-items: start;
}

.set-map-panel {
    padding: 0;
    overflow: hidden;
    background: var(--overview-bg);
}

.set-overview {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 10;
    min-height: 24rem;
    overflow: hidden;
    background: var(--surface-2);
}

.set-overview img,
.set-overview svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.set-overview img {
    object-fit: cover;
    filter: var(--overview-image-filter);
}

.set-overview svg {
    pointer-events: none;
}

.set-overview a {
    pointer-events: auto;
    cursor: pointer;
}

.set-overview-count {
    position: absolute;
    z-index: 3;
    top: 1rem;
    left: 1rem;
    border: 1px solid var(--floating-panel-border);
    border-radius: var(--radius-sm);
    padding: 0.55rem 0.75rem;
    background: var(--floating-panel-bg);
    color: var(--text);
    font-size: 0.9rem;
    font-weight: 800;
}

.set-area-polygon {
    fill: var(--plot-available-fill);
    stroke: var(--plot-available-stroke);
    stroke-dasharray: 0.9 0.65;
    stroke-width: 0.42;
    vector-effect: non-scaling-stroke;
    transition: fill 140ms ease, stroke 140ms ease, stroke-width 140ms ease;
}

.set-overview a:hover .set-area-polygon,
.set-overview a:focus-visible .set-area-polygon,
.set-area-polygon.active {
    fill-opacity: 0.5;
    stroke: var(--accent);
    stroke-dasharray: none;
    stroke-width: 0.85;
}

.set-area-reserved {
    fill: var(--plot-reserved-fill);
    stroke: var(--plot-reserved-stroke);
}

.set-area-sold {
    fill: var(--plot-sold-fill);
    stroke: var(--plot-sold-stroke);
}

.set-area-label {
    pointer-events: none;
}

.set-area-label-main {
    fill: var(--plot-label-main);
    font-size: 2.25px;
    font-weight: 900;
    paint-order: stroke;
    stroke: var(--plot-label-stroke);
    stroke-linejoin: round;
    stroke-width: 0.7;
}

.set-area-label-meta {
    fill: var(--plot-label-meta);
    font-size: 1.45px;
    font-weight: 650;
    paint-order: stroke;
    stroke: var(--plot-label-stroke);
    stroke-width: 0.42;
}

.set-area-status-bg {
    fill: rgba(21, 128, 61, 0.92);
    stroke: rgba(255, 255, 255, 0.58);
    stroke-width: 0.15;
}

.set-area-reserved + .set-area-label .set-area-status-bg {
    fill: rgba(180, 83, 9, 0.94);
    stroke: rgba(255, 255, 255, 0.58);
}

.set-area-sold + .set-area-label .set-area-status-bg {
    fill: rgba(185, 28, 28, 0.9);
    stroke: rgba(255, 255, 255, 0.54);
}

.set-area-status-text {
    fill: #ffffff;
    font-size: 1.05px;
    font-weight: 850;
}

.set-overview-footer {
    position: absolute;
    z-index: 3;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.set-overview-legend,
.set-overview-hint {
    min-height: 2.6rem;
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--floating-panel-border);
    border-radius: var(--radius-sm);
    background: var(--floating-panel-bg);
    color: var(--text);
}

.set-overview-legend {
    gap: 1rem;
    padding: 0.55rem 0.75rem;
}

.set-overview-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: var(--text);
    font-size: 0.9rem;
}

.set-overview-legend i {
    width: 0.85rem;
    height: 0.85rem;
    border-radius: 999px;
}

.legend-available {
    background: var(--success);
}

.legend-reserved {
    background: var(--warning);
}

.legend-sold {
    background: var(--danger);
}

.set-overview-hint {
    padding: 0.55rem 0.8rem;
    color: var(--text-muted);
    font-size: 0.88rem;
}

.set-area-list,
.set-description {
    align-content: start;
}

.set-description {
    grid-column: 1 / -1;
}

.set-area-items {
    display: grid;
    gap: 0.65rem;
}

.set-area-row {
    display: grid;
    gap: 0.65rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.85rem;
    background: var(--surface-2);
    color: var(--text);
}

.set-area-row:hover,
.set-area-row:focus-visible {
    border-color: var(--hover-border);
    background: var(--hover-bg);
    color: var(--text);
}

.set-area-row > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.set-area-row strong {
    color: var(--text);
}

.set-area-row dl {
    display: grid;
    gap: 0.35rem;
    margin: 0;
}

.set-area-row dl div {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    color: var(--text-muted);
}

.set-area-row dd {
    margin: 0;
    color: var(--text);
    font-weight: 800;
}

.gallery {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--surface-1);
}

.detail-photo {
    display: block;
    width: 100%;
    height: min(55vh, 32rem);
    object-fit: cover;
}

.gallery .photo-empty {
    display: grid;
    place-items: center;
    width: 100%;
    min-height: 18rem;
    padding: 1.5rem;
    color: var(--text-muted);
    text-align: center;
}

.gallery .photo-empty strong,
.gallery .photo-empty span {
    display: block;
}

.gallery .photo-empty strong {
    color: var(--text);
}

.gallery-radio {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.gallery-radio:not(:checked) + .gallery-slide {
    display: none;
}

.gallery-count {
    position: absolute;
    top: 0.9rem;
    right: 0.9rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.4rem 0.55rem;
    background: var(--floating-panel-bg);
    color: var(--text);
    font-weight: 700;
}

.thumbs {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

.thumbs label {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 10;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    overflow: hidden;
}

.thumbs label:hover,
.thumbs label:focus-within {
    border-color: var(--hover-border);
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.12);
}

.thumbs img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.price-card {
    position: sticky;
    top: 1rem;
}

.price-card span {
    color: var(--text-muted);
}

.price-card small {
    color: var(--text-muted);
}

.price-card strong {
    font-size: clamp(1.8rem, 4vw, 2.6rem);
}

.offer-public-hero {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 0 0.35rem;
}

.offer-public-hero h1 {
    margin: 0.45rem 0 0.4rem;
}

.offer-location-line {
    color: var(--text-muted);
    font-weight: 650;
}

.offer-hero-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, max-content));
    gap: 0.8rem;
    margin-top: 1.1rem;
}

.offer-hero-metrics span {
    display: grid;
    gap: 0.2rem;
    min-width: 8.5rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.75rem 0.9rem;
    background: var(--stat-bg);
    color: var(--text-muted);
    font-size: 0.82rem;
}

.offer-hero-metrics strong {
    color: var(--text);
    font-size: 1rem;
}

.offer-public-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.offer-preview-location {
    margin: 0;
    color: var(--text);
    font-size: 1.1rem;
    font-weight: 800;
}

.preline {
    white-space: pre-line;
    line-height: 1.65;
}

.facts {
    display: grid;
    gap: 0.7rem;
    margin: 0;
}

.facts div {
    display: grid;
    grid-template-columns: minmax(7rem, 1fr) minmax(0, 1fr);
    gap: 1rem;
}

.facts dt {
    color: var(--text-muted);
}

.facts dd {
    margin: 0;
    text-align: right;
    font-weight: 800;
}

.status-pill {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 1.7rem;
    border: 1px solid var(--success-pill-border);
    border-radius: 999px;
    padding: 0.22rem 0.65rem;
    background: var(--success-pill-bg);
    color: var(--success);
    font-size: 0.78rem;
    font-weight: 800;
}

.status-pill.tone-warning {
    border-color: var(--warning-pill-border);
    background: var(--warning-pill-bg);
    color: var(--warning);
}

.status-pill.tone-danger {
    border-color: var(--danger-pill-border);
    background: var(--danger-pill-bg);
    color: var(--danger);
}

.map-preview {
    position: relative;
    min-height: 11rem;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-2);
}

.offer-map-panel {
    display: grid;
    gap: 0.85rem;
}

.offer-map-panel .map-preview {
    min-height: clamp(30rem, 55vw, 42rem);
}

.public-offer-map,
.public-offer-overview-map {
    background: var(--surface-2);
}

.public-offer-overview-map .leaflet-container,
.public-offer-map .leaflet-container {
    min-height: inherit;
}

.public-offer-overview-map .leaflet-container,
.public-offer-map .leaflet-container,
.public-offer-overview-map .leaflet-control-attribution,
.public-offer-map .leaflet-control-attribution,
.public-offer-overview-map .leaflet-popup-content-wrapper,
.public-offer-map .leaflet-popup-content-wrapper,
.public-offer-overview-map .leaflet-popup-tip,
.public-offer-map .leaflet-popup-tip {
    background: var(--surface-1);
    color: var(--text);
}

.public-offer-overview-map .leaflet-tile-pane,
.public-offer-map .leaflet-tile-pane {
    filter: var(--map-tile-filter);
}

.public-offer-overview-map .leaflet-control-attribution,
.public-offer-map .leaflet-control-attribution {
    border-top-left-radius: var(--radius-sm);
    color: var(--text-muted);
}

.public-offer-overview-map .leaflet-control-attribution a,
.public-offer-map .leaflet-control-attribution a,
.public-offer-overview-map .leaflet-popup-content a,
.public-offer-map .leaflet-popup-content a {
    color: var(--accent-hover);
}

.public-offer-overview-map .leaflet-control-zoom a,
.public-offer-map .leaflet-control-zoom a {
    border-color: var(--border);
    background: var(--map-control-bg);
    color: var(--text);
}

.public-offer-overview-map .leaflet-control-zoom a:hover,
.public-offer-map .leaflet-control-zoom a:hover {
    background: var(--surface-3);
}

.map-empty {
    display: grid;
    place-items: center;
    min-height: inherit;
    padding: 1rem;
    color: var(--text-muted);
    text-align: center;
}

.map-preview > span {
    position: absolute;
    left: 52%;
    top: 47%;
    width: 1.35rem;
    height: 1.35rem;
    border: 0.3rem solid rgba(96, 165, 250, 0.28);
    border-radius: 999px;
    background: var(--accent);
    transform: translate(-50%, -50%);
}

.contact-band {
    padding: 1.2rem 1.4rem;
}

.footer {
    min-height: 4rem;
    border-top: 1px solid var(--border);
}

.empty {
    display: grid;
    place-items: center;
    min-height: 50vh;
    text-align: center;
}

.empty-inline {
    min-height: 6rem;
    display: grid;
    place-items: center;
    border: 1px dashed var(--border);
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    text-align: center;
}

@media (max-width: 900px) {
    .offer-grid,
    .set-grid,
    .detail-layout,
    .set-detail-layout,
    .offer-public-grid,
    .offer-discovery,
    .map-browse-layout,
    .filters {
        grid-template-columns: 1fr;
    }

    .map-offer-list {
        max-height: none;
        overflow: visible;
        padding-right: 0;
    }

    .offer-public-hero {
        display: grid;
        align-items: start;
    }

    .price-card {
        position: static;
    }

    .public-offer-overview-map,
    .map-browse-map .public-offer-overview-map {
        height: 28rem;
        min-height: 28rem;
    }

    .set-overview {
        min-height: 22rem;
    }
}

@media (max-width: 620px) {
    .topbar,
    .section-head,
    .page-heading,
    .card-bottom,
    .contact-band,
    .footer {
        align-items: stretch;
        flex-direction: column;
    }

    .filter-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .topbar nav {
        width: 100%;
        flex-wrap: wrap;
        justify-content: space-between;
    }

    .topbar-call {
        width: 100%;
        min-height: 3rem;
        order: -1;
    }

    .hero-actions,
    .hero-actions .button,
    .page-heading .button {
        width: 100%;
    }

    .hero-points,
    .card-facts,
    .set-card-stats,
    .thumbs,
    .offer-hero-metrics {
        grid-template-columns: 1fr;
    }

    .detail-photo {
        height: 20rem;
    }

    .gallery .photo-empty {
        min-height: 13rem;
    }

    .facts div {
        grid-template-columns: 1fr;
        gap: 0.2rem;
    }

    .facts dd {
        text-align: left;
    }
}
