:root {
  --kg-font: "Plus Jakarta Sans", "Segoe UI", Arial, sans-serif;
  --kg-bg: #eef3f6;
  --kg-bg-elevated: #f6fafc;
  --kg-surface: #ffffff;
  --kg-surface-alt: #f7fafb;
  --kg-text: #12313d;
  --kg-text-muted: #5f7680;
  --kg-border: #d4e0e6;
  --kg-border-strong: #bccdd6;
  --kg-brand: #0f7b83;
  --kg-brand-strong: #0c6670;
  --kg-brand-soft: #def2f3;
  --kg-info: #2463d2;
  --kg-success: #1a915f;
  --kg-warning: #a76905;
  --kg-danger: #b9374a;
  --kg-shadow-sm: 0 8px 22px rgba(15, 47, 62, 0.08);
  --kg-shadow-md: 0 16px 40px rgba(15, 47, 62, 0.13);
  --kg-radius-sm: 10px;
  --kg-radius-md: 14px;
  --kg-radius-lg: 18px;
  --kg-radius-pill: 999px;
  --kg-space-1: 4px;
  --kg-space-2: 8px;
  --kg-space-3: 12px;
  --kg-space-4: 16px;
  --kg-space-5: 20px;
  --kg-space-6: 24px;
}

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

body.app-body {
  background: radial-gradient(circle at 5% -20%, #d9e9f2 0%, var(--kg-bg) 40%, #f4f8fb 100%);
  color: var(--kg-text);
  font-family: var(--kg-font);
}

a {
  color: #1358b6;
}

.kg-skip-link {
  position: absolute;
  left: 10px;
  top: -100px;
  z-index: 9999;
  padding: 10px 14px;
  border-radius: var(--kg-radius-sm);
  background: #0e2a33;
  color: #fff;
  font-weight: 700;
}

.kg-skip-link:focus {
  top: 10px;
}

.kg-main-card,
.kg-side-card,
.kg-screen-section {
  background: var(--kg-surface);
  border: 1px solid var(--kg-border);
  border-radius: var(--kg-radius-lg);
  box-shadow: var(--kg-shadow-sm);
}

.kg-screen-section {
  padding: var(--kg-space-4);
}

.kg-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--kg-space-3);
  flex-wrap: wrap;
  margin-bottom: var(--kg-space-4);
}

.kg-page-kicker {
  margin: 0 0 2px 0;
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  font-weight: 700;
  text-transform: uppercase;
  color: #6b818b;
}

.kg-title {
  margin: 0;
  color: #153846;
  font-weight: 800;
  letter-spacing: -0.01em;
}

.kg-subtitle {
  margin: 4px 0 0;
  color: var(--kg-text-muted);
  line-height: 1.5;
}

/* Clean top headers: keep title/action, remove excess explanatory text */
.kg-header .kg-subtitle,
.kg-page-header .kg-page-kicker,
.kg-page-header p {
  display: none;
}

.kg-page-header {
  margin-bottom: 10px;
}

.kg-header {
  margin-bottom: 10px;
}

.app-header {
  background: linear-gradient(90deg, rgba(247, 251, 253, 0.95) 0%, rgba(237, 245, 249, 0.95) 100%);
  border-bottom: 1px solid var(--kg-border);
  backdrop-filter: blur(8px);
}

.app-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--kg-space-3);
  flex-wrap: wrap;
}

.app-brand-title {
  margin: 0;
  color: #153846;
  font-size: clamp(1.25rem, 2vw, 1.95rem);
  line-height: 1.1;
  font-weight: 800;
}

.app-brand-kicker {
  margin: 0;
  color: #6b818b;
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  font-weight: 700;
}

.app-top-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.app-top-actions form {
  margin: 0;
}

.app-top-actions .kg-btn {
  min-height: 36px;
  padding: 6px 12px;
}

.app-top-select {
  min-height: 36px;
  padding-top: 4px;
  padding-bottom: 4px;
}

.app-sidebar {
  background: rgba(249, 252, 253, 0.9);
  border-right: 1px solid var(--kg-border);
  border-radius: 22px;
  margin: 12px 0 12px 12px;
}

.app-nav-link,
.app-subnav-link {
  display: block;
  border-radius: 12px;
  min-height: 42px;
  padding: 10px 12px;
  font-weight: 700;
  color: #244551;
  border: 1px solid transparent;
}

.app-nav-link:hover,
.app-subnav-link:hover {
  background: #edf4f8;
}

.app-nav-link-active {
  background: linear-gradient(135deg, var(--kg-brand) 0%, var(--kg-brand-strong) 100%);
  border-color: var(--kg-brand-strong);
  color: #fff;
  box-shadow: 0 12px 22px rgba(14, 119, 126, 0.28);
}

.app-subnav {
  margin: 4px 0 8px 10px;
  padding-left: 8px;
  border-left: 2px solid #d7e5ec;
  display: grid;
  gap: 4px;
}

.app-subnav-link-active {
  background: var(--kg-brand-soft);
  color: #0d636a;
}

.app-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--kg-border);
  background: #f5f9fb;
  color: #355660;
  border-radius: var(--kg-radius-pill);
  padding: 6px 10px;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.1;
}

.app-pill-success {
  border-color: #bde5d2;
  background: #ebfaf2;
  color: #1f7f53;
}

.app-pill-no {
  border-color: #cfd8e3;
  background: #f3f7fb;
  color: #4a6170;
}

.app-pill-yes {
  border-color: #90d7b4;
  background: #def8ea;
  color: #0f6c43;
}

.kg-feedback,
.kg-alert {
  border-radius: var(--kg-radius-md);
  border: 1px solid var(--kg-border);
  padding: 10px 12px;
  font-size: 0.92rem;
  line-height: 1.45;
}

.kg-feedback.success,
.kg-alert.success {
  background: #eaf9f1;
  border-color: #bde7d2;
  color: #1e7f53;
}

.kg-feedback.error,
.kg-alert.error {
  background: #fceef1;
  border-color: #f2ccd3;
  color: #9d2f42;
}

.kg-alert.warning {
  background: #fff6e8;
  border-color: #f1d8a9;
  color: #8e5b0b;
}

.kg-alert.info {
  background: #edf4ff;
  border-color: #cddcf8;
  color: #204f9c;
}

.kg-btn,
.kg-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 42px;
  padding: 8px 14px;
  border: 1px solid var(--kg-border-strong);
  border-radius: var(--kg-radius-pill);
  font-weight: 700;
  color: #22424e;
  background: #fff;
  cursor: pointer;
  transition: 0.18s ease;
}

.kg-btn:hover,
.kg-icon-btn:hover {
  transform: translateY(-1px);
  background: #f1f7fb;
}

.kg-btn:disabled,
.kg-icon-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
}

.kg-btn-primary {
  background: linear-gradient(135deg, var(--kg-info) 0%, #1d4ea7 100%);
  border-color: #1d4ea7;
  color: #fff;
  box-shadow: 0 10px 20px rgba(29, 78, 167, 0.24);
}

.kg-btn-secondary {
  background: linear-gradient(135deg, var(--kg-brand) 0%, var(--kg-brand-strong) 100%);
  border-color: var(--kg-brand-strong);
  color: #fff;
}

.kg-btn-danger {
  background: #fff2f4;
  border-color: #f1c3cc;
  color: #a23547;
}

.kg-btn-danger:hover {
  background: #fde9ed;
  border-color: #e7aeb9;
  color: #8f2a3b;
}

.kg-btn-ghost {
  background: #fff;
  border-style: dashed;
}

.kg-icon-btn {
  width: 42px;
  padding: 0;
}

.kg-label {
  display: block;
  margin-bottom: 6px;
  font-size: 0.78rem;
  color: #5f7580;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.kg-input,
.kg-select,
.kg-textarea,
.kg-searchbar input,
.kg-searchbar select {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--kg-border-strong);
  border-radius: var(--kg-radius-md);
  background: #fff;
  color: var(--kg-text);
  padding: 8px 12px;
}

.kg-textarea {
  min-height: 112px;
  resize: vertical;
}

.kg-input:focus,
.kg-select:focus,
.kg-textarea:focus,
.kg-searchbar input:focus,
.kg-searchbar select:focus,
button:focus-visible,
a:focus-visible,
details summary:focus-visible {
  outline: none;
  border-color: var(--kg-brand);
  box-shadow: 0 0 0 3px rgba(15, 123, 131, 0.2);
}

.kg-checkbox,
.kg-switch {
  accent-color: var(--kg-brand);
}

.kg-switch-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 1px solid var(--kg-border);
  border-radius: var(--kg-radius-md);
  padding: 10px 12px;
  background: #fff;
}

.kg-header-switches {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.kg-header-switch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border: 1px solid var(--kg-border);
  border-radius: 10px;
  background: #fff;
}

.kg-header-switch .kg-label {
  margin: 0;
  font-size: 0.79rem;
  line-height: 1.1;
  white-space: nowrap;
}

.kg-switch {
  position: relative;
  display: inline-block;
  width: 46px;
  height: 26px;
  flex: 0 0 auto;
}

.kg-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.kg-switch-slider {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: #d2dbe0;
  transition: .2s;
  cursor: pointer;
}

.kg-switch-slider:before {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  left: 3px;
  top: 3px;
  border-radius: 999px;
  background: #fff;
  transition: .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}

.kg-switch input:checked + .kg-switch-slider {
  background: #1f9095;
}

.kg-switch input:checked + .kg-switch-slider:before {
  transform: translateX(20px);
}

.kg-tabs,
.kg-tablist {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.kg-tab-btn,
.kg-tab {
  border: 1px solid var(--kg-border);
  border-radius: var(--kg-radius-pill);
  min-height: 40px;
  padding: 8px 12px;
  background: #fff;
  color: #325965;
  font-weight: 700;
}

.kg-tab-btn.active,
.kg-tab.active {
  background: var(--kg-brand-soft);
  color: #0c6369;
  border-color: #a9d9dc;
}

.kg-tab-pane {
  display: none;
}

.kg-tab-pane.active {
  display: block;
}

.kg-table-wrap {
  border: 1px solid var(--kg-border);
  border-radius: var(--kg-radius-md);
  background: #fff;
  overflow: auto;
}

.kg-table,
table.kg-table {
  width: 100%;
  border-collapse: collapse;
}

.kg-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #eff5f8;
  color: #4a6773;
  text-align: left;
  font-size: 0.79rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  padding: 10px 10px;
  border-bottom: 1px solid var(--kg-border);
}

.kg-table td {
  padding: 10px;
  border-top: 1px solid #e8eff3;
  color: #233f4b;
  vertical-align: top;
}

.kg-table th.kg-col-flag,
.kg-table td.kg-col-flag {
  width: 116px;
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
}

.kg-table td.kg-col-flag .app-pill {
  min-width: 56px;
  justify-content: center;
}

.kg-table tbody tr:hover {
  background: #f4f9fc;
}

.kg-status-badge,
.kg-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  border-radius: var(--kg-radius-pill);
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.kg-status-Ativo,
.kg-badge.success {
  background: #dff5ea;
  color: #1f7f54;
}

.kg-status-Inativo,
.kg-badge.muted {
  background: #e8eef2;
  color: #50656e;
}

.kg-status-Bloqueado,
.kg-badge.danger {
  background: #fde8ec;
  color: #9f3144;
}

.kg-badge.warning {
  background: #fff1d8;
  color: #8d5908;
}

.kg-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.kg-pagination .kg-btn {
  min-height: 36px;
  padding: 6px 12px;
}

.kg-searchbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--kg-border);
  border-radius: var(--kg-radius-md);
  background: var(--kg-surface-alt);
}

.kg-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.82rem;
  color: #5f7782;
}

.kg-breadcrumb li + li::before {
  content: "/";
  margin-right: 8px;
  color: #9bb0ba;
}

.kg-empty-state,
.kg-no-permission-state {
  border: 1px dashed #b9ccd5;
  border-radius: var(--kg-radius-md);
  background: linear-gradient(180deg, #f9fcfd 0%, #f1f7fa 100%);
  text-align: center;
  padding: 24px 16px;
  color: #4d6773;
}

.kg-empty-state h3,
.kg-no-permission-state h3 {
  margin: 0 0 6px;
  color: #193c48;
}

.kg-skeleton {
  border-radius: 10px;
  background: linear-gradient(90deg, #edf3f6 0%, #f6fafc 50%, #edf3f6 100%);
  background-size: 200% 100%;
  animation: kg-skeleton 1.2s infinite linear;
}

@keyframes kg-skeleton {
  to { background-position: -200% 0; }
}

.kg-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(14, 32, 40, 0.5);
  padding: 16px;
}

.kg-modal.active {
  display: flex;
}

.kg-modal-content {
  width: min(920px, 100%);
  max-height: 90vh;
  overflow: auto;
  background: #fff;
  border: 1px solid var(--kg-border);
  border-radius: 18px;
  box-shadow: var(--kg-shadow-md);
  padding: 14px;
}

.kg-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.kg-modal-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.kg-drawer {
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: min(460px, 100vw);
  transform: translateX(100%);
  transition: transform 0.2s ease;
  background: #fff;
  border-left: 1px solid var(--kg-border);
  box-shadow: var(--kg-shadow-md);
  z-index: 95;
}

.kg-drawer.active {
  transform: translateX(0);
}

.kg-tooltip {
  position: relative;
}

.kg-tooltip[data-tooltip]:hover::after,
.kg-tooltip[data-tooltip]:focus-visible::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  border-radius: 8px;
  background: #122e38;
  color: #fff;
  padding: 6px 9px;
  white-space: nowrap;
  font-size: 0.75rem;
  font-weight: 600;
  z-index: 96;
}

.kg-popup-stack {
  position: fixed;
  right: 16px;
  top: 88px;
  z-index: 1200;
  display: grid;
  gap: 10px;
  width: min(400px, calc(100vw - 22px));
}

.kg-popup-card {
  border-radius: 16px;
  border: 1px solid var(--kg-border);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--kg-shadow-md);
  padding: 12px;
}

.kg-popup-card.success {
  border-color: #bde7d2;
  background: linear-gradient(180deg, #f4fff8 0%, #ebfaf2 100%);
}

.kg-popup-card.error {
  border-color: #f2ccd3;
  background: linear-gradient(180deg, #fff8f9 0%, #fceef1 100%);
}

.kg-popup-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 4px;
}

.kg-popup-close {
  border: 1px solid var(--kg-border);
  border-radius: var(--kg-radius-pill);
  background: #fff;
  color: #385962;
  min-height: 30px;
  padding: 4px 10px;
  font-size: 0.75rem;
  font-weight: 800;
}

.kg-audit-trail details {
  border: 1px solid var(--kg-border);
  border-radius: var(--kg-radius-sm);
  padding: 8px;
  background: #fbfdff;
}

.kg-audit-trail summary {
  cursor: pointer;
  font-weight: 700;
  color: #205f9a;
}

.kg-audit-trail pre {
  margin-top: 8px;
  border: 1px solid #d9e5ee;
  border-radius: 10px;
  background: #f6fafc;
  padding: 10px;
  font-size: 0.76rem;
  overflow: auto;
}

.app-footer {
  border-top: 1px solid var(--kg-border);
  color: #6d848f;
  background: #f8fbfd;
}

/* Shared app container: keep neutral to avoid cross-page breakage */
.kg-app {
  display: block;
  width: 100%;
}

.kg-single-pane {
  grid-template-columns: 1fr !important;
}

/* People/registry modules (owners, tenants, guarantors, companies, users) */
.kg-people {
  background: linear-gradient(180deg, #f5f7fb 0%, #f5f5f7 100%);
  border-radius: 18px;
  padding: 10px;
}

.kg-people .kg-main-card,
.kg-people .kg-side-card {
  border-color: #d9dde4;
  box-shadow: 0 8px 24px rgba(17, 24, 39, 0.06);
}

.kg-people .kg-title {
  color: #1d1d1f;
}

.kg-row-actions {
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.kg-inline-form {
  display: inline;
}

/* Contracts/filters and compact table actions */
.kg-contracts-page {
  grid-template-columns: 1fr 320px;
}

.kg-contract-filters {
  display: grid;
  grid-template-columns: minmax(260px, 1.4fr) minmax(180px, .8fr) minmax(180px, .8fr) auto;
  gap: 10px;
  margin: 14px 0 10px;
}

.kg-contract-counter {
  margin: 0;
  color: #6e6e73;
  font-size: .85rem;
}

.kg-contract-actions {
  position: relative;
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.kg-contract-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 220px;
  background: #fff;
  border: 1px solid #d2d2d7;
  border-radius: 14px;
  box-shadow: 0 14px 30px rgba(15, 23, 42, .18);
  padding: 8px;
  display: none;
  z-index: 60;
}

.kg-contract-actions.open .kg-contract-dropdown {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.kg-contract-action {
  display: block;
  width: 100%;
  border: 0;
  border-radius: 10px;
  padding: 10px 12px;
  text-align: left;
  background: #f3f4f6;
  color: #1f2937;
  cursor: pointer;
  text-decoration: none;
  font-weight: 500;
  white-space: nowrap;
}

.kg-contract-action:hover {
  background: #e5e7eb;
}

.kg-options-btn {
  min-width: 76px;
  white-space: nowrap;
}

.kg-contracts-page .kg-table-wrap {
  max-height: none;
  overflow: visible;
}

.kg-contract-modal-content {
  width: min(1120px, 100%);
}

.kg-contract-form-grid > .kg-field {
  background: #fbfdfe;
  border: 1px solid #e3ebf0;
  border-radius: 12px;
  padding: 8px 10px;
}

.kg-contract-form-grid .kg-inline-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.kg-contract-form-grid .kg-inline-toolbar .kg-btn {
  min-height: 42px;
  white-space: nowrap;
}

.kg-contract-extra-box {
  border: 1px solid #dce6ed;
  border-radius: 12px;
  background: #fbfdfe;
  padding: 10px;
}

.kg-contract-expenses-list {
  display: grid;
  gap: 8px;
}

.kg-contract-expense-row {
  display: grid;
  grid-template-columns: minmax(120px, 150px) minmax(200px, 1fr) minmax(130px, 160px) minmax(130px, 160px) minmax(130px, 160px) auto;
  gap: 8px;
  align-items: end;
  border: 1px solid #e3ebf0;
  border-radius: 12px;
  padding: 8px;
  background: #fff;
}

.kg-contract-expense-remove-wrap {
  display: flex;
  align-items: end;
}

#contract-installment-items-list .kg-expense-item {
  border: 1px solid #e3ebf0;
  border-radius: 12px;
  background: #fff;
  padding: 8px;
}

#contract-installment-items-list .kg-expense-grid {
  display: grid;
  grid-template-columns: minmax(150px, 180px) minmax(280px, 1fr) minmax(120px, 150px) auto;
  gap: 8px;
  align-items: end;
}

#contract-installment-items-list .kg-expense-grid .kg-input,
#contract-installment-items-list .kg-expense-grid .kg-select {
  min-height: 40px;
}

#contract-installment-items-list .kg-expense-grid .kg-btn {
  min-height: 40px;
  white-space: nowrap;
}

.kg-contract-modal-actions {
  justify-content: space-between;
  gap: 10px;
}

.kg-contract-modal-submit-actions,
.kg-contract-modal-shortcuts {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* Guarantor/Clause linkage chips */
.kg-fiadores-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.kg-fiadores-selected {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 40px;
  flex: 1 1 420px;
}

.kg-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: 100%;
  padding: 6px 10px;
  border: 1px solid #cbddeb;
  border-radius: 999px;
  background: #edf6ff;
  color: #1f4b6e;
  font-size: 0.83rem;
  line-height: 1.2;
}

.kg-chip > span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.kg-chip-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border: 1px solid #bfd2e3;
  border-radius: 999px;
  background: #fff;
  color: #4f6676;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  transition: 0.15s ease;
}

.kg-chip-remove:hover {
  border-color: #debac0;
  background: #fff3f5;
  color: #9a3345;
}

.kg-list-pagination {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.kg-contract-status-stack {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.kg-contract-deadline-chip {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 800;
  border: 1px solid transparent;
  line-height: 1;
}

.kg-contract-deadline-chip.is-overdue {
  background: #fde8ec;
  color: #9f3144;
  border-color: #f3c6d0;
}

.kg-contract-deadline-chip.is-urgent {
  background: #fff0f0;
  color: #b23a2f;
  border-color: #f2c8c1;
}

.kg-contract-deadline-chip.is-warning {
  background: #fff6e8;
  color: #8e5b0b;
  border-color: #f1d8a9;
}

.kg-contract-deadline-chip.is-soon {
  background: #edf4ff;
  color: #28529e;
  border-color: #cbdcf7;
}

/* Module accents */
.kg-contracts-ux {
  background: linear-gradient(180deg, #edf5f6 0%, #f3f8fa 58%, #f8f9fb 100%);
}

.kg-contracts-ux .kg-main-card {
  border-color: #d8e3e8;
  box-shadow: 0 10px 24px rgba(12, 38, 58, 0.08);
}

.kg-contracts-ux .kg-title {
  color: #183945;
}

.kg-properties-ux {
  background: linear-gradient(180deg, #eef7f5 0%, #f4f8fb 58%, #f7f8fa 100%);
}

/* Legal models module */
.kg-legal-models-page {
  grid-template-columns: 1fr;
}

.kg-model-tags-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.kg-model-tag-card {
  border: 1px solid #d2d2d7;
  border-radius: 14px;
  padding: 12px;
  background: #fbfcfd;
}

.kg-model-tag-card h4 {
  margin: 0 0 8px;
}

.kg-model-tag-card p {
  margin: 0;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .83rem;
  color: #334155;
}

.kg-models-layout {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 14px;
  margin-top: 14px;
}

.kg-models-list {
  border: 1px solid #d2d2d7;
  border-radius: 14px;
  padding: 12px;
  background: #fff;
}

.kg-models-list-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.kg-models-list-head h3 {
  margin: 0;
  font-size: 1rem;
}

.kg-model-editor-card {
  margin-top: 14px;
  border: 1px solid #d2d2d7;
  border-radius: 14px;
  padding: 14px;
  background: #fff;
}

.kg-model-editor-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.kg-model-editor-head h3 {
  margin: 0;
}

.kg-model-textarea {
  min-height: 190px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

.kg-model-help {
  margin: 0 0 8px;
  color: #475569;
  font-size: .84rem;
}

.kg-dashboard {
  display: grid;
  gap: 16px;
}

.kg-dashboard-filter {
  padding: 16px;
}

.kg-dashboard-filter-form {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
}

.kg-dashboard-metrics {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kg-metric-card {
  background: #ffffff;
  border: 1px solid var(--kg-border);
  border-radius: 14px;
  padding: 12px;
  box-shadow: 0 6px 16px rgba(15, 47, 62, 0.07);
  min-height: 92px;
}

.kg-metric-label {
  margin: 0 0 6px;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #6a7f88;
  font-weight: 700;
}

.kg-metric-value {
  margin: 0;
  color: #173f4e;
  font-size: 1.45rem;
  line-height: 1.2;
  word-break: break-word;
}

.kg-dashboard-analytics {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.kg-analytics-card {
  background: #ffffff;
  border: 1px solid var(--kg-border);
  border-radius: 14px;
  padding: 14px;
  min-height: 220px;
}

.kg-analytics-title {
  margin: 0 0 12px;
  font-weight: 800;
  color: #1a4452;
}

.kg-alert-btn {
  width: 100%;
  text-align: left;
  background: #f6fafc;
  border: 1px solid #d8e3ea;
  border-radius: 10px;
  padding: 10px 12px;
  transition: background-color 0.15s ease;
}

.kg-alert-btn:hover {
  background: #edf4f9;
}

@media (max-width: 1100px) {
  .app-sidebar {
    margin: 0;
    border-radius: 0;
  }

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

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

  .kg-contracts-page {
    grid-template-columns: 1fr;
  }

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

  .kg-contract-expense-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #contract-installment-items-list .kg-expense-grid {
    grid-template-columns: minmax(140px, 1fr) minmax(180px, 1fr) minmax(110px, 140px) auto;
  }

  .kg-contract-modal-content {
    width: min(980px, 100%);
  }

  .kg-contract-form-grid > .kg-field.kg-span-4 {
    grid-column: span 6 !important;
  }

  .kg-contract-form-grid > .kg-field.kg-span-3 {
    grid-column: span 6 !important;
  }

  .kg-contract-form-grid > .kg-field.kg-span-2 {
    grid-column: span 4 !important;
  }

  .kg-model-tags-grid {
    grid-template-columns: 1fr;
  }

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

  .kg-fiadores-row {
    align-items: stretch;
  }
}

@media (max-width: 900px) {
  .app-top-actions {
    width: 100%;
    justify-content: flex-start;
    row-gap: 6px;
  }

  .kg-page-header {
    margin-bottom: 12px;
  }

  .kg-searchbar {
    flex-direction: column;
  }

  .kg-dashboard-analytics {
    grid-template-columns: 1fr;
  }

  .kg-row-actions {
    min-width: 340px;
  }
}

@media (max-width: 640px) {
  .kg-modal {
    padding: 10px;
    align-items: flex-end;
  }

  .kg-modal-content {
    border-radius: 16px 16px 0 0;
    max-height: 84vh;
  }

  .kg-popup-stack {
    left: 12px;
    right: 12px;
    width: auto;
    top: auto;
    bottom: 10px;
  }

  .kg-dashboard-filter-form,
  .kg-dashboard-metrics {
    grid-template-columns: 1fr;
  }

  .kg-contract-filters {
    grid-template-columns: 1fr;
  }

  .kg-contract-expense-row {
    grid-template-columns: 1fr;
  }

  #contract-installment-items-list .kg-expense-grid {
    grid-template-columns: 1fr;
  }

  .kg-contract-form-grid .kg-inline-toolbar {
    grid-template-columns: 1fr;
  }

  .kg-contract-form-grid .kg-inline-toolbar .kg-btn {
    width: 100%;
  }

  .kg-table {
    min-width: 760px;
  }
}

.kg-contract-doc-modal-content {
  width: min(1100px, 100%);
}

.kg-contract-doc-actions {
  display: flex;
  gap: 8px;
  align-items: end;
  flex-wrap: wrap;
}

.kg-contract-doc-frame {
  width: 100%;
  min-height: 64vh;
  border: 1px solid #d2d2d7;
  border-radius: 12px;
  margin-top: 12px;
  background: #fff;
}

@media (max-width: 980px) {
  .kg-contract-doc-frame {
    min-height: 58vh;
  }
}

/* ---- Legacy visual restoration (global) ---- */
body.app-body {
  background: #e8edf0 !important;
}

.app-header {
  background: linear-gradient(90deg, #eff4f6 0%, #e8eff2 100%) !important;
}

.app-sidebar {
  background: #f7fafb !important;
  border-radius: 18px !important;
  box-shadow: 0 8px 18px rgba(16, 48, 64, 0.08) !important;
}

.kg-main-card,
.kg-side-card,
.kg-screen-section {
  border-radius: 16px !important;
  box-shadow: 0 8px 20px rgba(15, 47, 62, 0.06) !important;
}

.kg-btn-primary {
  background: linear-gradient(135deg, #2aa8ad 0%, #1f9095 100%) !important;
  border-color: #1f9095 !important;
  box-shadow: 0 10px 20px rgba(31, 144, 149, 0.24) !important;
}

.kg-people,
.kg-properties-ux,
.kg-contracts-ux {
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

.kg-people .kg-main-card,
.kg-people .kg-side-card,
.kg-contracts-ux .kg-main-card,
.kg-properties-ux .kg-main-card {
  border-color: var(--kg-border) !important;
  box-shadow: 0 8px 20px rgba(15, 47, 62, 0.06) !important;
}

.kg-contracts-ux .kg-title,
.kg-properties-ux .kg-title,
.kg-people .kg-title {
  color: #153846 !important;
}

.kg-property-head-controls {
  margin-top: 2px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.kg-property-head-controls .kg-header-switch {
  padding: 4px 8px;
}

.kg-property-head-controls-left {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.kg-property-status-card {
  min-width: 170px;
  max-width: 220px;
  border: 1px solid #e3ebf0;
  border-radius: 10px;
  background: #fbfdfe;
  padding: 8px 10px;
}

.kg-status-inline-meta {
  font-size: 0.82rem;
  color: #486573;
  font-weight: 700;
}

.kg-metric-card {
  border-top-width: 3px !important;
}

.kg-dashboard-metrics .kg-metric-card:nth-child(4n + 1) { border-top-color: #1f9aa2 !important; }
.kg-dashboard-metrics .kg-metric-card:nth-child(4n + 2) { border-top-color: #b7771c !important; }
.kg-dashboard-metrics .kg-metric-card:nth-child(4n + 3) { border-top-color: #2d6bc8 !important; }
.kg-dashboard-metrics .kg-metric-card:nth-child(4n + 4) { border-top-color: #b43c56 !important; }

/* ---- Property form UX refresh ---- */
.kg-property-form-shell .kg-tabs {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #fff;
  padding: 4px 0 8px;
  margin-top: 2px;
}

.kg-property-form-shell .kg-action-bar {
  position: sticky;
  bottom: 0;
  z-index: 3;
  background: rgba(255, 255, 255, 0.96);
  border-top: 1px solid #dde6eb;
  padding-top: 10px;
  padding-bottom: 4px;
  backdrop-filter: blur(4px);
}

.kg-property-edit-banner {
  margin: 4px 0 8px;
  padding: 10px 12px;
  border: 1px solid #d6e4ea;
  border-radius: 12px;
  background: linear-gradient(180deg, #f5fbfd 0%, #eef6fb 100%);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.kg-property-edit-title {
  color: #153846;
  font-size: 1rem;
  line-height: 1.2;
}

.kg-property-edit-meta {
  color: #57717c;
  font-size: 0.8rem;
}

.kg-property-grid > div {
  background: #fbfdfe;
  border: 1px solid #e3ebf0;
  border-radius: 12px;
  padding: 8px 10px;
}

.kg-property-grid > .kg-col-full {
  background: #f9fbfc;
}

.kg-property-grid .kg-label {
  font-weight: 700;
}

.kg-property-inline-row {
  display: grid;
  gap: 10px;
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
}

.kg-property-inline-row > .kg-field {
  background: #fbfdfe;
  border: 1px solid #e3ebf0;
  border-radius: 12px;
  padding: 8px 10px;
}

.kg-property-inline-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

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

.kg-property-grid.kg-grid-form-smart > .kg-span-1 { grid-column: span 1 !important; }
.kg-property-grid.kg-grid-form-smart > .kg-span-2 { grid-column: span 2 !important; }
.kg-property-grid.kg-grid-form-smart > .kg-span-3 { grid-column: span 3 !important; }
.kg-property-grid.kg-grid-form-smart > .kg-span-4 { grid-column: span 4 !important; }
.kg-property-grid.kg-grid-form-smart > .kg-span-5 { grid-column: span 5 !important; }
.kg-property-grid.kg-grid-form-smart > .kg-span-6 { grid-column: span 6 !important; }
.kg-property-grid.kg-grid-form-smart > .kg-span-8 { grid-column: span 8 !important; }
.kg-property-grid.kg-grid-form-smart > .kg-span-12 { grid-column: 1 / -1 !important; }

.kg-property-grid #property-status {
  min-height: 42px;
}

.kg-field-hint {
  margin: 6px 0 0;
  font-size: 0.75rem;
  color: #63808e;
}

.kg-inline-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

#property-group-select-wrap .kg-icon-btn {
  min-height: 42px;
  height: 42px;
  width: 42px;
  margin: 0;
}

.kg-property-address-pane {
  padding-top: 4px;
}

#open-property-groups-modal.kg-icon-btn {
  width: 42px;
  min-width: 42px;
  height: 42px;
  border-radius: 999px;
  font-size: 1rem;
}

#open-property-groups-modal.kg-icon-btn:hover {
  background: #eaf4fb;
}

/* ---- Smart form sizing across modules ---- */
.kg-grid-form {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 10px;
  align-items: end;
}

.kg-grid-form > div {
  grid-column: span 6;
  min-width: 0;
}

.kg-grid-form.kg-grid-form-smart > .kg-field {
  grid-column: span 6;
  min-width: 0;
}

.kg-grid-form.kg-grid-form-smart > .kg-span-1 { grid-column: span 1 !important; }
.kg-grid-form.kg-grid-form-smart > .kg-span-2 { grid-column: span 2 !important; }
.kg-grid-form.kg-grid-form-smart > .kg-span-3 { grid-column: span 3 !important; }
.kg-grid-form.kg-grid-form-smart > .kg-span-4 { grid-column: span 4 !important; }
.kg-grid-form.kg-grid-form-smart > .kg-span-5 { grid-column: span 5 !important; }
.kg-grid-form.kg-grid-form-smart > .kg-span-6 { grid-column: span 6 !important; }
.kg-grid-form.kg-grid-form-smart > .kg-span-7 { grid-column: span 7 !important; }
.kg-grid-form.kg-grid-form-smart > .kg-span-8 { grid-column: span 8 !important; }
.kg-grid-form.kg-grid-form-smart > .kg-span-12 { grid-column: 1 / -1 !important; }

.kg-grid-form > .kg-col-full {
  grid-column: 1 / -1 !important;
}

.kg-grid-form > div:has(textarea),
.kg-grid-form > div:has(.kg-textarea) {
  grid-column: 1 / -1;
}

.kg-grid-form > div:has([name="status"]),
.kg-grid-form > div:has([name$="[status]"]),
.kg-grid-form > div:has([name="uf"]),
.kg-grid-form > div:has([name$="[uf]"]),
.kg-grid-form > div:has([name="dia_vencimento"]),
.kg-grid-form > div:has([name="numero"]),
.kg-grid-form > div:has([name$="[numero]"]),
.kg-grid-form > div:has([name="max_moradores"]),
.kg-grid-form > div:has([name="moradores_atual"]) {
  grid-column: span 3;
}

.kg-grid-form > div:has([name="cpf"]),
.kg-grid-form > div:has([name="cpf_cnpj"]),
.kg-grid-form > div:has([name="cnpj"]),
.kg-grid-form > div:has([name="rg"]),
.kg-grid-form > div:has([name="cep"]),
.kg-grid-form > div:has([name="data_nascimento"]),
.kg-grid-form > div:has([name="data_inicio"]),
.kg-grid-form > div:has([name="data_fim"]),
.kg-grid-form > div:has([name$="[cpf]" ]),
.kg-grid-form > div:has([name$="[cnpj]"]),
.kg-grid-form > div:has([name$="[rg]"]),
.kg-grid-form > div:has([name$="[cep]"]) {
  grid-column: span 4;
}

.kg-grid-form > div:has([name="telefone"]),
.kg-grid-form > div:has([name="telefone_fixo"]),
.kg-grid-form > div:has([name="celular_whatsapp"]),
.kg-grid-form > div:has([name="email"]),
.kg-grid-form > div:has([name="orgao_emissor"]),
.kg-grid-form > div:has([name="estado_civil"]),
.kg-grid-form > div:has([name="nacionalidade"]),
.kg-grid-form > div:has([name="profissao"]),
.kg-grid-form > div:has([name="cargo"]),
.kg-grid-form > div:has([name="renda_mensal"]),
.kg-grid-form > div:has([name$="[telefone]"]),
.kg-grid-form > div:has([name$="[email]"]) {
  grid-column: span 4;
}

.kg-grid-form > div:has([name="logradouro"]),
.kg-grid-form > div:has([name="complemento"]),
.kg-grid-form > div:has([name="bairro"]),
.kg-grid-form > div:has([name="cidade"]),
.kg-grid-form > div:has([name="garantia"]),
.kg-grid-form > div:has([name="indice_reajuste"]),
.kg-grid-form > div:has([name="tipo"]),
.kg-grid-form > div:has([name="titulo"]),
.kg-grid-form > div:has([name$="[logradouro]"]),
.kg-grid-form > div:has([name$="[bairro]"]),
.kg-grid-form > div:has([name$="[cidade]"]) {
  grid-column: span 6;
}

.kg-grid-form > div:has([name="nome"]),
.kg-grid-form > div:has([name="nome_fantasia"]),
.kg-grid-form > div:has([name="razao_social"]),
.kg-grid-form > div:has([name="descricao"]),
.kg-grid-form > div:has([name="observacoes"]),
.kg-grid-form > div:has([name$="[nome]"]),
.kg-grid-form > div:has([name$="[descricao]"]),
.kg-grid-form > div:has([name$="[observacoes]"]) {
  grid-column: span 6;
}

.kg-doc-box {
  border: 1px solid #dce6ed;
  border-radius: 12px;
  padding: 12px;
  background: #fbfdfe;
}

.kg-doc-box-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.kg-doc-box-note {
  margin: 8px 0 10px;
  color: #5e7782;
  font-size: 0.82rem;
}

.kg-doc-rows {
  display: grid;
  gap: 8px;
}

.kg-doc-row {
  display: grid;
  grid-template-columns: minmax(140px, 200px) minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid #e3ebf0;
  border-radius: 12px;
  background: #fff;
  padding: 8px;
}

.kg-doc-row .kg-input[type="file"] {
  min-height: 38px;
}

.kg-doc-file-feedback {
  grid-column: 2 / 3;
  margin-top: -4px;
  font-size: 0.75rem;
  color: #5e7782;
}

.kg-doc-file-feedback.error {
  color: #aa2f43;
  font-weight: 700;
}

.kg-doc-existing {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed #d9e4ea;
}

.kg-doc-existing-title {
  margin: 0 0 8px;
  color: #274754;
  font-size: 0.85rem;
  font-weight: 700;
}

.kg-doc-existing-list {
  display: grid;
  gap: 8px;
}

.kg-doc-existing-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid #e4ecf1;
  border-radius: 10px;
  padding: 7px 9px;
  background: #fff;
}

.kg-doc-existing-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.kg-doc-type {
  border-radius: 999px;
  background: #e9f4fa;
  color: #1f607a;
  padding: 4px 8px;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.kg-doc-name {
  color: #274754;
  font-size: 0.84rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.kg-doc-existing-empty {
  margin: 0;
  color: #6f8792;
  font-size: 0.82rem;
}

/* ---- Inspections module ---- */
.kg-inspections-page .kg-title {
  color: #173b48;
}

.kg-inspection-modal-content {
  width: min(1220px, 100%);
  max-height: 92vh;
  padding: 16px;
}

.kg-inspection-form-grid > .kg-field {
  background: #fbfdfe;
  border: 1px solid #e3ebf0;
  border-radius: 12px;
  padding: 8px 10px;
}

.kg-inspection-edit-banner {
  margin-bottom: 2px;
  padding: 10px 12px;
  border: 1px solid #d6e4ea;
  border-radius: 12px;
  background: linear-gradient(180deg, #f5fbfd 0%, #eef6fb 100%);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.kg-inspection-edit-title {
  color: #153846;
  font-size: 0.98rem;
  line-height: 1.2;
}

.kg-inspection-edit-meta {
  color: #57717c;
  font-size: 0.8rem;
}

.kg-inspection-form-grid .kg-textarea {
  min-height: 110px;
}

.kg-inspection-form-grid .kg-modal-actions {
  position: sticky;
  bottom: 0;
  z-index: 2;
  background: rgba(255, 255, 255, 0.96);
  border-top: 1px solid #dde6eb;
  padding-top: 10px;
  padding-bottom: 4px;
  backdrop-filter: blur(4px);
}

.kg-inspection-row {
  display: grid;
  grid-template-columns: minmax(170px, 1.2fr) minmax(130px, 0.85fr) minmax(220px, 1.8fr) auto;
  gap: 8px;
  align-items: end;
}

.kg-inspection-row .kg-btn {
  min-height: 42px;
}

@media (max-width: 1100px) {
  .kg-inspection-modal-content {
    width: min(980px, 100%);
  }
}

@media (max-width: 900px) {
  .kg-inspection-form-grid > .kg-field.kg-span-7,
  .kg-inspection-form-grid > .kg-field.kg-span-3,
  .kg-inspection-form-grid > .kg-field.kg-span-6,
  .kg-inspection-form-grid > .kg-field.kg-span-4,
  .kg-inspection-form-grid > .kg-field.kg-span-2 {
    grid-column: span 6 !important;
  }

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

  .kg-inspection-row .kg-btn {
    grid-column: 1 / -1;
  }
}

@media (max-width: 640px) {
  .kg-inspection-modal-content {
    width: 100%;
  }

  .kg-inspection-form-grid > .kg-field.kg-span-7,
  .kg-inspection-form-grid > .kg-field.kg-span-3,
  .kg-inspection-form-grid > .kg-field.kg-span-6,
  .kg-inspection-form-grid > .kg-field.kg-span-4,
  .kg-inspection-form-grid > .kg-field.kg-span-2 {
    grid-column: 1 / -1 !important;
  }

  .kg-inspection-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1100px) {
  .kg-grid-form > div {
    grid-column: span 6;
  }

  .kg-grid-form.kg-grid-form-smart > .kg-field {
    grid-column: span 6 !important;
  }

  .kg-property-grid.kg-grid-form-smart > .kg-span-4 {
    grid-column: span 6 !important;
  }

  .kg-property-grid.kg-grid-form-smart > .kg-span-2 {
    grid-column: span 4 !important;
  }

  .kg-property-inline-5 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .kg-grid-form {
    grid-template-columns: 1fr;
  }

  .kg-grid-form > div,
  .kg-grid-form > .kg-col-full {
    grid-column: 1 / -1 !important;
  }

  .kg-grid-form.kg-grid-form-smart > .kg-field {
    grid-column: 1 / -1 !important;
  }

  .kg-property-grid.kg-grid-form-smart > .kg-field {
    grid-column: 1 / -1 !important;
  }

  .kg-property-inline-5,
  .kg-property-inline-2 {
    grid-template-columns: 1fr;
  }

  .kg-property-status-card {
    width: 100%;
    max-width: none;
  }

  .kg-doc-row {
    grid-template-columns: 1fr;
  }

  .kg-doc-file-feedback {
    grid-column: 1 / -1;
    margin-top: 0;
  }
}

/* Contract modal responsive hardening (kept at file end to win cascade) */
@media (max-width: 1100px) {
  .kg-contract-form-grid > .kg-field.kg-span-2 {
    grid-column: span 4 !important;
  }
}

@media (max-width: 900px) {
  .kg-contract-form-grid > .kg-field.kg-span-6,
  .kg-contract-form-grid > .kg-field.kg-span-4,
  .kg-contract-form-grid > .kg-field.kg-span-3,
  .kg-contract-form-grid > .kg-field.kg-span-2 {
    grid-column: span 6 !important;
  }
}

@media (max-width: 640px) {
  .kg-contract-form-grid > .kg-field.kg-span-6,
  .kg-contract-form-grid > .kg-field.kg-span-4,
  .kg-contract-form-grid > .kg-field.kg-span-3,
  .kg-contract-form-grid > .kg-field.kg-span-2 {
    grid-column: 1 / -1 !important;
  }
}
