:root {
    color-scheme: light;
    --bg: #f4f7fb;
    --bg-strong: #ebf0f6;
    --surface: #ffffff;
    --surface-alt: #f8fbff;
    --surface-soft: #fff7f8;
    --surface-muted: #f6f8fb;
    --text: #1f2430;
    --text-strong: #11151d;
    --text-muted: #5c6470;
    --text-soft: #7b8491;
    --border: #e3e7ee;
    --border-strong: #d2d9e3;
    --accent: #ff385c;
    --accent-deep: #d92d50;
    --accent-soft: #fff0f3;
    --teal: #12746b;
    --teal-soft: #e8f7f4;
    --sky-soft: #eaf4ff;
    --gold-soft: #fff5da;
    --radius-sm: 6px;
    --radius: 8px;
    --shadow-sm: 0 10px 24px rgba(15, 23, 42, 0.05);
    --shadow-md: 0 20px 50px rgba(15, 23, 42, 0.07), 0 2px 8px rgba(15, 23, 42, 0.04);
    --shadow-lg: 0 28px 70px rgba(15, 23, 42, 0.08), 0 8px 24px rgba(15, 23, 42, 0.05);
    --focus-ring: 0 0 0 3px rgba(255, 56, 92, 0.18);
}

html {
    box-sizing: border-box;
    min-height: 100%;
    font-size: 16px;
}

*,
*::before,
*::after {
    box-sizing: inherit;
}

[hidden] {
    display: none !important;
}

.visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

html:focus-within {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: Inter, "Segoe UI", "Segoe UI Variable", system-ui, -apple-system, BlinkMacSystemFont, Arial, sans-serif;
    line-height: 1.6;
    color: var(--text);
    background:
        radial-gradient(circle at 12% 6%, rgba(255, 56, 92, 0.08), transparent 26rem),
        radial-gradient(circle at 92% 8%, rgba(18, 116, 107, 0.08), transparent 24rem),
        linear-gradient(180deg, #fbfdff 0%, #f4f7fb 38%, #eef2f7 100%);
}

body::before,
body::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: -1;
}

body::before {
    background:
        radial-gradient(circle at 18% 18%, rgba(255, 56, 92, 0.06), transparent 18rem),
        radial-gradient(circle at 78% 82%, rgba(18, 116, 107, 0.07), transparent 24rem);
}

body::after {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0)),
        radial-gradient(circle at center, rgba(255, 255, 255, 0.36), rgba(255, 255, 255, 0));
    opacity: 0.8;
}

img,
picture,
video,
canvas,
svg {
    display: block;
    max-width: 100%;
}

a {
    color: inherit;
    text-decoration: none;
    transition: color 0.22s ease, border-color 0.22s ease, background-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0;
    color: var(--text-strong);
    line-height: 1.08;
    letter-spacing: 0;
    text-wrap: balance;
}

h1 {
    font-size: clamp(2.45rem, 4vw, 4.35rem);
    font-weight: 700;
}

h2 {
    font-size: clamp(1.7rem, 2.7vw, 2.6rem);
    font-weight: 700;
}

h3 {
    font-size: clamp(1.15rem, 2vw, 1.45rem);
    font-weight: 650;
}

p,
li,
label,
input,
select,
textarea,
button,
th,
td,
dt,
dd {
    font-size: 1rem;
}

p {
    margin: 0;
    color: var(--text-muted);
    text-wrap: pretty;
}

ul,
ol {
    margin: 0;
    padding-left: 1.15rem;
    color: var(--text-muted);
}

strong,
b {
    color: var(--text-strong);
}

small {
    font-size: 0.875rem;
}

code {
    padding: 0.12rem 0.32rem;
    border-radius: 4px;
    background: rgba(17, 21, 29, 0.06);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 0.92em;
}

hr {
    border: 0;
    height: 1px;
    margin: 0;
    background: linear-gradient(90deg, transparent, rgba(31, 36, 48, 0.12), transparent);
}

::selection {
    background: rgba(255, 56, 92, 0.18);
    color: var(--text-strong);
}

.app-shell {
    min-height: 100vh;
}

.topbar {
    position: sticky;
    top: 0;
    z-index: 40;
    border-bottom: 1px solid rgba(227, 231, 238, 0.88);
    background: rgba(255, 255, 255, 0.84);
    backdrop-filter: blur(18px);
}

.topbar-inner {
    width: min(1280px, calc(100% - 2rem));
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem 1.25rem;
    padding: 1rem 0;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 0.9rem;
    min-width: 0;
}

.brand:hover {
    color: inherit;
}

.brand > span:last-child {
    display: grid;
    gap: 0.12rem;
}

.brand strong {
    font-size: 1.05rem;
}

.brand small {
    color: var(--text-soft);
}

.brand-mark {
    position: relative;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 8px;
    background:
        radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0) 46%),
        linear-gradient(145deg, #ff5974, #ff385c 55%, #ff8d61 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.45),
        0 16px 28px rgba(255, 56, 92, 0.28);
}

.brand-mark::before,
.brand-mark::after {
    content: "";
    position: absolute;
    inset: 0;
    margin: auto;
    border-radius: 999px;
}

.brand-mark::before {
    width: 1.05rem;
    height: 1.05rem;
    background: rgba(255, 255, 255, 0.92);
    transform: translateY(-0.28rem);
}

.brand-mark::after {
    width: 1.35rem;
    height: 1.35rem;
    border: 3px solid rgba(255, 255, 255, 0.92);
    border-bottom-color: transparent;
    transform: translateY(0.18rem) rotate(45deg);
}

.topnav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.35rem;
    border: 1px solid rgba(227, 231, 238, 0.96);
    border-radius: 999px;
    background: rgba(248, 251, 255, 0.92);
    box-shadow: var(--shadow-sm);
}

.topnav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 2.5rem;
    padding: 0.65rem 1rem;
    border: 1px solid transparent;
    border-radius: 999px;
    color: var(--text-muted);
    font-weight: 600;
    white-space: nowrap;
}

.topnav__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.4rem;
    height: 1.4rem;
    padding: 0 0.35rem;
    border-radius: 999px;
    background: #dc2626;
    color: #fff;
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1;
    flex: 0 0 auto;
}

.topnav a:hover {
    color: var(--text-strong);
    background: rgba(255, 255, 255, 0.92);
}

.topnav a.active {
    color: var(--accent-deep);
    background: #ffffff;
    border-color: rgba(255, 56, 92, 0.18);
    box-shadow: 0 10px 24px rgba(255, 56, 92, 0.12);
}

.userbox {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
}

.userbox form {
    margin: 0;
}

.userbox > div {
    display: grid;
    gap: 0.12rem;
    text-align: right;
}

.userbox strong {
    font-size: 0.96rem;
}

.userbox small {
    color: var(--text-soft);
}

.page-shell {
    padding: 2rem 0 4rem;
}

.page-container {
    width: min(1280px, calc(100% - 2rem));
    margin: 0 auto;
    display: grid;
    gap: 2rem;
}

button {
    appearance: none;
    font: inherit;
    letter-spacing: 0;
}

button,
.btn,
.btn-secondary,
a.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-height: 2.9rem;
    padding: 0.78rem 1.1rem;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--text-strong);
    font-weight: 600;
    line-height: 1;
    box-shadow: none;
    cursor: pointer;
}

button:hover,
.btn:hover,
.btn-secondary:hover,
a.button:hover {
    transform: translateY(-1px);
}

.btn {
    border-color: rgba(255, 56, 92, 0.2);
    background: linear-gradient(180deg, #ff5874 0%, #ff385c 100%);
    color: #ffffff;
    box-shadow: 0 16px 30px rgba(255, 56, 92, 0.24);
}

.btn:hover {
    color: #ffffff;
    box-shadow: 0 20px 36px rgba(255, 56, 92, 0.28);
}

.btn-secondary,
button.secondary {
    background: rgba(255, 255, 255, 0.94);
    color: var(--text);
    box-shadow: var(--shadow-sm);
}

.btn-secondary:hover,
button.secondary:hover {
    color: var(--text-strong);
}

.btn-danger {
    border-color: rgba(185, 28, 28, 0.18);
    background: linear-gradient(180deg, #ef5a5a 0%, #dc2626 100%);
    color: #ffffff;
    box-shadow: 0 16px 30px rgba(220, 38, 38, 0.22);
}

.btn-danger:hover {
    color: #ffffff;
    box-shadow: 0 20px 36px rgba(220, 38, 38, 0.28);
}

.link-button {
    display: inline-flex;
    align-items: center;
    min-height: auto;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--accent-deep);
    box-shadow: none;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
}

.link-button:hover {
    color: #c73658;
    transform: none;
    box-shadow: none;
}

.danger-link {
    color: #b91c1c;
}

button:focus-visible,
.btn:focus-visible,
.btn-secondary:focus-visible,
a.button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring);
}

input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
select,
textarea {
    width: 100%;
    min-height: 3rem;
    padding: 0.82rem 0.95rem;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    background: #ffffff;
    color: var(--text);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

input[type="file"] {
    width: 100%;
    padding: 0.75rem 0.85rem;
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.9);
    color: var(--text);
}

textarea {
    min-height: 7.2rem;
    resize: vertical;
}

input::placeholder,
textarea::placeholder {
    color: #97a0ac;
}

input:hover,
select:hover,
textarea:hover {
    border-color: #c6cfda;
}

input:focus,
select:focus,
textarea:focus {
    border-color: rgba(255, 56, 92, 0.45);
}

label {
    display: inline-block;
    font-weight: 600;
    color: var(--text-strong);
}

.form-field {
    display: grid;
    gap: 0.45rem;
}

.checkbox-row {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    color: var(--text);
    font-weight: 500;
}

.checkbox-row input {
    width: 1.1rem;
    height: 1.1rem;
    margin: 0;
}

.field-hint,
.muted,
.text-soft {
    color: var(--text-soft);
    font-size: 0.88rem;
}

.field-validation-error {
    color: #c73658;
    font-size: 0.88rem;
}

.field-hint--danger {
    color: #b4233f;
    font-weight: 600;
}

.form-field--missing label {
    color: #b4233f;
}

.form-field--missing input,
.form-field--missing select,
.form-field--missing textarea {
    border-color: rgba(199, 54, 88, 0.48);
    background: #fff5f7;
    box-shadow: inset 0 0 0 1px rgba(199, 54, 88, 0.08);
}

.validation-summary-errors {
    display: grid;
    gap: 0.45rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(199, 54, 88, 0.18);
    border-radius: var(--radius-sm);
    background: #fff1f4;
    color: #b72a49;
}

.validation-summary-errors ul {
    padding-left: 1rem;
}

.page-heading,
.section-heading {
    display: grid;
    gap: 0.55rem;
}

.page-heading-row,
.table-actions,
.actions,
.inline-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
}

.actions form,
.inline-actions form {
    margin: 0;
}

.table-panel.is-collapsed table,
.table-panel.is-collapsed .compact-empty,
.table-panel.is-collapsed .spaces-panel-body {
    display: none;
}

.page-heading-row {
    justify-content: space-between;
    align-items: end;
}

.section-heading {
    max-width: 64ch;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    width: fit-content;
    padding: 0.35rem 0.7rem;
    border: 1px solid rgba(255, 56, 92, 0.12);
    border-radius: 999px;
    background: rgba(255, 56, 92, 0.08);
    color: var(--accent-deep);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.lead {
    max-width: 60ch;
    font-size: 1.05rem;
}

.badge-list,
.tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.badge,
.tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: fit-content;
    min-height: 2rem;
    padding: 0.38rem 0.7rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--text);
    font-size: 0.82rem;
    font-weight: 600;
}

.tag {
    background: var(--surface-muted);
    color: var(--text-muted);
}

.badge-building {
    background: #edf5ff;
    border-color: #d4e6ff;
    color: #215a9a;
}

.badge-floor {
    background: #fff5df;
    border-color: #ffe2a5;
    color: #946516;
}

.badge-premise {
    background: #eef7f5;
    border-color: #cce9e4;
    color: #1e6b61;
}

.space-tone-rentable {
    --tone-fill: rgba(18, 116, 107, 0.2);
    --tone-stroke: #12746b;
}

.space-tone-service {
    --tone-fill: rgba(245, 178, 50, 0.2);
    --tone-stroke: #b8801b;
}

.space-tone-short-term {
    --tone-fill: rgba(243, 112, 33, 0.24);
    --tone-stroke: #F37021;
}

.space-tone-occupied {
    --tone-fill: rgba(255, 56, 92, 0.22);
    --tone-stroke: #d92d50;
}

.space-tone-pending {
    --tone-fill: rgba(68, 134, 255, 0.18);
    --tone-stroke: #3b6fe1;
}

.space-tone-archived {
    --tone-fill: rgba(109, 120, 137, 0.16);
    --tone-stroke: #6d7889;
}

.badge.space-tone-rentable {
    background: var(--teal-soft);
    border-color: #cae8e3;
    color: #0f625b;
}

.badge.space-tone-service {
    background: var(--gold-soft);
    border-color: #f3df9e;
    color: #926613;
}

.badge.space-tone-short-term {
    background: rgba(243, 112, 33, 0.14);
    border-color: rgba(243, 112, 33, 0.28);
    color: #a8440b;
}

.badge.space-tone-occupied {
    background: var(--accent-soft);
    border-color: rgba(255, 56, 92, 0.2);
    color: var(--accent-deep);
}

.badge.space-tone-pending {
    background: var(--sky-soft);
    border-color: #d0e3ff;
    color: #2f5fbf;
}

.badge.space-tone-archived {
    background: #f0f3f8;
    border-color: #d6dde8;
    color: #596474;
}

.badge.status-vacant {
    background: var(--teal-soft);
    border-color: #cae8e3;
    color: #0f625b;
}

.badge.status-pending {
    background: var(--sky-soft);
    border-color: #d0e3ff;
    color: #2f5fbf;
}

.badge.status-occupied {
    background: var(--accent-soft);
    border-color: rgba(255, 56, 92, 0.2);
    color: var(--accent-deep);
}

.badge.status-archived,
.badge.status-no-spaces {
    background: #f0f3f8;
    border-color: #d6dde8;
    color: #596474;
}

.panel,
.detail-card,
.feature-item,
.form-panel,
.table-panel,
.auth-panel,
.summary-tile,
.stat-card,
.object-map-card,
.document-key-panel,
.document-generator-panel,
.binding-card,
.source-field-card,
.lease-tenant-card {
    padding: 1.25rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: var(--shadow-md);
}

.panel,
.detail-card,
.feature-item,
.form-panel,
.auth-panel,
.object-map-card,
.document-key-panel,
.document-generator-panel,
.binding-card,
.source-field-card,
.lease-tenant-card {
    display: grid;
    gap: 1rem;
    align-content: start;
}

.tone-info {
    background:
        linear-gradient(135deg, rgba(255, 56, 92, 0.08), rgba(255, 255, 255, 0.98) 38%, rgba(18, 116, 107, 0.08));
    border-color: rgba(255, 56, 92, 0.14);
}

.tone-success {
    background:
        linear-gradient(135deg, rgba(16, 185, 129, 0.12), rgba(255, 255, 255, 0.98) 42%, rgba(52, 211, 153, 0.08));
    border-color: rgba(16, 185, 129, 0.18);
}

.tone-warning {
    background:
        linear-gradient(135deg, rgba(245, 158, 11, 0.14), rgba(255, 255, 255, 0.98) 42%, rgba(251, 191, 36, 0.08));
    border-color: rgba(245, 158, 11, 0.22);
}

.compact-panel {
    padding: 1rem;
}

.stats-grid,
.summary-strip,
.cards-grid,
.details-grid,
.properties-grid {
    display: grid;
    gap: 1rem;
}

.summary-strip,
.stats-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.cards-grid,
.details-grid,
.properties-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.summary-tile,
.stat-card {
    display: grid;
    gap: 0.55rem;
    align-content: start;
    min-height: 8.5rem;
}

.summary-tile--danger {
    border-color: rgba(220, 38, 38, 0.35);
    background:
        linear-gradient(135deg, rgba(220, 38, 38, 0.12), rgba(255, 255, 255, 0.98) 48%);
}

.summary-tile--danger .stat-label,
.summary-tile--danger strong,
.lease-end-date--danger {
    color: #b91c1c;
}

.summary-tile strong,
.stat-value,
.metric-value {
    color: var(--text-strong);
    font-size: clamp(1.55rem, 2.4vw, 2.35rem);
    line-height: 1.05;
    text-wrap: balance;
}

.summary-expense-list {
    display: grid;
    gap: 0.28rem;
    margin-top: 0.15rem;
}

.summary-expense-list span {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    color: var(--text-muted);
    font-size: 0.86rem;
    font-weight: 600;
}

.summary-expense-list strong {
    font-size: 0.86rem;
}

.stat-label,
.metric-label {
    color: var(--text-soft);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

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

.detail-stack {
    display: grid;
    gap: 1rem;
    align-content: start;
}

.metadata-list {
    display: grid;
    gap: 1rem;
}

.metadata-item {
    display: grid;
    gap: 0.35rem;
    padding-top: 0.95rem;
    border-top: 1px solid var(--border);
}

.metadata-item:first-child {
    padding-top: 0;
    border-top: 0;
}

.metadata-item > span:first-child {
    color: var(--text-soft);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.definition-grid {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.definition-grid > div {
    display: grid;
    gap: 0.25rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
}

dt {
    color: var(--text-soft);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

dd {
    margin: 0;
    color: var(--text-strong);
    font-weight: 600;
}

.table-panel {
    overflow-x: auto;
}

table {
    width: 100%;
    min-width: 640px;
    border-collapse: collapse;
    border-spacing: 0;
    margin-top: 0.25rem;
}

.table-row-link {
    cursor: pointer;
}

.table-row-link:hover,
.table-row-link:focus-visible {
    background: rgba(18, 116, 107, 0.06);
}

.table-row-link.is-highlighted {
    background: rgba(59, 130, 246, 0.12);
    box-shadow: inset 4px 0 0 #2563eb;
}

.table-primary-link {
    color: var(--text-strong);
    text-decoration: none;
}

.table-primary-link:hover,
.table-primary-link:focus-visible {
    color: var(--accent);
    text-decoration: underline;
    text-underline-offset: 0.18em;
}

thead th {
    background: #fbfcfe;
    color: var(--text-soft);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

th,
td {
    padding: 0.95rem 1rem;
    text-align: left;
    border-bottom: 1px solid var(--border);
    vertical-align: top;
}

tbody tr {
    transition: background-color 0.2s ease;
}

tbody tr:hover {
    background: rgba(255, 56, 92, 0.04);
}

tbody tr:last-child td {
    border-bottom: 0;
}

.clickable-table-row {
    cursor: pointer;
}

.clickable-table-row:focus-visible {
    outline: none;
    background: rgba(255, 56, 92, 0.06);
    box-shadow: inset 0 0 0 2px rgba(255, 56, 92, 0.18);
}

.empty-state {
    display: grid;
    gap: 1rem;
    justify-items: start;
    padding: 1.35rem;
    border: 1px dashed #d5dbe5;
    border-radius: var(--radius);
    background: rgba(248, 251, 255, 0.88);
}

.compact-empty {
    padding: 1.15rem;
}

.hero {
    scroll-margin-top: 7rem;
}

.hero-home {
    position: relative;
    display: grid;
    gap: 1.4rem;
    min-height: 40rem;
    padding: clamp(2rem, 4vw, 3rem);
    border-radius: var(--radius);
    overflow: hidden;
    isolation: isolate;
    background:
        linear-gradient(120deg, rgba(255, 255, 255, 0.96) 0%, rgba(255, 247, 248, 0.94) 42%, rgba(239, 250, 248, 0.9) 100%);
    box-shadow: var(--shadow-lg);
}

.hero-home::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.96) 0%, rgba(255, 255, 255, 0.78) 36%, rgba(255, 255, 255, 0.16) 100%);
    z-index: -1;
}

.hero-media {
    position: absolute;
    inset: 0;
    z-index: -2;
}

.hero-media-main {
    position: absolute;
    right: -4rem;
    top: -2rem;
    width: min(74%, 950px);
    height: calc(100% + 4rem);
    object-fit: cover;
    object-position: center;
    opacity: 0.96;
    filter: saturate(0.92) contrast(1.04);
}

.hero-float {
    position: absolute;
    width: min(20vw, 260px);
    padding: 0.55rem;
    border: 1px solid rgba(255, 255, 255, 0.74);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.9);
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(12px);
}

.hero-float img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 6px;
}

.hero-float-top {
    right: 16%;
    top: 12%;
}

.hero-float-bottom {
    right: 7%;
    bottom: 14%;
}

.hero-content {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 1.2rem;
    align-content: start;
    max-width: 43rem;
    padding-top: 0.35rem;
}

.home-navigator {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
}

.home-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
    padding: 0.74rem 1rem;
    border: 1px solid rgba(255, 255, 255, 0.78);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.8);
    color: var(--text);
    font-weight: 600;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

.home-pill:hover,
.home-pill.is-active {
    color: var(--accent-deep);
    border-color: rgba(255, 56, 92, 0.15);
    background: #ffffff;
}

.home-inline-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.home-inline-list span {
    display: inline-flex;
    align-items: center;
    min-height: 2.2rem;
    padding: 0.45rem 0.72rem;
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--text-muted);
    font-size: 0.9rem;
    font-weight: 600;
}

.hero-summary {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    align-self: end;
}

.analytics-glance-card {
    background: rgba(255, 255, 255, 0.88);
    border-color: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(12px);
}

.home-section {
    display: grid;
    gap: 1.25rem;
    scroll-margin-top: 7rem;
}

.home-section-heading {
    max-width: 66rem;
}

.home-section-alt {
    padding: 0.5rem 0;
}

.home-command-grid,
.home-flow-grid,
.home-proof-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-command-card,
.home-proof-card,
.home-flow-card {
    display: grid;
    gap: 1rem;
    align-content: start;
}

.home-flow-card {
    padding: 1.25rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: var(--shadow-md);
}

.home-card-image {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--surface-muted);
}

.home-bullet-list {
    display: grid;
    gap: 0.45rem;
    padding-left: 1.05rem;
}

.home-step-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent-deep);
    font-size: 0.92rem;
    font-weight: 800;
}

.home-proof-card strong {
    font-size: clamp(1.6rem, 2.2vw, 2.3rem);
    line-height: 1.08;
    text-wrap: balance;
}

.auth-layout {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.8fr);
    align-items: start;
}

.auth-panel {
    display: grid;
    gap: 1.25rem;
    padding: clamp(1.5rem, 3vw, 2rem);
}

.auth-panel form {
    display: grid;
    gap: 1rem;
}

.mode-switch {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
    width: fit-content;
    padding: 0.35rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: var(--shadow-sm);
}

.mode-switch a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.45rem;
    padding: 0.68rem 1rem;
    border-radius: 999px;
    color: var(--text-muted);
    font-weight: 600;
}

.mode-switch a.active {
    background: var(--accent);
    color: #ffffff;
}

.object-map-layout {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.95fr);
    align-items: start;
}

.utility-allocation-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
    align-items: start;
}

.object-map-frame {
    min-height: 520px;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}

.object-map-canvas {
    width: 100%;
    min-height: 520px;
}

.leaflet-container {
    font: inherit;
}

.object-map-list {
    display: grid;
    gap: 0.9rem;
    max-height: 520px;
    overflow: auto;
    padding-right: 0.25rem;
}

.object-map-card {
    display: grid;
    gap: 0.75rem;
    cursor: pointer;
}

.object-map-card.is-active {
    border-color: rgba(255, 56, 92, 0.22);
    box-shadow: 0 0 0 3px rgba(255, 56, 92, 0.1), var(--shadow-md);
}

.object-map-card-head,
.object-map-card-meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.75rem;
}

.object-map-card-head {
    align-items: start;
}

.object-map-card-meta {
    color: var(--text-soft);
    font-size: 0.9rem;
}

.map-fallback-panel {
    display: grid;
    gap: 1rem;
    padding: 1.25rem;
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius);
    background: rgba(248, 251, 255, 0.84);
}

.map-balloon p {
    margin: 0 0 0.45rem;
}

.map-balloon a {
    color: var(--accent-deep);
    font-weight: 700;
}

.map-balloon__photo {
    margin: 0 0 0.65rem;
    overflow: hidden;
    border-radius: 8px;
    border: 1px solid rgba(19, 31, 45, 0.08);
    background: var(--surface-muted);
}

.map-balloon__photo img {
    display: block;
    width: 100%;
    max-height: 10rem;
    object-fit: cover;
}

.address-picker,
.address-picker__results {
    display: grid;
    gap: 0.75rem;
}

.address-picker__bar {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
}

.address-picker__results {
    padding: 0.8rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: rgba(248, 251, 255, 0.82);
}

.address-picker__option {
    display: grid;
    gap: 0.35rem;
    justify-items: start;
    width: 100%;
    padding: 0.9rem 1rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: #ffffff;
    text-align: left;
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.address-picker__option:hover {
    border-color: rgba(255, 56, 92, 0.24);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

.address-picker__option strong {
    color: var(--text-strong);
}

.address-picker__option span,
.address-picker [data-address-status] {
    color: var(--text-muted);
    font-size: 0.92rem;
    line-height: 1.45;
}

.address-picker [data-address-status][data-tone="success"] {
    color: #0f8a6b;
}

.address-picker [data-address-status][data-tone="warning"] {
    color: #a16207;
}

.building-floor-builder,
.building-floor-form,
.building-floor-table,
.building-floor-row,
.building-floor-card {
    display: grid;
    gap: 0.75rem;
}

.building-floor-card {
    position: relative;
}

.building-floor-builder[hidden] {
    display: none;
}

.building-floor-builder {
    padding: 1rem;
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius);
    background: rgba(248, 251, 255, 0.72);
}

.building-floor-row {
    grid-template-columns: minmax(5rem, 0.55fr) minmax(10rem, 1.4fr) minmax(7rem, 0.8fr) minmax(7rem, 0.8fr) auto;
    align-items: center;
}

@media (max-width: 860px) {
    .building-floor-row {
        grid-template-columns: 1fr;
    }
}

.address-picker__map-shell {
    display: grid;
    gap: 0.55rem;
    padding: 0.75rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: rgba(248, 251, 255, 0.72);
}

.address-picker__map {
    height: 320px;
    min-height: 320px;
    overflow: hidden;
    isolation: isolate;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    background: #eef2f7;
}

.address-picker__map-note {
    color: var(--text-muted);
    font-size: 0.92rem;
    line-height: 1.45;
}

.plan-workspace {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.95fr);
    align-items: start;
}

.plan-surface {
    display: grid;
    gap: 1rem;
    padding: 1.25rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: var(--shadow-md);
}

.plan-sidebar {
    align-content: start;
}

.plan-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
}

.plan-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.42rem 0.72rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: #ffffff;
    color: var(--text-muted);
    font-size: 0.84rem;
    font-weight: 600;
}

.plan-legend-item::before {
    content: "";
    width: 0.72rem;
    height: 0.72rem;
    border-radius: 999px;
    background: var(--tone-fill, rgba(31, 36, 48, 0.12));
    border: 2px solid var(--tone-stroke, var(--text-soft));
}

.plan-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.plan-tool {
    min-height: 2.6rem;
    padding-inline: 0.95rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--text-muted);
}

.plan-tool.is-active {
    border-color: rgba(255, 56, 92, 0.2);
    background: var(--accent-soft);
    color: var(--accent-deep);
}

.plan-stage,
.space-preview {
    position: relative;
    width: 100%;
    aspect-ratio: var(--plan-aspect, 16 / 9);
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 248, 251, 0.96)),
        repeating-linear-gradient(90deg, rgba(227, 231, 238, 0.5) 0, rgba(227, 231, 238, 0.5) 1px, transparent 1px, transparent 32px),
        repeating-linear-gradient(180deg, rgba(227, 231, 238, 0.5) 0, rgba(227, 231, 238, 0.5) 1px, transparent 1px, transparent 32px);
}

.plan-stage img,
.space-preview img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: rgba(255, 255, 255, 0.9);
}

.object-plan-preview {
    aspect-ratio: var(--plan-aspect, 16 / 9);
}

.floor-plan-card {
    position: relative;
}

.floor-plan-card__delete {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    z-index: 4;
    margin: 0;
}

.floor-plan-card__delete .btn-icon {
    background: rgba(255, 255, 255, 0.92);
    box-shadow: var(--shadow-sm);
}

.object-plan-popup {
    position: absolute;
    z-index: 6;
    display: grid;
    gap: 0.5rem;
    min-width: 12rem;
    max-width: min(18rem, 78%);
    color: var(--text);
    pointer-events: auto;
    transform: none;
}

.object-plan-popup__card {
    display: grid;
    gap: 0.35rem;
    padding: 0.7rem 0.8rem;
    border: 1px solid rgba(19, 31, 45, 0.14);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: var(--shadow-md);
}

.object-plan-popup__card strong {
    color: var(--text-strong);
    font-size: 0.96rem;
}

.object-plan-popup__card span {
    color: var(--text-muted);
    font-size: 0.82rem;
}

.object-plan-popup__muted {
    color: var(--text-muted);
}

.object-plan-popup__metric {
    color: var(--text-strong);
    font-size: 0.96rem;
    font-weight: 700;
}

.object-plan-popup__contact {
    color: var(--text-strong);
    font-size: 0.88rem;
    font-weight: 600;
}

.object-plan-popup__field {
    display: grid;
    gap: 0.3rem;
}

.object-plan-popup__field span {
    color: var(--text-muted);
    font-size: 0.8rem;
    font-weight: 600;
}

.object-plan-popup__field input {
    width: 100%;
    min-height: 2.2rem;
    padding: 0.45rem 0.65rem;
    border: 1px solid rgba(19, 31, 45, 0.14);
    border-radius: 8px;
    background: #fff;
    color: var(--text-strong);
}

.object-plan-popup__error {
    padding: 0.45rem 0.55rem;
    border-radius: 8px;
    background: #fff1f4;
    color: #b4233f;
    font-size: 0.82rem;
    font-weight: 600;
}

.object-plan-popup__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.2rem;
}

.object-plan-popup__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.35rem 0.7rem;
    border: 1px solid rgba(19, 31, 45, 0.14);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.96);
    color: var(--text-strong);
    font-size: 0.82rem;
    font-weight: 700;
    text-decoration: none;
}

.object-plan-popup__action:hover,
.object-plan-popup__action:focus-visible {
    border-color: rgba(15, 23, 42, 0.28);
    background: rgba(248, 250, 252, 0.98);
}

.object-plan-popup__action--primary {
    background: rgba(255, 56, 92, 0.1);
    border-color: rgba(255, 56, 92, 0.22);
    color: #b4233f;
}

.object-plan-popup__action--invoice {
    border-color: rgba(220, 38, 38, 0.45);
    background: rgba(254, 242, 242, 0.98);
    color: #b42318;
}

.object-plan-popup__action--invoice:hover,
.object-plan-popup__action--invoice:focus-visible {
    border-color: rgba(220, 38, 38, 0.62);
    background: rgba(254, 226, 226, 0.98);
}

.object-plan-popup__icon-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.15rem;
}

.object-plan-popup__icon-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.15rem;
    height: 2.15rem;
    padding: 0.25rem;
    border: 1px solid rgba(19, 31, 45, 0.14);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.98);
    cursor: pointer;
}

.object-plan-popup__icon-action:hover,
.object-plan-popup__icon-action:focus-visible {
    border-color: rgba(255, 56, 92, 0.3);
    background: var(--accent-soft);
}

.object-plan-popup__icon-action img {
    display: block;
    width: 1.35rem;
    height: 1.35rem;
    object-fit: contain;
}

.btn-invoice-accent {
    border-color: rgba(220, 38, 38, 0.48);
    color: #b42318;
    background: rgba(254, 242, 242, 0.92);
    box-shadow: inset 0 0 0 1px rgba(220, 38, 38, 0.08);
}

.btn-invoice-accent:hover,
.btn-invoice-accent:focus-visible {
    border-color: rgba(220, 38, 38, 0.68);
    background: rgba(254, 226, 226, 0.98);
    color: #991b1b;
}

.company-logo-preview {
    max-width: 18rem;
    aspect-ratio: 1 / 1;
    overflow: hidden;
}

.company-logo-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.company-logo-preview-wrap {
    position: relative;
    width: fit-content;
}

.company-logo-delete {
    position: absolute;
    top: 0.45rem;
    right: 0.45rem;
    width: 1.9rem;
    height: 1.9rem;
    border: 1px solid rgba(220, 38, 38, 0.36);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.96);
    color: #b42318;
    font-size: 1.15rem;
    line-height: 1;
    box-shadow: var(--shadow-sm);
}

.company-logo-delete:hover,
.company-logo-delete:focus-visible {
    border-color: rgba(220, 38, 38, 0.6);
    background: rgba(254, 242, 242, 0.98);
}

.plan-overlay-svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.plan-stage[data-tool="polygon"],
.plan-stage[data-tool="rectangle"] {
    cursor: crosshair;
}

.plan-region {
    fill: var(--tone-fill, rgba(255, 56, 92, 0.15));
    stroke: var(--tone-stroke, #ff385c);
    stroke-width: 2.2;
    vector-effect: non-scaling-stroke;
    transition: fill 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.plan-region-link:hover .plan-region,
.plan-region-link.is-linked-group-highlight .plan-region,
.plan-region.is-selected,
.space-preview-region {
    opacity: 1;
    filter: saturate(1.05);
}

.plan-region-link.is-linked-group-muted .plan-region,
.object-plan-preview.is-linked-group-hover .plan-region-link:not(.is-linked-group-highlight) .plan-region {
    opacity: 0.22;
}

.plan-region-link.is-linked-group-highlight .plan-region {
    stroke-width: 3.4;
}

.plan-linked-group-icon {
    pointer-events: none;
    opacity: 0.92;
    filter: drop-shadow(0 2px 4px rgba(15, 23, 42, 0.28));
}

.plan-region.is-selected {
    stroke-width: 3;
}

.object-plan-preview[data-selection-mode="multi"] .plan-region-link {
    cursor: cell;
}

.object-plan-preview[data-expense-link-mode="true"] .plan-region-link {
    cursor: crosshair;
}

.object-plan-preview[data-expense-link-mode="true"] .plan-region-link .plan-region {
    stroke-dasharray: 8 5;
    stroke-width: 3;
}

.editor-overlay-draft {
    pointer-events: none;
}

.editor-overlay-draft [data-active-space-id],
.editor-overlay-draft [data-active-space-id] .plan-region,
.editor-overlay-draft [data-handle-index] {
    pointer-events: auto;
}

.editor-overlay-draft [data-active-space-id] .plan-region {
    cursor: move;
}

.geometry-status {
    padding: 0.85rem 0.95rem;
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
    color: var(--text-muted);
}

.geometry-json {
    margin: 0;
    padding: 0.85rem 0.95rem;
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
    color: var(--text-muted);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 0.92rem;
    white-space: pre-wrap;
    word-break: break-word;
}

.document-constructor-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(340px, 0.88fr) minmax(0, 1.12fr);
}

.document-constructor-column {
    display: grid;
    gap: 1rem;
    align-content: start;
}

.finance-layout-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
}

.finance-panel {
    display: grid;
    gap: 1rem;
    min-height: 0;
}

.finance-top-panel {
    min-height: 38rem;
}

.finance-panel--recent {
    grid-template-rows: auto minmax(0, 1fr);
    overflow: hidden;
}

.finance-panel--upcoming {
    grid-column: 1 / -1;
}

.finance-table-scroll {
    min-height: 0;
    overflow: auto;
}

.finance-table-scroll table {
    margin-top: 0;
}

.finance-row-highlight {
    background: rgba(59, 130, 246, 0.12);
    outline: 2px solid rgba(59, 130, 246, 0.28);
    outline-offset: -2px;
}

.document-builder {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.45fr) minmax(360px, 0.95fr);
    align-items: start;
}

.document-builder-sidebar {
    display: grid;
    gap: 1rem;
    align-content: start;
}

.document-preview-surface {
    display: grid;
    gap: 1rem;
}

.document-word-shell {
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: #eef2f7;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.document-word-toolbar {
    display: grid;
    gap: 0.7rem;
    padding: 0.9rem 1rem;
    border-bottom: 1px solid var(--border);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(246, 248, 251, 0.95));
}

.document-word-toolbar-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.document-word-toolbar-tools {
    gap: 0.65rem;
}

.document-word-tab {
    display: inline-flex;
    align-items: center;
    min-height: 2.2rem;
    padding: 0.45rem 0.8rem;
    border: 1px solid transparent;
    border-radius: 999px;
    color: var(--text-soft);
    font-size: 0.88rem;
    font-weight: 600;
    background: rgba(255, 255, 255, 0.8);
}

.document-word-tab.is-active {
    border-color: rgba(255, 56, 92, 0.18);
    color: var(--accent-deep);
    background: #ffffff;
}

.document-word-tool-group {
    display: inline-flex;
    flex-direction: column;
    gap: 0.08rem;
    min-height: 3rem;
    padding: 0.55rem 0.8rem;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.92);
    color: var(--text-muted);
}

.document-word-tool-group strong,
.document-word-tool-group span {
    color: var(--text-strong);
    font-size: 0.9rem;
}

.document-word-ruler {
    display: grid;
    grid-template-columns: repeat(9, 1fr);
    padding: 0.45rem 1.35rem;
    color: var(--text-soft);
    font-size: 0.76rem;
}

.document-word-canvas {
    padding: 1.5rem;
    overflow: auto;
}

.document-word-page {
    width: min(100%, 860px);
    min-height: 1100px;
    margin: 0 auto;
    display: grid;
    align-content: start;
    gap: 1.5rem;
    padding: 2.5rem 2.35rem;
    border: 1px solid #dde3eb;
    border-radius: 4px;
    background: #ffffff;
    box-shadow: 0 32px 70px rgba(15, 23, 42, 0.09);
    font-family: "Times New Roman", Times, serif;
}

.document-word-page-header,
.document-word-page-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    color: #667184;
    font-size: 0.94rem;
}

.document-word-page-footer {
    padding-top: 1rem;
    border-top: 1px solid #e7ecf3;
}

.document-preview {
    display: grid;
    gap: 1rem;
}

.document-preview-block {
    position: relative;
    display: grid;
    gap: 0.75rem;
    padding: 1rem 1rem 1rem 3.65rem;
    border: 1px solid #e7ecf3;
    border-radius: 6px;
    background: #fffdfc;
}

.document-preview-block::before {
    content: attr(data-sequence);
    position: absolute;
    left: 1rem;
    top: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.8rem;
    height: 1.8rem;
    border-radius: 999px;
    background: #f3f6fa;
    color: #7f8793;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.document-preview-block.is-active-block {
    border-color: rgba(255, 56, 92, 0.18);
    background: rgba(255, 240, 243, 0.46);
}

.document-preview-content {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.18rem;
    line-height: 1.72;
    color: #2b313d;
}

.document-preview-empty {
    color: #8b94a0;
    font-style: italic;
}

.document-drop-point {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.7rem;
    min-height: 1.7rem;
    padding: 0 0.3rem;
    border: 1px dashed #cbd4df;
    border-radius: 999px;
    background: #ffffff;
    color: var(--accent-deep);
    font-size: 0.86rem;
    font-weight: 800;
    vertical-align: middle;
    cursor: pointer;
}

.document-drop-point:hover {
    border-color: rgba(255, 56, 92, 0.3);
    background: var(--accent-soft);
}

.document-drop-point:focus-visible {
    border-color: rgba(255, 56, 92, 0.4);
    background: var(--accent-soft);
}

.document-drop-point.is-filled {
    gap: 0.35rem;
    border-style: solid;
    border-color: rgba(255, 56, 92, 0.16);
    background: var(--accent-soft);
}

.document-drop-point.is-target {
    border-color: rgba(255, 56, 92, 0.42);
    background: rgba(255, 240, 243, 0.88);
    box-shadow: 0 0 0 3px rgba(255, 56, 92, 0.12);
}

.document-drop-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.18rem 0.45rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.88);
    color: var(--accent-deep);
    font-size: 0.72rem;
    font-weight: 700;
    white-space: nowrap;
}

.document-drop-plus {
    line-height: 1;
}

.document-field-list {
    display: grid;
    gap: 0.75rem;
}

.document-field-card {
    display: grid;
    gap: 0.6rem;
    padding: 0.95rem 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: var(--shadow-md);
    cursor: grab;
}

.document-field-card.is-selected {
    border-color: rgba(255, 56, 92, 0.2);
    background: rgba(255, 240, 243, 0.52);
}

.document-field-card.is-placed {
    box-shadow: inset 3px 0 0 var(--teal), var(--shadow-sm);
}

.document-field-card.is-unplaced {
    box-shadow: inset 3px 0 0 rgba(255, 56, 92, 0.16), var(--shadow-sm);
}

.document-field-card.is-dragging {
    opacity: 0.72;
    cursor: grabbing;
}

.document-field-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 0.75rem;
}

.document-field-select {
    display: grid;
    gap: 0.25rem;
    padding: 0;
    border: 0;
    background: transparent;
    text-align: left;
    color: inherit;
    box-shadow: none;
}

.document-field-select strong {
    font-size: 0.98rem;
}

.document-field-status {
    color: var(--text-soft);
    font-size: 0.88rem;
}

.document-field-clear {
    min-height: auto;
    padding: 0.55rem 0.72rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: #ffffff;
    color: var(--text-soft);
    box-shadow: none;
}

.document-add-fields-form,
.document-counterparty-form {
    display: grid;
    gap: 1rem;
}

.lease-builder-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.18fr) minmax(300px, 0.82fr);
    align-items: start;
}

.utility-space-link {
    display: inline-flex;
}

.lease-field-grid,
.form-grid,
.binding-grid,
.source-field-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.lease-tenant-card {
    display: grid;
    gap: 1rem;
}

.lease-tenant-card__counterparty {
    color: inherit;
    text-decoration: none;
}

.lease-tenant-card__counterparty:hover,
.lease-tenant-card__counterparty:focus-visible {
    color: var(--accent-deep);
    text-decoration: underline;
}

.space-payment-schedule-card {
    order: 2;
    position: relative;
}

.payment-schedule-linked-icon {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    width: 28px;
    height: 28px;
    object-fit: contain;
    opacity: 0.82;
    filter: drop-shadow(0 2px 5px rgba(15, 23, 42, 0.2));
}

.is-disabled {
    opacity: 0.55;
    pointer-events: none;
}

.space-documents-card {
    order: 3;
}

.space-tenant-documents-card {
    order: 3;
}

.space-photos-card {
    order: 1;
}

.space-lease-status-card {
    order: 4;
}

.space-tenant-portal-card {
    order: 5;
}

.manual-lease-editor {
    border-top: 1px solid var(--border);
    padding-top: 0.75rem;
}

.manual-lease-editor summary {
    color: var(--text-strong);
    cursor: pointer;
    font-weight: 700;
}

.manual-lease-editor[open] summary {
    margin-bottom: 0.75rem;
}

.building-overview-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    align-items: start;
}

.building-floors-panel--legacy,
.object-spaces-panel--legacy,
.building-rest-grid .object-documents-card--legacy,
.building-rest-grid .object-photo-card--legacy {
    display: none;
}

.object-spaces-panel--primary {
    scroll-margin-top: 1.5rem;
}

.object-documents-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.object-documents-card__state-icon {
    width: 44px;
    height: 44px;
    object-fit: contain;
    flex: 0 0 auto;
}

.object-egrn-panel {
    display: grid;
    gap: 0.75rem;
    padding: 0.85rem;
    border: 1px solid rgba(18, 116, 107, 0.18);
    border-radius: 8px;
    background: rgba(232, 247, 244, 0.54);
}

.object-egrn-upload {
    margin: 0;
}

.object-egrn-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 172px;
    min-height: 46px;
    padding: 0;
    border: 0;
    border-radius: 8px;
    background: transparent;
    cursor: pointer;
    overflow: hidden;
    text-decoration: none;
    box-shadow: var(--shadow-sm);
}

.object-egrn-button img {
    width: 100%;
    height: 100%;
    min-height: 46px;
    object-fit: fill;
    display: block;
}

.object-egrn-button:hover,
.object-egrn-button:focus-visible {
    filter: brightness(0.98);
    outline: none;
    box-shadow: var(--focus-ring), var(--shadow-sm);
}

.spaces-panel-body {
    display: grid;
    gap: 1rem;
}

.object-document-folder-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.object-document-folder {
    position: relative;
}

.object-document-folder__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
}

.object-document-folder__controls {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex: 0 0 auto;
}

.space-document-folder .object-document-folder__header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: start;
}

.space-document-icon-form {
    margin: 0;
}

.space-document-folder__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border: 1px solid rgba(31, 36, 48, 0.12);
    border-radius: 8px;
    background: #ffffff;
    cursor: pointer;
}

.space-document-folder__icon img {
    width: 34px;
    height: 34px;
    object-fit: contain;
}

.space-document-folder__icon:hover,
.space-document-folder__icon:focus-visible {
    border-color: rgba(255, 56, 92, 0.42);
    outline: none;
    box-shadow: var(--focus-ring);
}

.object-document-folder__collapse,
.object-document-folder__delete,
.object-document-delete {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(31, 36, 48, 0.14);
    border-radius: 6px;
    background: #ffffff;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1;
}

.object-document-folder__delete {
    border-color: rgba(220, 38, 38, 0.26);
    background: rgba(254, 242, 242, 0.92);
    color: #dc2626;
}

.object-document-folder__collapse span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    font-size: 1rem;
    letter-spacing: 0;
}

.object-document-folder__collapse span::before {
    content: "...";
    transform: translateY(-4px);
}

.object-document-folder__collapse:hover,
.object-document-folder__collapse:focus-visible,
.object-document-delete:hover,
.object-document-delete:focus-visible {
    border-color: rgba(255, 56, 92, 0.42);
    color: var(--accent-deep);
    outline: none;
    box-shadow: var(--focus-ring);
}

.object-document-folder__delete:hover,
.object-document-folder__delete:focus-visible {
    border-color: rgba(185, 28, 28, 0.46);
    background: rgba(254, 226, 226, 0.96);
    color: #b91c1c;
    outline: none;
    box-shadow: var(--focus-ring);
}

.object-document-folder.is-collapsed .object-document-folder__body {
    display: none;
}

.object-document-folder__upload {
    margin-top: 0.85rem;
    padding-top: 0.85rem;
    border-top: 1px solid rgba(18, 116, 107, 0.16);
}

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

.object-document-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.45rem;
    align-items: stretch;
}

.object-document-link {
    display: grid;
    gap: 0.15rem;
    padding: 0.65rem 0.75rem;
    border: 1px solid rgba(18, 116, 107, 0.2);
    border-radius: 8px;
    background: rgba(232, 247, 244, 0.72);
    color: var(--teal);
    font-weight: 700;
    text-decoration: none;
}

.object-document-link span {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 600;
}

.object-document-link:hover,
.object-document-link:focus-visible {
    border-color: rgba(18, 116, 107, 0.42);
    background: rgba(220, 244, 240, 0.96);
}

.building-expenses-panel,
.building-expense-form,
.building-expense-table {
    display: grid;
    gap: 1rem;
}

.building-expense-row {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: minmax(160px, 1.15fr) minmax(110px, 0.65fr) minmax(150px, 0.9fr) minmax(170px, 1fr) auto;
    align-items: center;
}

.building-expenses-panel--floor .building-expense-row {
    grid-template-columns: minmax(150px, 1.05fr) minmax(100px, 0.55fr) minmax(130px, 0.8fr) minmax(140px, 0.8fr) minmax(140px, 0.8fr) auto;
}

.building-expense-row[data-building-expense-row] {
    border-radius: 8px;
    cursor: pointer;
    padding: 0.45rem;
}

.building-expense-row[data-building-expense-row]:hover,
.building-expense-row[data-building-expense-row]:focus-visible,
.building-expense-row[data-building-expense-row].is-selected {
    background: rgba(232, 247, 244, 0.7);
    outline: none;
}

.building-expense-row--head {
    color: var(--text-muted);
    font-size: 0.82rem;
    font-weight: 700;
}

.building-expense-row--form {
    align-items: end;
}

.building-expense-row__action {
    display: flex;
    align-items: end;
    gap: 0.45rem;
    min-height: 100%;
}

.building-expense-row__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.45rem;
}

.building-expense-row__actions .link-button.is-active {
    color: var(--teal-deep);
    text-decoration: underline;
}

.building-expense-link-button {
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    cursor: pointer;
    transition: border-color 0.16s ease, background 0.16s ease, transform 0.16s ease;
}

.building-expense-link-button img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

.building-expense-link-button:hover,
.building-expense-link-button:focus-visible,
.building-expense-link-button.is-active {
    border-color: rgba(18, 116, 107, 0.42);
    background: rgba(232, 247, 244, 0.9);
    outline: none;
}

.building-floor-title-link {
    color: inherit;
    text-decoration: none;
}

.building-floor-title-link:hover,
.building-floor-title-link:focus-visible {
    color: var(--teal);
    text-decoration: underline;
    outline: none;
}

.photo-drop-zone {
    position: relative;
    display: none;
    gap: 0.65rem;
    padding: 0.85rem;
    border: 1px dashed rgba(18, 116, 107, 0.38);
    border-radius: 8px;
    background: rgba(232, 247, 244, 0.48);
    color: var(--text);
    transition: border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}

body.is-photo-dragging .photo-drop-zone,
.photo-drop-zone.is-dragging,
.photo-drop-zone:focus-within {
    display: grid;
}

.photo-drop-zone input[type="file"] {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.photo-drop-zone__content {
    display: grid;
    gap: 0.1rem;
    place-items: center;
    min-height: 74px;
    cursor: pointer;
    text-align: center;
}

.photo-drop-zone__content span {
    color: var(--text-muted);
    font-size: 0.86rem;
    font-weight: 600;
}

.photo-drop-zone__content .photo-drop-zone__format {
    max-width: 34rem;
    color: #56706c;
    font-size: 0.78rem;
    font-weight: 500;
}

.photo-drop-zone__submit {
    justify-self: center;
}

.photo-drop-zone.is-dragging {
    border-color: var(--teal);
    background: rgba(220, 244, 240, 0.96);
    box-shadow: 0 0 0 3px rgba(18, 116, 107, 0.12);
}

body.is-photo-lightbox-open {
    overflow: hidden;
}

.is-lightbox-trigger {
    cursor: zoom-in;
}

.photo-lightbox {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: grid;
    place-items: center;
    padding: clamp(1rem, 4vw, 3rem);
    background: rgba(8, 18, 22, 0.76);
}

.photo-lightbox[hidden] {
    display: none;
}

.photo-lightbox__figure {
    position: relative;
    display: grid;
    gap: 0.7rem;
    margin: 0;
    max-width: min(100%, 1180px);
    max-height: 100%;
}

.photo-lightbox__image {
    display: block;
    max-width: min(100%, calc(100vw - 2rem));
    max-height: calc(100vh - 7rem);
    border-radius: 8px;
    object-fit: contain;
    background: #ffffff;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.34);
}

.photo-lightbox__close {
    position: absolute;
    top: 0.65rem;
    right: 0.65rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 1px solid rgba(255, 255, 255, 0.54);
    border-radius: 999px;
    background: rgba(12, 20, 24, 0.74);
    color: #ffffff;
    font-size: 1.45rem;
    line-height: 1;
    cursor: pointer;
}

.photo-lightbox__nav {
    position: absolute;
    top: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 999px;
    background: rgba(12, 20, 24, 0.72);
    color: #ffffff;
    font-size: 2rem;
    line-height: 1;
    cursor: pointer;
    transform: translateY(-50%);
}

.photo-lightbox__nav[hidden] {
    display: none;
}

.photo-lightbox__nav--prev {
    left: 0.8rem;
}

.photo-lightbox__nav--next {
    right: 0.8rem;
}

.photo-lightbox__close:hover,
.photo-lightbox__close:focus-visible,
.photo-lightbox__nav:hover,
.photo-lightbox__nav:focus-visible {
    background: rgba(12, 20, 24, 0.9);
    outline: none;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.22);
}

.photo-lightbox__caption {
    justify-self: center;
    max-width: min(100%, 760px);
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.92rem;
    text-align: center;
}

.space-detail-shell {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
    align-items: start;
}

.space-detail-shell > .detail-grid {
    min-width: 0;
}

.space-notes-rail {
    position: sticky;
    top: 1rem;
    display: grid;
    gap: 0.8rem;
    min-width: 0;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.space-note-stack {
    display: grid;
    gap: 0.75rem;
}

.space-note-card {
    position: relative;
    display: grid;
    gap: 0.55rem;
    padding: 0.85rem 2.8rem 0.85rem 0.9rem;
    border: 1px solid rgba(255, 193, 7, 0.24);
    border-radius: 8px;
    background: #fff9e8;
    color: var(--text-strong);
}

.space-note-card p {
    margin: 0;
    white-space: pre-wrap;
}

.space-note-card span {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 600;
}

.space-note-card__delete {
    position: absolute;
    top: 0.55rem;
    right: 0.55rem;
    margin: 0;
}

.space-note-modal,
.object-space-note-modal {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: grid;
    place-items: center;
    padding: 1rem;
    background: rgba(15, 23, 42, 0.36);
}

.space-note-modal[hidden],
.object-space-note-modal[hidden] {
    display: none;
}

.space-note-dialog,
.object-space-note-dialog {
    display: grid;
    gap: 1rem;
    width: min(32rem, 100%);
    padding: 1.25rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-md);
}

.space-note-dialog textarea,
.object-space-note-dialog textarea {
    min-height: 9rem;
}

@media (max-width: 980px) {
    .building-overview-grid,
    .space-detail-shell {
        grid-template-columns: 1fr;
    }

    .space-notes-rail {
        position: static;
    }

    .building-expense-row {
        grid-template-columns: 1fr;
        align-items: stretch;
    }
}

@media (max-width: 640px) {
    .address-picker__map-shell {
        overflow: hidden;
    }

    .address-picker__map {
        height: 260px;
        min-height: 260px;
    }

    .object-plan-popup {
        max-width: calc(100% - 1.5rem);
    }
}

.upload-form,
.inline-form {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin: 0;
}

.full {
    grid-column: 1 / -1;
}

.reveal-item {
    opacity: 0;
    transform: translateY(18px);
    transition: transform 0.48s ease, opacity 0.48s ease;
}

[data-home-analytics].is-visible .reveal-item {
    opacity: 1;
    transform: translateY(0);
}

::-webkit-scrollbar {
    width: 12px;
    height: 12px;
}

::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.35);
}

::-webkit-scrollbar-thumb {
    border: 3px solid rgba(0, 0, 0, 0);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255, 56, 92, 0.75), rgba(18, 116, 107, 0.72));
    background-clip: padding-box;
}

@media (max-width: 1180px) {
    .detail-grid,
    .utility-allocation-grid,
    .object-map-layout,
    .document-builder,
    .document-constructor-grid,
    .lease-builder-grid,
    .plan-workspace {
        grid-template-columns: 1fr;
    }

    .finance-top-panel {
        min-height: auto;
    }

    .floor-bulk-panel__actions [data-floor-bulk-assign] {
        grid-template-columns: 1fr;
    }

    .home-command-grid,
    .home-flow-grid,
    .home-proof-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .hero-media-main {
        width: min(82%, 920px);
        right: -8rem;
    }

    .hero-float {
        width: min(24vw, 240px);
    }
}

@media (max-width: 920px) {
    .page-shell {
        padding-top: 1.5rem;
        padding-bottom: 3rem;
    }

    .topbar-inner {
        width: min(100% - 1rem, 100%);
        padding: 0.8rem 0;
    }

    .page-container {
        width: min(100% - 1rem, 100%);
        gap: 1.5rem;
    }

    .page-heading-row {
        align-items: start;
    }

    .topnav {
        justify-content: flex-start;
    }

    .userbox {
        justify-content: flex-start;
    }

    .userbox > div {
        text-align: left;
    }

    .hero-home {
        min-height: auto;
        padding: 1.5rem;
    }

    .hero-home::before {
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0.86) 46%, rgba(255, 255, 255, 0.68) 100%);
    }

    .hero-media-main {
        width: 100%;
        height: 100%;
        right: 0;
        top: 0;
        opacity: 0.22;
        object-fit: cover;
    }

    .hero-float {
        display: none;
    }

    .hero-content {
        max-width: none;
    }
}

.field-draft-table {
    display: grid;
    gap: 0.6rem;
}

.field-draft-table-head,
.field-draft-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.6rem;
    align-items: center;
}

.field-draft-table-head {
    color: var(--muted);
    font-size: 0.85rem;
    font-weight: 600;
}

.field-draft-cell {
    min-width: 0;
}

.field-draft-cell input {
    width: 100%;
}

.field-draft-actions {
    display: flex;
    justify-content: flex-end;
}

.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(120, 139, 160, 0.38);
    background: rgba(15, 26, 23, 0.04);
    color: inherit;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 8px;
    cursor: pointer;
    font-size: 1.2rem;
    line-height: 1;
}

.btn-icon:disabled {
    opacity: 0.45;
    cursor: default;
}

.compact-section-heading {
    margin-top: 1.5rem;
}

.form-field-span-2 {
    grid-column: span 2;
}

.filter-switch {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    padding: 0.35rem;
    background: rgba(10, 28, 23, 0.06);
    border: 1px solid rgba(120, 139, 160, 0.18);
    border-radius: 8px;
    margin-bottom: 1.25rem;
}

.filter-switch a {
    padding: 0.55rem 0.95rem;
    border-radius: 7px;
    color: var(--text-muted);
    text-decoration: none;
    font-weight: 600;
    transition: background 0.2s ease, color 0.2s ease;
}

.filter-switch a:hover {
    color: var(--text-strong);
    background: rgba(255, 255, 255, 0.82);
}

.filter-switch a.active {
    background: var(--accent-soft);
    color: var(--accent-deep);
}

.topbar.is-hidden {
    display: none;
}

.page-shell-home {
    padding: 0;
    min-height: auto;
}

.page-container-home {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
    display: block;
    gap: 0;
}

.home-interface-layout {
    background:
        radial-gradient(circle at 12% 6%, rgba(255, 56, 92, 0.08), transparent 26rem),
        radial-gradient(circle at 92% 8%, rgba(18, 116, 107, 0.08), transparent 24rem),
        linear-gradient(180deg, #fbfdff 0%, #f4f7fb 38%, #eef2f7 100%);
}

body.home-interface-layout::before,
body.home-interface-layout::after {
    display: block;
}

.home-interface {
    min-height: 100vh;
    padding: 20px;
    background: #ffffff;
}

.home-interface__frame {
    min-height: calc(100vh - 40px);
    padding: 18px 16px 18px 18px;
    background: #f6f6f6;
    border: 1px solid #c5c5c5;
    border-radius: 22px;
    box-shadow: none;
}

.home-interface__header {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 18px;
    align-items: center;
    margin-bottom: 18px;
}

.home-interface__history {
    display: flex;
    gap: 8px;
}

.home-interface__nav-button,
.home-interface__settings,
.home-interface__filter,
.home-interface__info,
.home-interface__map-toolbar button,
.home-interface__summary-tabs button {
    border: 1px solid #c5c5c5;
    background: #f3f3f3;
    color: #111;
    border-radius: 5px;
    box-shadow: none;
}

.home-interface__nav-button {
    width: 28px;
    height: 28px;
    font-size: 16px;
}

.home-interface__tabs {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0;
}

.home-interface__tab {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 44px;
    padding: 0 18px;
    background: #e7e7e7;
    border: 1px solid #c5c5c5;
    border-right: 0;
    color: #111;
    font-family: Montserrat, Inter, "Segoe UI", sans-serif;
    font-size: 15px;
    font-weight: 600;
}

.home-interface__tab:first-child {
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
}

.home-interface__tab:last-child {
    border-right: 1px solid #c5c5c5;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
}

.home-interface__tab.is-active {
    background: #efede6;
}

.home-interface__tab-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 4px;
    background: linear-gradient(180deg, #fff5ec 0%, #ffd7bd 100%);
    color: #8a4b1f;
    font-size: 11px;
    font-weight: 700;
}

.home-interface__tab-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    margin-left: auto;
    padding: 0 0.4rem;
    border-radius: 999px;
    background: #dc2626;
    color: #fff;
    font-size: 0.76rem;
    font-weight: 700;
    line-height: 1;
}

.home-interface__settings {
    width: 42px;
    height: 42px;
    font-size: 24px;
}

.home-interface__body {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 18px;
    min-height: 780px;
}

.home-interface__sidebar {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 14px;
    background: #eaeaea;
    border: 1px solid #c5c5c5;
    border-radius: 28px;
}

.home-interface__search {
    display: grid;
    grid-template-columns: 1fr 34px;
    gap: 8px;
    align-items: center;
}

.home-interface__search input,
.home-interface__selected-object,
.home-interface__canvas-heading h1,
.home-interface__callout,
.home-interface__alert,
.home-interface__lease-card,
.home-interface__summary-tabs,
.home-interface__map-wrap {
    font-family: Montserrat, Inter, "Segoe UI", sans-serif;
}

.home-interface__search input {
    height: 28px;
    padding: 0 10px;
    border: 1px solid #000;
    border-radius: 7px;
    background: #fff;
    color: #111;
    font-size: 14px;
    font-weight: 700;
}

.home-interface__filter {
    width: 34px;
    height: 34px;
    padding: 0;
    display: grid;
    place-items: center;
}

.home-interface__filter span {
    display: block;
    width: 14px;
    height: 2px;
    background: #111;
    margin: 1.5px 0;
    border-radius: 999px;
}

.home-interface__selected-object {
    display: grid;
    gap: 6px;
    padding: 14px 12px;
    background: #fff;
    border-radius: 9px;
    color: #111;
}

.home-interface__selected-object strong {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.2;
}

.home-interface__selected-object span {
    color: #111;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.25;
}

.home-interface__sidebar-actions {
    margin-top: auto;
    display: flex;
    gap: 10px;
}

.home-interface__pill-action {
    flex: 1 1 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    border-radius: 24px;
    font-family: Montserrat, Inter, "Segoe UI", sans-serif;
    font-size: 20px;
    font-weight: 500;
    color: #111;
}

.home-interface__pill-action.is-add {
    background: #97e79f;
}

.home-interface__pill-action.is-remove {
    background: #e79797;
}

.home-interface__canvas {
    display: grid;
    gap: 10px;
}

.home-interface__canvas-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 2px 2px 0;
}

.home-interface__canvas-heading h1 {
    font-size: 22px;
    font-weight: 700;
    color: #111;
}

.home-interface__info {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    font-size: 24px;
    font-weight: 700;
}

.home-interface__map-wrap {
    display: grid;
    gap: 0;
    padding: 0;
    background: #fff;
    border: 3px solid #c5c5c5;
    border-radius: 8px;
    overflow: hidden;
}

.home-interface__map-toolbar {
    position: absolute;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin: 10px;
}

.home-interface__mini-search {
    display: inline-block;
    width: 78px;
    height: 20px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid #d7d7d7;
    border-radius: 3px;
}

.home-interface__map-toolbar button {
    width: 20px;
    height: 20px;
    padding: 0;
    font-size: 12px;
    line-height: 1;
}

.home-interface__map-surface {
    position: relative;
    min-height: 560px;
    overflow: hidden;
}

.home-interface__map-surface > img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-interface__alert {
    position: absolute;
    left: 18px;
    max-width: 190px;
    padding: 12px 14px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.25;
    background: rgba(255, 255, 255, 0.95);
}

.home-interface__alert--success {
    top: 34px;
    color: #01a865;
    background: #d5f8dc;
}

.home-interface__alert--info {
    top: 96px;
    color: #2484c8;
    background: #dff0ff;
}

.home-interface__map-pin {
    position: absolute;
    width: 18px;
    height: 18px;
    border: 0;
    border-radius: 999px;
    padding: 0;
    background: #111;
    color: #fff;
    transform: translate(-50%, -50%);
    display: grid;
    place-items: center;
    font-size: 10px;
    font-weight: 700;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.7);
}

.home-interface__map-pin.is-primary {
    width: 22px;
    height: 22px;
    background: #fff;
    color: #111;
}

.home-interface__callout {
    position: absolute;
    top: 84px;
    right: 88px;
    width: 122px;
    padding: 8px 8px 10px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid #e7e7e7;
    border-radius: 8px;
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
    display: grid;
    gap: 6px;
    color: #111;
}

.home-interface__callout-tag {
    width: fit-content;
    padding: 2px 8px;
    border-radius: 4px;
    background: #fff;
    border: 0.5px solid #000;
    font-size: 8px;
    font-weight: 700;
}

.home-interface__callout-image {
    height: 54px;
    border-radius: 2px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.18) 100%),
        linear-gradient(135deg, #d5dbe7 0%, #c5cedd 44%, #9faac0 100%);
}

.home-interface__callout strong,
.home-interface__callout span,
.home-interface__callout small {
    color: #111;
}

.home-interface__callout strong {
    font-size: 8px;
    line-height: 1.2;
}

.home-interface__callout span {
    font-size: 7px;
    line-height: 1.25;
}

.home-interface__callout small {
    font-size: 8px;
    font-weight: 700;
}

.home-interface__summary-tabs {
    display: inline-flex;
    align-items: center;
    gap: 0;
    padding: 0 0 0 18px;
    margin-top: -2px;
}

.home-interface__summary-tabs button {
    min-width: 146px;
    height: 30px;
    padding: 0 16px;
    border-radius: 4px 4px 0 0;
    border-bottom: 0;
    background: #e7e7e7;
    font-size: 20px;
    font-weight: 600;
}

.home-interface__summary-tabs button:first-child {
    min-width: 68px;
    margin-right: 8px;
}

.home-interface__summary-tabs .is-active {
    background: #fcfbfb;
}

.home-interface__lease-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    padding: 12px 18px 16px;
    background: #fff;
}

.home-interface__lease-card {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    color: #111;
}

.home-interface__lease-icon {
    width: 56px;
    height: 56px;
    border-radius: 999px;
    background: #d9f1e3;
    display: grid;
    place-items: center;
    font-size: 36px;
    font-weight: 500;
}

.home-interface__lease-card strong {
    display: block;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.1;
}

.home-interface__lease-card span,
.home-interface__lease-card small {
    display: block;
    color: #111;
}

.home-interface__lease-card span {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.2;
}

.home-interface__lease-card small {
    font-size: 15px;
    line-height: 1.25;
}

@media (max-width: 720px) {
    h1 {
        font-size: clamp(2.1rem, 11vw, 3rem);
    }

    h2 {
        font-size: clamp(1.45rem, 8vw, 2rem);
    }

    .home-command-grid,
    .home-flow-grid,
    .home-proof-grid,
    .detail-grid,
    .home-interface__body,
    .home-interface__lease-grid {
        grid-template-columns: 1fr;
    }

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

    .hero-summary {
        grid-template-columns: 1fr;
    }

    .mode-switch,
    .filter-switch,
    .topnav,
    .home-interface__tabs {
        width: 100%;
    }

    .topnav a,
    .filter-switch a,
    .mode-switch a {
        flex: 1 1 calc(50% - 0.3rem);
    }

    .field-draft-table-head,
    .field-draft-row {
        grid-template-columns: 1fr;
    }

    .address-picker__bar {
        grid-template-columns: 1fr;
    }

    .home-interface {
        padding: 10px;
    }

    .home-interface__frame {
        min-height: auto;
        padding: 12px;
    }

    .home-interface__header {
        grid-template-columns: 1fr;
        justify-items: stretch;
    }

    .home-interface__tabs {
        justify-content: flex-start;
    }

    .home-interface__tab {
        border-right: 1px solid #c5c5c5;
        border-radius: 5px;
        margin: 0 6px 6px 0;
    }

    .home-interface__sidebar-actions {
        margin-top: 0;
    }

    .home-interface__map-surface {
        min-height: 420px;
    }

    .home-interface__callout {
        right: 20px;
        top: 96px;
    }

    .home-interface__summary-tabs {
        padding-left: 10px;
        flex-wrap: wrap;
    }

    .home-interface__summary-tabs button {
        min-width: 0;
        font-size: 16px;
    }

    .field-draft-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 560px) {
    .summary-strip,
    .stats-grid {
        grid-template-columns: 1fr;
    }

    .panel,
    .detail-card,
    .feature-item,
    .form-panel,
    .table-panel,
    .auth-panel,
    .summary-tile,
    .stat-card,
    .object-map-card,
    .document-key-panel,
    .document-generator-panel,
    .binding-card,
    .source-field-card,
    .lease-tenant-card {
        padding: 1rem;
    }

    .home-interface__sidebar-actions {
        flex-direction: column;
    }

    .home-interface__lease-card {
        grid-template-columns: 1fr;
    }

    .document-word-canvas {
        padding: 1rem;
    }

    .document-word-page {
        padding: 1.75rem 1rem;
        min-height: auto;
    }

    th,
    td {
        padding: 0.78rem 0.82rem;
    }
}

.dashboard-workspace,
.dashboard-filter-stack,
.dashboard-filter-group,
.dashboard-header-actions,
.dashboard-object-card,
.dashboard-object-card__top,
.dashboard-object-card__meta,
.dashboard-object-card__actions,
.dashboard-summary-grid,
.dashboard-summary-card,
.dashboard-map-fallback {
    display: grid;
    gap: 0.75rem;
}

.dashboard-workspace {
    min-width: 0;
}

.dashboard-filter-stack {
    gap: 0.75rem;
}

.dashboard-filter-group {
    gap: 0.4rem;
}

.dashboard-filter-switch {
    margin-bottom: 0;
}

.dashboard-workspace strong {
    color: #f8fcfd;
    font-size: 1rem;
}

.dashboard-workspace small {
    color: rgba(228, 242, 241, 0.74);
}

.dashboard-header-actions {
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    align-items: center;
}

.dashboard-header-actions form {
    margin: 0;
}

.home-interface__sidebar {
    grid-template-rows: auto minmax(0, 1fr) auto;
}

.dashboard-object-list {
    display: grid;
    gap: 0.75rem;
    min-height: 0;
    overflow: auto;
    padding-right: 0.2rem;
}

.dashboard-object-card {
    padding: 1rem;
    border: 1px solid rgba(108, 126, 125, 0.28);
    border-radius: 8px;
    background: rgba(8, 26, 25, 0.58);
    color: rgba(233, 243, 242, 0.94);
    cursor: pointer;
    transition:
        border-color 0.2s ease,
        transform 0.2s ease,
        background-color 0.2s ease;
}

.dashboard-object-card:hover {
    border-color: rgba(82, 224, 196, 0.42);
    transform: translateY(-1px);
}

.dashboard-object-card.is-active {
    border-color: rgba(82, 224, 196, 0.8);
    background: rgba(10, 37, 34, 0.82);
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.18);
}

.dashboard-object-card strong {
    color: #ffffff;
    font-size: 1rem;
}

.dashboard-object-card > span {
    color: rgba(210, 225, 223, 0.84);
    font-size: 0.92rem;
    line-height: 1.45;
}

.dashboard-object-card__top,
.dashboard-object-card__meta,
.dashboard-object-card__actions {
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    align-items: center;
    justify-content: space-between;
}

.dashboard-object-card__meta {
    gap: 1rem;
    justify-content: start;
    color: rgba(188, 211, 208, 0.82);
    font-size: 0.84rem;
}

.dashboard-object-card__actions {
    align-items: center;
}

.dashboard-object-card__actions .btn-secondary {
    min-height: 2.45rem;
    padding: 0.55rem 0.8rem;
}

.dashboard-object-card__actions .btn-secondary:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.home-interface__map-surface {
    min-height: 430px;
}

.home-interface__map-canvas {
    position: absolute;
    inset: 0;
    z-index: 1;
}

.home-interface__alert {
    display: grid;
    gap: 0.2rem;
    max-width: min(20rem, calc(100% - 2rem));
    text-decoration: none;
    z-index: 5;
}

.home-interface__alert strong,
.home-interface__alert span {
    color: inherit;
    line-height: 1.3;
}

.dashboard-callout {
    width: min(18rem, calc(100% - 2rem));
    z-index: 5;
}

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

.dashboard-summary-card {
    min-height: 12rem;
    padding: 1.1rem 1.15rem;
    border: 1px solid rgba(108, 126, 125, 0.18);
    border-radius: 8px;
    background: rgba(246, 249, 250, 0.94);
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.08);
}

.dashboard-summary-card p {
    margin: 0;
    color: var(--text-muted);
    line-height: 1.5;
}

.dashboard-summary-card[hidden] {
    display: none !important;
}

.dashboard-map-fallback {
    min-height: 430px;
    align-content: center;
}

@media (max-width: 1080px) {
    .dashboard-workspace {
        grid-column: 1 / -1;
    }

    .dashboard-header-actions {
        justify-self: end;
    }
}

@media (max-width: 860px) {
    .dashboard-summary-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-object-card__top,
    .dashboard-object-card__meta,
    .dashboard-object-card__actions {
        grid-auto-flow: row;
        justify-content: start;
    }

    .home-interface__map-surface,
    .dashboard-map-fallback {
        min-height: 360px;
    }
}

.home-interface--dashboard {
    min-height: auto;
    padding: 1.5rem 0 2rem;
    background: transparent;
}

.home-interface--dashboard .home-interface__frame {
    display: flex;
    flex-direction: column;
    width: min(100% - 2.5rem, 1780px);
    min-height: 0;
    margin: 0 auto;
    padding: 1rem;
    border-color: var(--border);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: var(--shadow-md);
}

.home-interface--dashboard .home-interface__header {
    display: none;
    flex: 0 0 auto;
    gap: 1rem;
    margin-bottom: 0;
    padding: 0.2rem;
}

.home-interface--dashboard .home-interface__tab {
    min-height: 40px;
    padding: 0 1rem;
    border-color: var(--border-strong);
    background: var(--surface-muted);
    color: var(--text);
    font-family: inherit;
    font-size: 0.92rem;
}

.home-interface--dashboard .home-interface__tab.is-active {
    background: var(--surface);
    color: var(--text-strong);
    box-shadow: inset 0 -2px 0 var(--accent);
}

.home-interface--dashboard .home-interface__tab-icon {
    background: var(--accent-soft);
    color: var(--accent-deep);
}

.home-interface--dashboard .home-interface__tab-badge {
    background: #dc2626;
    color: #fff;
}

.home-interface--dashboard .home-interface__settings,
.home-interface--dashboard .home-interface__filter,
.home-interface--dashboard .home-interface__info,
.home-interface--dashboard .home-interface__summary-tabs button {
    border-color: var(--border-strong);
    background: var(--surface);
    color: var(--text-strong);
}

.home-interface--dashboard .home-interface__settings,
.home-interface--dashboard .home-interface__info {
    border-radius: var(--radius-sm);
}

.home-interface--dashboard .home-interface__search input {
    height: 2.45rem;
    border-color: var(--border-strong);
    color: var(--text);
    font-family: inherit;
    font-size: 0.92rem;
    font-weight: 500;
}

.home-interface--dashboard .home-interface__filter span {
    background: var(--text-muted);
}

.home-interface--dashboard .dashboard-workspace strong {
    color: #111;
}

.home-interface--dashboard .dashboard-workspace small {
    color: #7b8491;
}

.home-interface--dashboard .dashboard-workspace .eyebrow {
    color: var(--accent-deep);
}

.home-interface--dashboard .home-interface__body {
    flex: 0 0 auto;
    grid-template-columns: minmax(340px, 380px) minmax(0, 1fr);
    align-items: stretch;
    min-height: 0;
}

.home-interface--dashboard .home-interface__sidebar,
.home-interface--dashboard .home-interface__canvas,
.home-interface--dashboard .home-interface__map-wrap,
.home-interface--dashboard .dashboard-object-card {
    min-width: 0;
}

.home-interface--dashboard .home-interface__sidebar {
    overflow: hidden;
    max-height: calc(100svh - 8rem);
    padding: 1rem;
    border-color: var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.home-interface--dashboard .home-interface__sidebar-actions {
    margin-top: 0;
    gap: 0.75rem;
}

.home-interface--dashboard .home-interface__pill-action {
    min-height: 2.75rem;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius);
    font-family: inherit;
    font-size: 0.95rem;
    font-weight: 700;
}

.home-interface--dashboard .home-interface__pill-action.is-add {
    background: var(--accent);
    color: #fff;
}

.home-interface--dashboard .dashboard-sidebar-add {
    flex: 0 0 auto;
    align-self: flex-start;
    width: 11.5rem;
    max-width: 100%;
    white-space: nowrap;
}

.home-interface--dashboard .home-interface__pill-action.is-remove {
    background: var(--surface-muted);
    color: var(--text-strong);
}

.home-interface--dashboard .dashboard-object-list {
    align-content: start;
    flex: 1 1 auto;
    min-height: 0;
    max-height: calc(100svh - 18rem);
    padding: 0 0.35rem 0.9rem 0;
    scrollbar-gutter: stable;
}

.home-interface--dashboard .dashboard-object-card {
    gap: 0.55rem;
    padding: 0.85rem;
    overflow: hidden;
    border-color: var(--border);
    background: var(--surface-alt);
    color: var(--text);
    box-shadow: none;
}

.home-interface--dashboard .dashboard-object-card:hover {
    border-color: rgba(255, 56, 92, 0.28);
    background: var(--surface);
}

.home-interface--dashboard .dashboard-object-card.is-active {
    border-color: rgba(255, 56, 92, 0.46);
    background: var(--accent-soft);
    box-shadow: var(--focus-ring);
}

.home-interface--dashboard .dashboard-object-card strong {
    color: var(--text-strong);
}

.home-interface--dashboard .dashboard-object-card > span,
.home-interface--dashboard .dashboard-object-card__meta,
.home-interface--dashboard .dashboard-object-card__meta span {
    color: var(--text-muted);
}

.home-interface--dashboard .dashboard-object-card strong,
.home-interface--dashboard .dashboard-object-card > span,
.home-interface--dashboard .dashboard-object-card__meta span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.home-interface--dashboard .dashboard-object-card__top,
.home-interface--dashboard .dashboard-object-card__meta,
.home-interface--dashboard .dashboard-object-card__actions {
    display: flex;
    flex-wrap: wrap;
    grid-auto-flow: initial;
    grid-auto-columns: initial;
    align-items: center;
    justify-content: flex-start;
}

.home-interface--dashboard .dashboard-object-card__top {
    justify-content: space-between;
}

.home-interface--dashboard .dashboard-object-card__meta {
    gap: 0.35rem 0.8rem;
}

.home-interface--dashboard .dashboard-object-card__actions {
    gap: 0.5rem;
}

.home-interface--dashboard .dashboard-object-card__actions .btn-secondary {
    min-height: 2.2rem;
    padding: 0.45rem 0.7rem;
}

.home-interface--dashboard .home-interface__canvas {
    display: flex;
    flex-direction: column;
    align-content: start;
    gap: 0.75rem;
    min-height: 0;
}

.home-interface--dashboard .home-interface__canvas-heading {
    flex: 0 0 auto;
    align-items: end;
    padding-top: 0;
}

.home-interface--dashboard .home-interface__canvas-heading h1 {
    font-size: clamp(20px, 1.25vw, 24px);
    line-height: 1.15;
    font-family: inherit;
    color: var(--text-strong);
}

.home-interface--dashboard .home-interface__map-wrap {
    display: flex;
    flex: 0 0 auto;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.home-interface--dashboard .home-interface__map-surface,
.home-interface--dashboard .dashboard-map-fallback {
    height: clamp(500px, 58svh, 690px);
    min-height: 500px;
}

.home-interface--dashboard .home-interface__alerts {
    top: 1rem;
    left: 4.4rem;
    gap: 0.65rem;
}

.home-interface--dashboard .home-interface__alert {
    padding: 0.85rem 1rem;
    border: 1px solid rgba(18, 116, 107, 0.12);
    border-radius: var(--radius);
    font-family: inherit;
    font-size: 0.88rem;
    font-weight: 700;
    box-shadow: var(--shadow-sm);
}

.home-interface--dashboard .home-interface__alert--success {
    color: var(--teal);
    background: var(--teal-soft);
}

.home-interface--dashboard .home-interface__alert--info {
    color: #21679f;
    background: var(--sky-soft);
}

.home-interface--dashboard .home-interface__alert--danger {
    color: #991b1b;
    background: rgba(254, 226, 226, 0.94);
    border-color: rgba(220, 38, 38, 0.22);
}

.home-interface--dashboard .dashboard-callout {
    top: 1.4rem;
    right: 1.4rem;
    width: min(18rem, calc(100% - 2rem));
    padding: 0.85rem;
    border-color: var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
}

.home-interface--dashboard .home-interface__callout-tag {
    border-color: var(--border-strong);
    background: var(--surface-muted);
    color: var(--text-strong);
    font-size: 0.72rem;
}

.home-interface--dashboard .home-interface__callout-image {
    height: 4.25rem;
    border-radius: var(--radius-sm);
}

.home-interface--dashboard .home-interface__callout strong {
    font-size: 0.95rem;
}

.home-interface--dashboard .home-interface__callout span,
.home-interface--dashboard .home-interface__callout small {
    font-size: 0.78rem;
    line-height: 1.35;
}

.home-interface--dashboard .home-interface__summary-tabs {
    padding: 0.75rem 1rem 0;
    margin-top: 0;
    border-top: 1px solid var(--border);
}

.home-interface--dashboard .home-interface__summary-tabs button {
    min-width: auto;
    height: 2.4rem;
    padding: 0 1rem;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    font-family: inherit;
    font-size: 0.95rem;
}

.home-interface--dashboard .home-interface__summary-tabs button:first-child {
    min-width: auto;
    margin-right: 0.5rem;
}

.home-interface--dashboard .home-interface__summary-tabs .is-active {
    border-color: rgba(255, 56, 92, 0.28);
    background: var(--accent-soft);
    color: var(--accent-deep);
}

.home-interface--dashboard .dashboard-summary-grid {
    gap: 0;
    padding: 1rem;
}

.home-interface--dashboard .dashboard-summary-card {
    min-height: 9rem;
    border-radius: var(--radius);
    background: var(--surface-alt);
    box-shadow: none;
}

.home-interface--dashboard .home-interface__map-canvas,
.home-interface--dashboard .leaflet-container {
    width: 100%;
    height: 100%;
}

.home-interface--dashboard .leaflet-top.leaflet-left {
    top: 0.65rem;
    left: 0.65rem;
}

.home-interface__alerts {
    position: absolute;
    top: 24px;
    left: 18px;
    z-index: 5;
    display: grid;
    gap: 8px;
    width: min(330px, calc(100% - 36px));
    pointer-events: none;
}

.home-interface__alerts .home-interface__alert {
    position: static;
    top: auto;
    left: auto;
    width: 100%;
    max-width: none;
    pointer-events: auto;
}

.home-interface__alerts .home-interface__alert--success,
.home-interface__alerts .home-interface__alert--info,
.home-interface__alerts .home-interface__alert--danger {
    top: auto;
}

@media (max-width: 1180px) {
    .home-interface--dashboard .home-interface__body {
        grid-template-columns: minmax(330px, 360px) minmax(0, 1fr);
    }
}

@media (max-width: 900px) {
    .home-interface--dashboard .home-interface__body {
        grid-template-columns: 1fr;
    }

    .home-interface--dashboard .home-interface__sidebar {
        max-height: none;
    }

    .home-interface--dashboard .dashboard-object-list {
        max-height: 24rem;
    }

    .home-interface--dashboard .home-interface__map-surface,
    .home-interface--dashboard .dashboard-map-fallback {
        height: 460px;
        min-height: 460px;
    }

    .home-interface--dashboard .home-interface__alerts {
        left: 4rem;
        width: min(300px, calc(100% - 5rem));
    }
}

@media (prefers-reduced-motion: reduce) {
    html:focus-within {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation: none !important;
        transition: none !important;
    }
}

.share-link-box {
    display: grid;
    gap: 0.35rem;
    max-width: 100%;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(18, 116, 107, 0.18);
    border-radius: var(--radius);
    background: var(--teal-soft);
}

.share-link-box span {
    color: var(--teal);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.share-link-box a {
    overflow-wrap: anywhere;
    color: var(--text-strong);
    font-weight: 700;
}

.public-space-hero,
.public-space-grid,
.public-space-facts {
    display: grid;
    gap: 1rem;
}

.public-space-hero {
    padding: clamp(1.5rem, 3vw, 2.5rem);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background:
        linear-gradient(135deg, rgba(255, 56, 92, 0.08), rgba(255, 255, 255, 0.98) 44%, rgba(18, 116, 107, 0.12));
    box-shadow: var(--shadow-md);
}

.public-space-facts {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.public-space-facts > div {
    display: grid;
    gap: 0.35rem;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.9);
}

.public-space-facts strong {
    font-size: 1.35rem;
    line-height: 1.1;
}

.public-space-grid {
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.75fr);
    align-items: start;
}

.public-space-region {
    fill: rgba(18, 116, 107, 0.26);
    stroke: #12746b;
    stroke-width: 4;
}

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

.assistant-sidebar,
.assistant-chat {
    display: grid;
    gap: 1rem;
}

.assistant-conversation-list {
    display: grid;
    gap: 0.5rem;
}

.assistant-conversation {
    display: grid;
    gap: 0.25rem;
    padding: 0.75rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    text-decoration: none;
}

.assistant-conversation.active,
.assistant-conversation:hover {
    border-color: rgba(255, 56, 92, 0.24);
    background: var(--accent-soft);
}

.assistant-conversation span,
.assistant-message-meta span {
    color: var(--text-muted);
    font-size: 0.82rem;
}

.assistant-messages {
    display: grid;
    gap: 0.85rem;
}

.assistant-message {
    display: grid;
    gap: 0.5rem;
    max-width: 78ch;
    padding: 0.9rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.92);
}

.user-message {
    justify-self: end;
    background: rgba(255, 56, 92, 0.08);
}

.assistant-message-response {
    justify-self: start;
}

.assistant-message p {
    margin: 0;
    white-space: pre-wrap;
}

.assistant-message-meta,
.assistant-compose-row,
.assistant-attachments {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.assistant-attachments span {
    padding: 0.3rem 0.5rem;
    border-radius: 8px;
    background: rgba(19, 31, 45, 0.06);
    color: var(--text-muted);
    font-size: 0.84rem;
}

.assistant-pending-actions {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
    border: 1px solid rgba(255, 56, 92, 0.22);
    border-radius: 8px;
    background: rgba(255, 56, 92, 0.06);
}

.assistant-pending-action {
    display: grid;
    gap: 0.65rem;
    padding: 0.85rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
}

.assistant-pending-action > div,
.assistant-action-form {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.assistant-pending-action span {
    color: var(--text-muted);
    font-size: 0.82rem;
}

.assistant-pending-action p {
    margin: 0;
    white-space: pre-wrap;
}

.assistant-pending-action pre {
    overflow-x: auto;
    margin: 0.5rem 0 0;
    padding: 0.75rem;
    border-radius: 8px;
    background: rgba(19, 31, 45, 0.07);
    font-size: 0.84rem;
}

.assistant-compose {
    display: grid;
    gap: 0.75rem;
    padding-top: 1rem;
}

.assistant-compose textarea {
    min-height: 8rem;
}

@media (max-width: 900px) {
    .public-space-grid {
        grid-template-columns: 1fr;
    }

    .assistant-layout {
        grid-template-columns: 1fr;
    }
}

.badge-parking {
    background: #f4edff;
    border-color: #dfd0ff;
    color: #6d3fd6;
}

.badge-apartment {
    background: #fff0f1;
    border-color: #ffcfd5;
    color: #c63857;
}

.badge-land-plot {
    background: #edf9ef;
    border-color: #caebd0;
    color: #257a3a;
}

.badge-equipment {
    background: #eef3f9;
    border-color: #d7e0ec;
    color: #49627e;
}

.badge-billboard {
    background: #fff0f9;
    border-color: #ffd2ec;
    color: #b43b83;
}

.object-photo-preview {
    display: grid;
    gap: 0.55rem;
}

.object-photo-preview img {
    width: 100%;
    max-width: 24rem;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
    box-shadow: var(--shadow-sm);
}

.object-photo-preview--details img {
    max-width: 100%;
    aspect-ratio: 16 / 10;
}

.object-photo-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.9rem;
}

.object-photo-gallery__item {
    position: relative;
    display: grid;
    gap: 0.75rem;
    padding: 0.85rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
}

.object-photo-gallery__item[draggable="true"],
.object-photo-slider__thumb[draggable="true"] {
    cursor: grab;
}

.object-photo-gallery__item.is-dragging,
.object-photo-slider__thumb.is-dragging {
    opacity: 0.56;
    cursor: grabbing;
}

.object-photo-gallery__item.is-drop-before,
.object-photo-gallery__item.is-drop-after,
.object-photo-slider__thumb.is-drop-before,
.object-photo-slider__thumb.is-drop-after {
    outline: 2px solid var(--brand);
    outline-offset: 3px;
}

.object-photo-gallery__thumb {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
}

.object-photo-slider {
    display: grid;
    gap: 0.9rem;
}

.object-photo-slider__stage {
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.object-photo-slider__stage img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    display: block;
}

.object-photo-slider__meta {
    display: grid;
    gap: 0.2rem;
}

.object-photo-slider__thumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.object-photo-slider__thumb {
    width: 5.5rem;
    padding: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.object-photo-slider__thumb:hover,
.object-photo-slider__thumb:focus-visible {
    border-color: var(--brand);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

.object-photo-slider__thumb.is-active {
    border-color: var(--brand);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--brand) 35%, transparent);
}

.object-photo-slider__thumb img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    display: block;
}

.plan-zoom-group {
    display: inline-flex;
    flex-wrap: nowrap;
    gap: 0.55rem;
}

.plan-stage__viewport {
    position: absolute;
    inset: 0;
    overflow: hidden;
    cursor: grab;
    touch-action: none;
}

.plan-stage__viewport.is-panning {
    cursor: grabbing;
}

.plan-stage__content {
    position: absolute;
    inset: 0;
    transform-origin: top left;
    will-change: transform;
}

.plan-stage__content img,
.plan-stage__content .plan-overlay-svg {
    user-select: none;
    -webkit-user-drag: none;
}

.plan-region-label {
    fill: var(--text-strong);
    font-size: 16px;
    font-weight: 700;
    paint-order: stroke;
    stroke: rgba(255, 255, 255, 0.92);
    stroke-width: 4px;
    stroke-linejoin: round;
    vector-effect: non-scaling-stroke;
    pointer-events: none;
}

.plan-region-label--secondary {
    font-size: 12px;
    fill: rgba(19, 31, 45, 0.8);
    stroke-width: 3px;
}

.plan-region.is-filter-match {
    fill: rgba(124, 58, 237, 0.24);
    stroke: rgba(124, 58, 237, 0.9);
}

.plan-region.is-filter-muted {
    opacity: 0.38;
}

.plan-payment-action {
    cursor: pointer;
    text-decoration: none;
}

.plan-payment-action__button {
    fill: #f59e0b;
    stroke: rgba(255, 255, 255, 0.95);
    stroke-width: 3;
    vector-effect: non-scaling-stroke;
    filter: drop-shadow(0 10px 18px rgba(15, 23, 42, 0.22));
}

.plan-payment-action__text {
    fill: #ffffff;
    font-size: 20px;
    font-weight: 800;
    pointer-events: none;
}

.plan-payment-action.payment-indicator--today .plan-payment-action__button,
.plan-payment-action.payment-indicator--overdue .plan-payment-action__button {
    fill: #dc2626;
}

.plan-payment-action.payment-indicator--debt .plan-payment-action__button {
    fill: #111827;
}

.plan-payment-action:hover .plan-payment-action__button,
.plan-payment-action:focus-visible .plan-payment-action__button {
    stroke-width: 4;
}

.plan-invoice-delivery-action {
    cursor: pointer;
    outline: none;
}

.plan-invoice-delivery-action--static {
    cursor: default;
}

.plan-invoice-delivery-action__button {
    fill: rgba(255, 255, 255, 0.96);
    stroke: #2563eb;
    stroke-width: 3;
    vector-effect: non-scaling-stroke;
    filter: drop-shadow(0 10px 18px rgba(15, 23, 42, 0.2));
}

.plan-invoice-delivery-action__icon {
    pointer-events: none;
    filter: drop-shadow(0 6px 10px rgba(15, 23, 42, 0.22));
}

.plan-invoice-delivery-action.payment-indicator--today .plan-invoice-delivery-action__button,
.plan-invoice-delivery-action.payment-indicator--overdue .plan-invoice-delivery-action__button {
    stroke: #dc2626;
}

.plan-invoice-delivery-action:hover .plan-invoice-delivery-action__button,
.plan-invoice-delivery-action:focus-visible .plan-invoice-delivery-action__button {
    stroke-width: 4;
}

.plan-invoice-delivery-action--static:hover .plan-invoice-delivery-action__button {
    stroke-width: 3;
}

.plan-lease-expiration-action {
    cursor: default;
    outline: none;
}

.plan-lease-expiration-action__icon,
.plan-lease-expiration-action__mail-icon {
    pointer-events: none;
    filter: drop-shadow(0 8px 14px rgba(15, 23, 42, 0.24));
}

.plan-lease-expiration-action--mail {
    cursor: pointer;
}

.plan-lease-expiration-action__button {
    fill: rgba(255, 255, 255, 0.94);
    stroke: #f59e0b;
    stroke-width: 3;
    vector-effect: non-scaling-stroke;
    filter: drop-shadow(0 10px 18px rgba(15, 23, 42, 0.2));
}

.plan-lease-expiration-action.payment-indicator--today .plan-lease-expiration-action__button,
.plan-lease-expiration-action.payment-indicator--overdue .plan-lease-expiration-action__button {
    stroke: #dc2626;
}

.plan-lease-expiration-action--mail:hover .plan-lease-expiration-action__button,
.plan-lease-expiration-action--mail:focus-visible .plan-lease-expiration-action__button {
    stroke-width: 4;
}

.plan-vertex-outline {
    fill: rgba(255, 255, 255, 0.96);
    stroke: rgba(19, 31, 45, 0.32);
    stroke-width: 2;
    vector-effect: non-scaling-stroke;
}

.plan-vertex-handle {
    fill: #ff385c;
    stroke: #ffffff;
    stroke-width: 2;
    vector-effect: non-scaling-stroke;
    cursor: pointer;
}

.plan-draft-region {
    fill: rgba(255, 56, 92, 0.12);
    stroke: #ff385c;
    stroke-width: 2.5;
    stroke-dasharray: 8 6;
    vector-effect: non-scaling-stroke;
}

.plan-polygon-guideline {
    fill: none;
    stroke: rgba(19, 31, 45, 0.5);
    stroke-width: 2;
    stroke-dasharray: 5 5;
    vector-effect: non-scaling-stroke;
}

.table-checkbox-cell {
    width: 2.75rem;
    text-align: center;
}

.table-checkbox-cell input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
}

tr[data-space-row].is-selected {
    background: rgba(255, 56, 92, 0.08);
}

tr[data-space-row].is-selected td {
    box-shadow: inset 0 1px 0 rgba(255, 56, 92, 0.08), inset 0 -1px 0 rgba(255, 56, 92, 0.08);
}

.dashboard-filter-form {
    display: grid;
    gap: 0.85rem;
}

.dashboard-filter-group {
    display: grid;
    gap: 0.35rem;
}

.dashboard-filter-select {
    width: 100%;
    min-height: 2.7rem;
    padding: 0.5rem 0.8rem;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.96);
    color: var(--text-strong);
    font: inherit;
}

.home-interface__callout-image.has-photo {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.floor-bulk-panel {
    display: grid;
    gap: 0.85rem;
    margin-bottom: 1rem;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--surface-muted) 65%, white);
}

.floor-bulk-panel[hidden],
.floor-bulk-panel__actions [hidden] {
    display: none !important;
}

.floor-bulk-panel__message {
    color: var(--text-muted);
}

.floor-bulk-panel__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 0.85rem;
}

.table-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 0.75rem;
}

.checkbox-field {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2.75rem;
    color: var(--text-strong);
    font-weight: 600;
}

.floor-bulk-panel__actions .inline-form {
    align-items: end;
}

.floor-bulk-panel__actions [data-floor-bulk-assign] {
    display: grid;
    grid-template-columns: minmax(18rem, 1fr) auto;
    gap: 0.75rem;
    flex: 1 1 34rem;
}

.floor-bulk-panel__actions [data-floor-bulk-clear] {
    align-self: end;
}

.payment-indicator {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.45rem;
    height: 1.45rem;
    margin-left: 0.45rem;
    padding: 0 0.35rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 700;
    line-height: 1;
    color: #fff;
    background: #f59e0b;
    vertical-align: middle;
}

a.payment-indicator {
    text-decoration: none;
}

.payment-indicator-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: inherit;
    text-decoration: none;
}

.payment-indicator-link .payment-indicator {
    margin-left: 0;
}

.payment-indicator-link:hover span:last-child,
.payment-indicator-link:focus-visible span:last-child {
    text-decoration: underline;
}

.payment-indicator--soon {
    background: #f59e0b;
}

.payment-indicator--overdue,
.payment-indicator--today {
    background: #dc2626;
}

.payment-indicator--debt {
    background: #111827;
}

.payment-schedule-pay-button {
    border: 0;
    cursor: pointer;
}

.invoice-delivery-button {
    display: inline-grid;
    place-items: center;
    width: 2.1rem;
    height: 2.1rem;
    padding: 0;
    border: 1px solid rgba(37, 99, 235, 0.28);
    border-radius: 999px;
    background: #ffffff;
    cursor: pointer;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.invoice-delivery-button--static {
    cursor: default;
    transform: none;
}

.invoice-delivery-button img {
    width: 1.45rem;
    height: 1.45rem;
    object-fit: contain;
}

.invoice-delivery-button:hover,
.invoice-delivery-button:focus-visible {
    border-color: #2563eb;
    transform: translateY(-1px);
}

.invoice-delivery-button--static:hover,
.invoice-delivery-button--static:focus-visible {
    border-color: rgba(37, 99, 235, 0.28);
    transform: none;
}

.payment-status {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 600;
}

.payment-status--scheduled {
    background: rgba(59, 130, 246, 0.12);
    color: #1d4ed8;
}

.payment-status--soon {
    background: rgba(245, 158, 11, 0.16);
    color: #b45309;
}

.payment-status--today,
.payment-status--overdue {
    background: rgba(220, 38, 38, 0.14);
    color: #b91c1c;
}

.payment-status--debt {
    background: rgba(17, 24, 39, 0.12);
    color: #111827;
}

.payment-status--paid {
    background: rgba(16, 185, 129, 0.14);
    color: #047857;
}

.payment-schedule-toolbar {
    display: flex;
    justify-content: flex-end;
}

[data-payment-schedule-list].is-hiding-paid [data-payment-paid="true"] {
    display: none;
}

.payment-popup {
    font-weight: 600;
}

.payment-schedule-form {
    gap: 1rem;
}

.payment-schedule-cadence-field {
    max-width: 18rem;
}

.payment-schedule-composer {
    display: grid;
    gap: 1rem;
}

.payment-schedule-composer__workspace {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(21rem, 0.95fr);
    gap: 1rem;
    align-items: start;
}

.payment-schedule-composer__toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.payment-schedule-composer__heading {
    display: grid;
    gap: 0.2rem;
}

.payment-schedule-listview {
    display: grid;
    gap: 0.6rem;
}

.payment-schedule-listview__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
    min-height: 3.1rem;
    padding: 0.8rem 0.9rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
    text-align: left;
    box-shadow: none;
}

.payment-schedule-listview__item:hover,
.payment-schedule-listview__item:focus-visible {
    border-color: rgba(255, 56, 92, 0.25);
    background: #fff;
}

.payment-schedule-listview__item.is-active {
    border-color: rgba(255, 56, 92, 0.4);
    background: var(--accent-soft);
}

.payment-schedule-listview__item.is-complete .payment-schedule-listview__value {
    color: var(--text-strong);
}

.payment-schedule-listview__item--readonly {
    cursor: default;
}

.payment-schedule-listview__item--readonly:hover,
.payment-schedule-listview__item--readonly:focus-visible {
    transform: none;
    box-shadow: none;
}

.tenant-portal-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    gap: 1rem;
    align-items: start;
}

.tenant-portal-page {
    display: grid;
    gap: 1rem;
    max-width: 100%;
    min-width: 0;
    overflow-x: clip;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.tenant-portal-gate {
    width: min(100%, 30rem);
    max-width: 30rem;
    margin: 0 auto;
    max-inline-size: 100%;
    overflow-x: clip;
    overflow-y: visible;
}

.tenant-portal-signin {
    max-width: 30rem;
}

.tenant-pin-entry {
    display: grid;
    gap: 0.65rem;
    min-width: 0;
    max-width: 100%;
}

.tenant-pin-entry__boxes {
    display: grid;
    grid-template-columns: repeat(var(--tenant-pin-slot-count, 4), minmax(0, 1fr));
    gap: 0.7rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: clip;
}

.tenant-pin-entry__slot-input {
    min-height: 3.4rem;
    width: 100%;
    max-width: 100%;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--surface) 92%, white);
    color: var(--text-strong);
    font-size: 1.6rem;
    font-weight: 800;
    text-align: center;
    padding-inline: 0;
    overflow: hidden;
    text-overflow: clip;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
    appearance: none;
    -webkit-appearance: none;
}

.tenant-pin-entry__slot-input:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--brand) 72%, white);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 14%, transparent);
    transform: translateY(-1px);
}

.tenant-pin-entry__slot-input:not(:placeholder-shown),
.tenant-pin-entry__slot-input[value] {
    background: color-mix(in srgb, var(--surface-muted) 52%, white);
}

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

.tenant-request-card {
    display: grid;
    gap: 0.7rem;
    padding: 0.95rem 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
}

.tenant-request-card__header {
    display: flex;
    flex-wrap: wrap;
    align-items: start;
    justify-content: space-between;
    gap: 0.75rem;
}

.tenant-request-card__media {
    display: grid;
    gap: 0.55rem;
}

.tenant-request-card__photo {
    width: 100%;
    max-width: 18rem;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
}

.tenant-portal-plan-picker,
.tenant-request-plan {
    display: grid;
    gap: 0.55rem;
}

.tenant-portal-plan-picker .space-preview,
.tenant-request-plan .space-preview {
    cursor: crosshair;
}

.tenant-request-plan .space-preview {
    cursor: default;
}

.tenant-portal-plan-picker__marker {
    position: absolute;
    width: 1rem;
    height: 1rem;
    border: 3px solid #ffffff;
    border-radius: 999px;
    background: #dc2626;
    box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.18), 0 8px 18px rgba(15, 23, 42, 0.22);
    transform: translate(-50%, -50%);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.18s ease;
}

.tenant-portal-plan-picker__marker.is-visible {
    opacity: 1;
}

.tenant-portal-access {
    display: grid;
    gap: 0.85rem;
}

.tenant-portal-access__field {
    display: grid;
    gap: 0.35rem;
}

.tenant-portal-access__field input {
    width: 100%;
}

@media (max-width: 960px) {
    .tenant-portal-grid {
        grid-template-columns: 1fr;
    }
}

.payment-schedule-listview__month {
    color: var(--text-soft);
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
}

.payment-schedule-listview__value {
    color: var(--text-muted);
    font-size: 1rem;
    font-weight: 700;
}

.payment-schedule-listview__meta,
.payment-schedule-listview__aside {
    display: grid;
    gap: 0.3rem;
}

.payment-schedule-listview__aside {
    justify-items: end;
}

.payment-schedule-picker {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: #fff;
    will-change: transform;
}

@media (max-width: 900px) {
    .payment-schedule-composer__workspace {
        grid-template-columns: 1fr;
    }

    .payment-schedule-picker {
        margin-top: 0 !important;
        transform: none !important;
    }
}

.payment-schedule-picker__header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.75rem;
}

.payment-schedule-picker__title-group {
    display: grid;
    gap: 0.25rem;
    justify-items: center;
    text-align: center;
}

.payment-schedule-picker__title-group strong {
    font-size: 1.05rem;
}

.payment-schedule-picker__weekdays,
.payment-schedule-picker__days {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.4rem;
}

.payment-schedule-picker__weekdays span {
    color: var(--text-soft);
    font-size: 0.78rem;
    font-weight: 700;
    text-align: center;
    text-transform: uppercase;
}

.payment-schedule-picker__day {
    min-height: 2.8rem;
    padding: 0.45rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
    color: var(--text-strong);
    font-weight: 600;
    box-shadow: none;
}

.payment-schedule-picker__day:hover,
.payment-schedule-picker__day:focus-visible {
    border-color: rgba(255, 56, 92, 0.3);
    background: #fff;
}

.payment-schedule-picker__day.is-selected {
    border-color: rgba(255, 56, 92, 0.45);
    background: var(--accent-soft);
    color: var(--accent-deep);
}

.payment-schedule-picker__day.is-disabled,
.payment-schedule-picker__day:disabled {
    cursor: not-allowed;
    opacity: 0.45;
}

.payment-schedule-picker__day--blank {
    min-height: 2.8rem;
}

.payment-schedule-picker__footer {
    display: flex;
    justify-content: flex-end;
}

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

.attention-issue {
    display: grid;
    gap: 0.35rem;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: inherit;
    text-decoration: none;
    background: var(--surface);
    transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.attention-issue:hover,
.attention-issue:focus-visible {
    border-color: var(--brand);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

.attention-issue.payment-indicator--soon {
    border-color: rgba(245, 158, 11, 0.45);
}

.attention-issue.payment-indicator--overdue,
.attention-issue.payment-indicator--today {
    border-color: rgba(220, 38, 38, 0.45);
}

.attention-issue.payment-indicator--debt {
    border-color: rgba(17, 24, 39, 0.42);
}

.attention-issue--warning {
    border-color: rgba(245, 158, 11, 0.45);
}

.attention-issue--danger {
    border-color: rgba(220, 38, 38, 0.45);
}

.map-payment-indicator {
    border: 0;
    border-radius: 999px;
    background: #f59e0b;
    color: #fff;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.22);
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.28rem 0.38rem;
}

.map-payment-indicator.payment-indicator--today {
    background: #dc2626;
}

.map-payment-indicator.payment-indicator--overdue {
    background: #dc2626;
}

.map-payment-indicator.payment-indicator--debt {
    background: #111827;
}

.map-payment-marker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: 0;
    border-radius: 999px;
    background: #f59e0b;
    color: #fff;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.22);
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
}

.map-payment-marker.payment-indicator--today,
.map-payment-marker.payment-indicator--overdue {
    background: #dc2626;
}

.map-payment-marker.payment-indicator--debt {
    background: #111827;
}

.map-balloon__payment {
    margin: 0;
    font-weight: 600;
}

.map-balloon__payment a {
    color: inherit;
    text-decoration: none;
}
