:root {
    --realty-ink: #27292f;
    --realty-muted: #6d717b;
    --realty-soft: #fff7f2;
    --realty-panel: #ffffff;
    --realty-line: #eadcdf;
    --realty-red: #df1f2d;
    --realty-red-dark: #bc1521;
    --realty-gold: #f7bc24;
    --realty-teal: #0f9b8e;
    --realty-blue: #e7f8fb;
    --realty-bg: #fffaf8;
    --realty-radius: 8px;
    --realty-shadow: 0 14px 34px rgba(92, 25, 30, 0.1);
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    background: var(--realty-bg);
    color: var(--realty-ink);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.58;
    margin: 0;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
}

a {
    color: inherit;
    text-decoration: none;
}

a:hover,
a:focus {
    color: var(--realty-red);
}

button,
input,
select,
textarea {
    font: inherit;
}

img {
    display: block;
    max-width: 100%;
}

.btn {
    border-radius: 999px;
    font-weight: 800;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
}

.btn-primary {
    background: var(--realty-red);
    border: 1px solid var(--realty-red);
    box-shadow: 0 12px 24px rgba(223, 31, 45, 0.22);
    color: #ffffff;
}

.btn-primary:hover,
.btn-primary:focus {
    background: var(--realty-red-dark);
    border-color: var(--realty-red-dark);
    color: #ffffff;
}

.btn-soft,
.btn-light {
    background: #fff1f1;
    border: 1px solid #ffd1d5;
    color: var(--realty-red-dark);
}

.btn-soft:hover,
.btn-light:hover {
    background: #ffe3e5;
    border-color: #ffc4ca;
    color: var(--realty-red-dark);
}

.site-topbar {
    background: var(--realty-red);
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.9rem;
    padding: 0.55rem 0;
}

.topbar-links,
.nav-actions,
.property-type-row,
.hero-actions,
.proof-actions,
.invoice-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.topbar-links a {
    color: #ffffff;
    font-weight: 800;
}

.site-navbar {
    background: rgba(255, 255, 255, 0.96);
    border-bottom: 1px solid var(--realty-line);
    box-shadow: 0 10px 26px rgba(39, 41, 47, 0.06);
    backdrop-filter: blur(14px);
}

.brand-lockup,
.footer-brand {
    align-items: center;
    display: inline-flex;
    gap: 0.75rem;
}

.brand-mark {
    align-items: center;
    background: var(--realty-red);
    border-radius: var(--realty-radius);
    color: #ffffff;
    display: inline-flex;
    flex: 0 0 42px;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.navbar-brand strong,
.footer-brand span:last-child {
    color: var(--realty-ink);
    display: block;
    font-size: 1.18rem;
    font-weight: 900;
    line-height: 1.1;
}

.navbar-brand small {
    color: var(--realty-muted);
    display: block;
    font-size: 0.75rem;
    font-weight: 700;
}

.site-navbar .nav-link {
    color: #444852;
    font-weight: 800;
    padding-left: 0.9rem !important;
    padding-right: 0.9rem !important;
}

.site-navbar .nav-link:hover,
.site-navbar .nav-link:focus {
    color: var(--realty-red);
}

.navbar-toggler {
    border-color: #ffd4d7;
    border-radius: var(--realty-radius);
}

.menu-lines,
.menu-lines::before,
.menu-lines::after {
    background: var(--realty-ink);
    border-radius: 999px;
    display: block;
    height: 2px;
    width: 22px;
}

.menu-lines {
    margin: 0.35rem 0;
    position: relative;
}

.menu-lines::before,
.menu-lines::after {
    content: "";
    left: 0;
    position: absolute;
}

.menu-lines::before {
    top: -6px;
}

.menu-lines::after {
    top: 6px;
}

.nav-actions {
    align-items: center;
}

.icon-btn {
    align-items: center;
    background: #fff1f1;
    border: 1px solid #ffd1d5;
    border-radius: 999px;
    color: var(--realty-red-dark);
    display: inline-flex;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.hero-section {
    background:
        linear-gradient(135deg, rgba(255, 250, 248, 0.96), rgba(255, 242, 242, 0.94)),
        #fff7f4;
    padding: 4rem 0 4.5rem;
}

.hero-grid {
    align-items: center;
    display: grid;
    gap: 2rem;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.7fr);
}

.hero-content h1,
.page-hero h1,
.seller-card h1 {
    font-size: clamp(2.35rem, 5vw, 4.25rem);
    font-weight: 950;
    line-height: 1.02;
    margin-bottom: 1rem;
}

.hero-copy,
.page-hero p,
.section-heading p,
.purchase-card p,
.checkout-summary p,
.invoice-paper p,
.seller-card li,
.filter-panel,
.catalog-card p {
    color: var(--realty-muted);
}

.hero-copy {
    font-size: 1.12rem;
    max-width: 680px;
}

.eyebrow {
    color: var(--realty-red);
    font-size: 0.78rem;
    font-weight: 900;
    margin-bottom: 0.65rem;
    text-transform: uppercase;
}

.search-console {
    background: var(--realty-panel);
    border: 1px solid var(--realty-line);
    border-radius: var(--realty-radius);
    box-shadow: var(--realty-shadow);
    margin: 1.6rem 0 1rem;
    padding: 1rem;
}

.search-tabs {
    border-bottom: 1px solid var(--realty-line);
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 1rem;
    padding-bottom: 0.7rem;
}

.search-tabs button,
.catalog-filter button {
    background: transparent;
    border: 0;
    border-radius: 999px;
    color: #555965;
    font-weight: 850;
    padding: 0.55rem 0.85rem;
}

.search-tabs button.active,
.catalog-filter button.active {
    background: var(--realty-red);
    color: #ffffff;
}

.search-fields {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: minmax(180px, 1fr) minmax(150px, 0.7fr) minmax(150px, 0.7fr) auto;
}

.search-fields label,
.seller-form label,
.filter-panel label {
    color: #474b55;
    display: grid;
    font-weight: 850;
    gap: 0.35rem;
}

.search-fields span {
    font-size: 0.78rem;
    text-transform: uppercase;
}

.search-fields input,
.search-fields select,
.seller-form input,
.seller-form select,
.filter-panel input,
.filter-panel select {
    background: #ffffff;
    border: 1px solid #eadcdf;
    border-radius: var(--realty-radius);
    color: var(--realty-ink);
    min-height: 48px;
    outline: 0;
    padding: 0.72rem 0.8rem;
    width: 100%;
}

.property-type-row span {
    align-items: center;
    background: #ffffff;
    border: 1px solid var(--realty-line);
    border-radius: 999px;
    display: inline-flex;
    font-weight: 800;
    gap: 0.45rem;
    padding: 0.5rem 0.8rem;
}

.property-type-row i {
    color: var(--realty-red);
}

.hero-card,
.property-card,
.bundle-card,
.locality-grid article,
.flow-list article,
.agent-grid article,
.catalog-card,
.filter-panel,
.purchase-card,
.summary-panel,
.checkout-card,
.checkout-summary,
.invoice-paper,
.seller-card {
    background: var(--realty-panel);
    border: 1px solid var(--realty-line);
    border-radius: var(--realty-radius);
    box-shadow: 0 14px 34px rgba(39, 41, 47, 0.06);
}

.hero-card {
    overflow: hidden;
}

.hero-card img {
    aspect-ratio: 4 / 3;
    height: auto;
    object-fit: cover;
    width: 100%;
}

.hero-card div {
    padding: 1.1rem;
}

.hero-card span,
.property-body small,
.catalog-top span,
.bundle-head span,
.summary-kicker {
    color: var(--realty-red);
    display: block;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.hero-card strong {
    display: block;
    font-size: 1.25rem;
    font-weight: 900;
}

.hero-card a {
    color: var(--realty-red);
    font-weight: 900;
}

.metric-strip {
    margin-top: -2rem;
    position: relative;
    z-index: 2;
}

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

.metric-grid article {
    background: var(--realty-panel);
    border: 1px solid var(--realty-line);
    border-radius: var(--realty-radius);
    box-shadow: var(--realty-shadow);
    padding: 1rem;
    text-align: center;
}

.metric-grid strong {
    color: var(--realty-red);
    display: block;
    font-size: 1.45rem;
    font-weight: 950;
}

.metric-grid span {
    color: var(--realty-muted);
    font-size: 0.86rem;
    font-weight: 800;
}

.section-pad {
    padding: 5rem 0;
}

.section-heading {
    margin-bottom: 2rem;
    max-width: 760px;
}

.section-heading h2,
.flow-section h2,
.proof-panel h2 {
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 950;
    line-height: 1.1;
}

.property-grid,
.bundle-grid,
.locality-grid,
.agent-grid,
.catalog-grid {
    display: grid;
    gap: 1.25rem;
}

.property-grid,
.agent-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.bundle-grid,
.locality-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.property-card,
.catalog-card {
    overflow: hidden;
}

.property-image,
.catalog-image {
    display: block;
    position: relative;
}

.property-image img,
.catalog-image img {
    aspect-ratio: 16 / 10;
    object-fit: cover;
    width: 100%;
}

.property-image span,
.catalog-image span {
    background: rgba(39, 41, 47, 0.78);
    border-radius: 999px;
    bottom: 0.8rem;
    color: #ffffff;
    font-size: 0.75rem;
    font-weight: 850;
    left: 0.8rem;
    padding: 0.35rem 0.65rem;
    position: absolute;
}

.property-body,
.catalog-card {
    padding: 1rem;
}

.property-body h3,
.catalog-card h2,
.bundle-card h3,
.locality-grid h3,
.flow-list h3,
.agent-grid h3,
.checkout-summary h2 {
    font-size: 1.15rem;
    font-weight: 900;
    margin-bottom: 0.45rem;
}

.property-body strong,
.catalog-price strong {
    color: var(--realty-ink);
    display: block;
    font-size: 1.25rem;
    font-weight: 950;
}

.property-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin: 0.9rem 0;
}

.property-meta span,
.catalog-footer small {
    color: var(--realty-muted);
    font-size: 0.86rem;
    font-weight: 800;
}

.property-meta i,
.catalog-top i {
    color: var(--realty-gold);
}

.locality-section,
.faq-section,
.flow-section {
    background: #ffffff;
}

.locality-grid article {
    background: #e9fbfd;
    box-shadow: none;
    padding: 1.25rem;
}

.locality-grid span {
    color: var(--realty-teal);
    font-weight: 900;
}

.locality-grid a,
.invoice-paper footer a {
    color: var(--realty-red);
    font-weight: 900;
}

.package-highlight {
    background: linear-gradient(180deg, #fffaf8, #fff1f1);
}

.bundle-card {
    padding: 1.25rem;
}

.bundle-head {
    align-items: center;
    display: flex;
    justify-content: space-between;
}

.bundle-head i {
    color: var(--realty-red);
    font-size: 1.6rem;
}

.bundle-head span {
    background: #fff0c5;
    border-radius: 999px;
    color: #9a6400;
    padding: 0.35rem 0.65rem;
}

.bundle-price {
    color: var(--realty-red);
    font-size: 1.55rem;
    font-weight: 950;
    margin: 1rem 0;
}

.bundle-card ul,
.catalog-card ul,
.seller-card ul {
    list-style: none;
    margin: 0 0 1.2rem;
    padding: 0;
}

.bundle-card li,
.catalog-card li,
.seller-card li {
    align-items: center;
    display: flex;
    font-weight: 750;
    gap: 0.55rem;
    margin-bottom: 0.55rem;
}

.bundle-card li i,
.catalog-card li i,
.seller-card li i,
.side-list-item i {
    color: var(--realty-teal);
}

.flow-list {
    display: grid;
    gap: 0.85rem;
}

.flow-list article {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    padding: 1rem;
}

.flow-list article > span {
    align-items: center;
    background: #fff1f1;
    border-radius: 999px;
    color: var(--realty-red);
    display: inline-flex;
    flex: 0 0 42px;
    font-weight: 900;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.agent-grid article {
    padding: 1.1rem;
}

.agent-avatar {
    align-items: center;
    background: #e9fbfd;
    border-radius: 999px;
    color: var(--realty-teal);
    display: inline-flex;
    font-size: 1.3rem;
    font-weight: 950;
    height: 52px;
    justify-content: center;
    margin-bottom: 0.75rem;
    width: 52px;
}

.agent-grid small {
    color: var(--realty-teal);
    display: block;
    font-weight: 900;
}

.agent-grid article > div {
    border-top: 1px solid var(--realty-line);
    display: flex;
    gap: 1rem;
    margin-top: 1rem;
    padding-top: 1rem;
}

.agent-grid strong {
    display: grid;
    font-size: 1.3rem;
    font-weight: 950;
}

.agent-grid strong span {
    color: var(--realty-muted);
    font-size: 0.78rem;
}

.proof-section {
    padding-top: 0;
}

.proof-panel {
    align-items: center;
    background: var(--realty-red);
    border-radius: var(--realty-radius);
    box-shadow: var(--realty-shadow);
    color: #ffffff;
    display: grid;
    gap: 2rem;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.5fr);
    padding: 2.2rem;
}

.proof-panel .eyebrow,
.proof-panel p {
    color: rgba(255, 255, 255, 0.86);
}

.proof-actions {
    justify-content: flex-end;
}

.accordion {
    max-width: 920px;
}

.accordion-item {
    border-color: var(--realty-line);
    border-radius: var(--realty-radius) !important;
    margin-bottom: 0.75rem;
    overflow: hidden;
}

.accordion-button {
    color: var(--realty-ink);
    font-weight: 850;
}

.accordion-button:not(.collapsed) {
    background: #fff1f1;
    color: var(--realty-red);
}

.accordion-button:focus,
.form-control:focus,
.form-select:focus {
    border-color: #ffb7bd;
    box-shadow: 0 0 0 0.2rem rgba(223, 31, 45, 0.14);
}

.page-hero,
.detail-hero {
    background: linear-gradient(135deg, #fff2f2, #fff9ed);
    padding: 4rem 0;
}

.page-hero.compact {
    padding: 2rem 0;
}

.page-hero-grid {
    align-items: end;
    display: grid;
    gap: 2rem;
    grid-template-columns: minmax(0, 1fr) auto;
}

.flow-breadcrumb {
    align-items: center;
    color: var(--realty-muted);
    display: flex;
    flex-wrap: wrap;
    font-size: 0.9rem;
    font-weight: 800;
    gap: 0.55rem;
    margin-bottom: 1rem;
}

.flow-breadcrumb a {
    color: var(--realty-red);
}

.catalog-filter,
.flow-progress {
    align-items: center;
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid rgba(255, 255, 255, 0.84);
    border-radius: 999px;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    padding: 0.4rem;
}

.flow-progress span {
    border-radius: 999px;
    color: #565b66;
    font-weight: 850;
    padding: 0.55rem 0.85rem;
}

.flow-progress .active {
    background: var(--realty-red);
    color: #ffffff;
}

.flow-progress .done {
    background: #ffffff;
    color: var(--realty-red);
}

.listing-layout {
    align-items: start;
    display: grid;
    gap: 1.25rem;
    grid-template-columns: 280px minmax(0, 1fr);
}

.filter-panel {
    display: grid;
    gap: 0.9rem;
    padding: 1rem;
    position: sticky;
    top: 96px;
}

.filter-panel h2 {
    font-size: 1.25rem;
    font-weight: 950;
    margin: 0;
}

.side-list-item {
    align-items: center;
    display: flex;
    font-weight: 800;
    gap: 0.55rem;
}

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

.catalog-card.is-hidden {
    display: none;
}

.catalog-top {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin: 1rem 0 0.4rem;
}

.catalog-price {
    margin: 1rem 0;
}

.catalog-price span {
    color: var(--realty-muted);
    display: block;
    font-weight: 800;
}

.catalog-footer {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-top: auto;
}

.detail-gallery {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: 2fr 1fr 1fr 1fr;
}

.detail-gallery img {
    aspect-ratio: 4 / 3;
    border-radius: var(--realty-radius);
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.detail-gallery-main {
    grid-column: span 2;
}

.detail-heading {
    align-items: end;
    background: var(--realty-panel);
    border: 1px solid var(--realty-line);
    border-radius: var(--realty-radius);
    box-shadow: var(--realty-shadow);
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-top: 1rem;
    padding: 1.2rem;
}

.detail-heading h1 {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 950;
}

.detail-price {
    text-align: right;
}

.detail-price span {
    color: var(--realty-red);
    display: block;
    font-size: 1.5rem;
    font-weight: 950;
}

.purchase-section,
.checkout-section,
.invoice-section {
    background: var(--realty-bg);
}

.purchase-grid,
.checkout-grid {
    align-items: start;
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(0, 1fr) 360px;
}

.purchase-card,
.summary-panel,
.checkout-card,
.checkout-summary {
    padding: 1.4rem;
}

.purchase-card + .purchase-card {
    margin-top: 1rem;
}

.purchase-card h2,
.checkout-card h1 {
    font-size: 1.55rem;
    font-weight: 950;
}

.detail-grid,
.field-grid,
.choice-grid,
.floor-plan-row {
    display: grid;
    gap: 0.8rem;
}

.detail-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 1.2rem;
}

.detail-grid span,
.floor-plan-row div {
    background: #fff7f2;
    border: 1px solid var(--realty-line);
    border-radius: var(--realty-radius);
    color: var(--realty-muted);
    display: block;
    font-size: 0.86rem;
    font-weight: 800;
    padding: 0.85rem;
}

.detail-grid strong,
.floor-plan-row strong {
    color: var(--realty-ink);
    display: block;
}

.feature-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-top: 1rem;
}

.feature-cloud span {
    align-items: center;
    background: #e9fbfd;
    border-radius: 999px;
    color: #24535a;
    display: inline-flex;
    font-weight: 850;
    gap: 0.45rem;
    padding: 0.46rem 0.75rem;
}

.feature-cloud i {
    color: var(--realty-teal);
}

.floor-plan-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.floor-plan-row small {
    color: var(--realty-muted);
    display: block;
}

.summary-panel,
.checkout-summary {
    position: sticky;
    top: 96px;
}

.summary-lines {
    border-bottom: 1px solid var(--realty-line);
    border-top: 1px solid var(--realty-line);
    margin: 1rem 0;
    padding: 0.5rem 0;
}

.summary-lines p,
.total-line,
.invoice-total p {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin: 0;
    padding: 0.55rem 0;
}

.summary-lines span,
.total-line span,
.invoice-total span {
    color: var(--realty-muted);
    font-weight: 800;
}

.checkout-main {
    display: grid;
    gap: 1rem;
}

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

.field-grid label {
    color: #444852;
    display: grid;
    font-weight: 850;
    gap: 0.35rem;
}

.choice-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.choice-tile {
    border: 1px solid var(--realty-line);
    border-radius: var(--realty-radius);
    cursor: pointer;
    display: grid;
    gap: 0.25rem;
    padding: 0.9rem;
}

.choice-tile input {
    accent-color: var(--realty-red);
}

.choice-tile span,
.choice-tile strong {
    display: block;
}

.choice-tile strong {
    color: var(--realty-red);
}

.checkout-summary table,
.invoice-table {
    border-collapse: collapse;
    width: 100%;
}

.checkout-summary td {
    border-bottom: 1px solid var(--realty-line);
    padding: 0.9rem 0;
    vertical-align: top;
}

.checkout-summary td:last-child {
    color: var(--realty-ink);
    font-weight: 900;
    text-align: right;
    white-space: nowrap;
}

.checkout-summary td span {
    color: var(--realty-muted);
    display: block;
    font-size: 0.84rem;
}

.total-line {
    font-size: 1.2rem;
    margin: 0.6rem 0 1rem;
}

.invoice-actions {
    justify-content: flex-end;
    margin-bottom: 1rem;
}

.invoice-paper {
    margin: 0 auto;
    max-width: 920px;
    padding: 2rem;
}

.invoice-paper header,
.invoice-meta,
.invoice-paper footer {
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.invoice-paper header {
    border-bottom: 1px solid var(--realty-line);
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
}

.invoice-paper header > div:first-child {
    align-items: center;
    display: flex;
    gap: 0.8rem;
}

.invoice-paper h1 {
    font-size: 1.8rem;
    font-weight: 950;
    margin: 0;
}

.invoice-id {
    text-align: right;
}

.invoice-id span,
.invoice-id small,
.invoice-meta span {
    color: var(--realty-muted);
    display: block;
    font-weight: 800;
}

.invoice-id strong {
    display: block;
    font-size: 1.25rem;
}

.invoice-meta {
    background: #fff7f2;
    border: 1px solid var(--realty-line);
    border-radius: var(--realty-radius);
    margin-bottom: 1.5rem;
    padding: 1rem;
}

.invoice-table th,
.invoice-table td {
    border-bottom: 1px solid var(--realty-line);
    padding: 0.9rem;
    text-align: left;
}

.invoice-table th {
    background: #fff1f1;
    color: #444852;
    font-size: 0.84rem;
    text-transform: uppercase;
}

.invoice-table td:last-child,
.invoice-table th:last-child {
    text-align: right;
}

.invoice-total {
    margin: 1rem 0 1.5rem auto;
    max-width: 360px;
}

.invoice-total .grand {
    border-top: 2px solid var(--realty-ink);
    color: var(--realty-ink);
    font-size: 1.15rem;
}

.invoice-paper footer {
    border-top: 1px solid var(--realty-line);
    padding-top: 1rem;
}

.seller-section {
    background: linear-gradient(135deg, #fff7f2, #ffffff);
    padding: 4rem 0;
}

.seller-grid {
    align-items: start;
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(0, 1fr) minmax(340px, 0.65fr);
}

.seller-visual {
    background: #ffffff;
    border: 1px solid var(--realty-line);
    border-radius: var(--realty-radius);
    overflow: hidden;
}

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

.seller-card {
    padding: clamp(1.2rem, 4vw, 2rem);
}

.seller-form {
    display: grid;
    gap: 0.9rem;
    margin-top: 1rem;
}

.site-footer {
    background: #2a2020;
    color: rgba(255, 255, 255, 0.76);
    padding: 3.4rem 0 1.3rem;
}

.footer-grid {
    display: grid;
    gap: 2rem;
    grid-template-columns: 1.3fr repeat(3, minmax(0, 0.7fr));
}

.footer-brand {
    color: #ffffff;
    margin-bottom: 1rem;
}

.site-footer .footer-brand span:last-child {
    color: #ffffff;
}

.site-footer h3 {
    color: #ffffff;
    font-size: 0.9rem;
    font-weight: 900;
    margin-bottom: 1rem;
    text-transform: uppercase;
}

.site-footer a:not(.footer-brand) {
    color: rgba(255, 255, 255, 0.72);
    display: block;
    font-weight: 750;
    margin-bottom: 0.55rem;
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: space-between;
    margin-top: 2rem;
    padding-top: 1.2rem;
}

@media (max-width: 991.98px) {
    .site-navbar .navbar-collapse {
        padding: 1rem 0;
    }

    .hero-grid,
    .metric-grid,
    .property-grid,
    .bundle-grid,
    .locality-grid,
    .agent-grid,
    .listing-layout,
    .catalog-grid,
    .purchase-grid,
    .checkout-grid,
    .footer-grid,
    .page-hero-grid,
    .proof-panel,
    .seller-grid {
        grid-template-columns: 1fr;
    }

    .search-fields {
        grid-template-columns: 1fr 1fr;
    }

    .filter-panel,
    .summary-panel,
    .checkout-summary {
        position: static;
    }

    .proof-actions {
        justify-content: flex-start;
    }

    .detail-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .site-topbar {
        text-align: center;
    }

    .hero-section {
        padding: 3rem 0;
    }

    .section-pad {
        padding: 3.5rem 0;
    }

    .search-fields,
    .choice-grid,
    .field-grid,
    .payment-grid,
    .detail-grid,
    .floor-plan-row {
        grid-template-columns: 1fr;
    }

    .detail-heading,
    .invoice-paper header,
    .invoice-meta,
    .invoice-paper footer,
    .invoice-actions {
        align-items: flex-start;
        flex-direction: column;
    }

    .detail-price,
    .invoice-id {
        text-align: left;
    }

    .invoice-paper {
        padding: 1.1rem;
    }

    .invoice-table {
        font-size: 0.88rem;
    }
}
