body { font-family: system-ui, sans-serif; margin: 0; background: #f7f7f9; color: #222; }
.topbar { background: #1f2937; padding: 1rem; }
.topbar a { color: white; margin-right: 1rem; text-decoration: none; }
.container { max-width: 1360px; margin: 1.1rem auto; background: white; padding: 1.4rem; border-radius: 12px; box-shadow: 0 2px 10px rgba(0,0,0,.08); }
.cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.card { background: #eef2ff; padding: 1rem; border-radius: 10px; }
.detail-card, .contact-header-card { background: #fff; border: 1px solid #e5e7eb; box-shadow: 0 1px 2px rgba(0,0,0,.04); border-radius: 12px; padding: 1rem 1.05rem; }
.flash { padding: .75rem 1rem; border-radius: 8px; margin-bottom: 1rem; }
.flash.success { background: #dcfce7; }
.flash.error { background: #fee2e2; }
.btn, .button, button { background: #2563eb; color: white; border: 0; padding: .55rem .9rem; border-radius: 8px; text-decoration: none; cursor: pointer; display: inline-block; }
.btn-small { padding: .35rem .65rem; font-size: .9rem; }
.btn-secondary { background: #e5e7eb; color: #111827; }
.btn-primary { background: #2563eb; color: white; }
form { margin: 1rem 0; }
.form-grid { display: grid; gap: 1rem; max-width: 700px; }
.form-grid.two-cols { grid-template-columns: repeat(2, minmax(0, 1fr)); }
label { display: grid; gap: .35rem; }
.field { display: grid; gap: .35rem; }
input, textarea, select { padding: .55rem; border: 1px solid #cbd5e1; border-radius: 8px; font: inherit; }
table { width: 100%; border-collapse: collapse; margin-top: 1rem; }
th, td { padding: .65rem; border-bottom: 1px solid #e5e7eb; text-align: left; }
.searchbar { display: flex; gap: .75rem; align-items: center; }
.inline-form { display: grid; gap: .75rem; max-width: 700px; margin-top: 1rem; }
.compact-form { margin-top: 0; }
ul { padding-left: 1.25rem; }
.contact-page { display: grid; gap: .95rem; }
.contact-layout { display: grid; grid-template-columns: minmax(0, 1.16fr) minmax(23rem, 1fr); gap: 1rem; align-items: start; }
.contact-main, .contact-side { display: grid; gap: 1rem; }
.contact-header-grid { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(12rem, .72fr) minmax(16rem, 1fr); gap: .9rem; align-items: start; }
.page-title { margin: .1rem 0 .45rem; font-size: 1.8rem; line-height: 1.08; }
.eyebrow { text-transform: uppercase; letter-spacing: .06em; font-size: .75rem; color: #6b7280; }
.header-badges, .link-list { display: flex; flex-wrap: wrap; gap: .5rem; }
.badge { display: inline-flex; align-items: center; border-radius: 999px; padding: .15rem .55rem; font-size: .8rem; font-weight: 600; }
.badge-success { background: #dcfce7; color: #166534; }
.badge-muted { background: #e5e7eb; color: #374151; }
.badge-neutral { background: #dbeafe; color: #1d4ed8; }
.badge-warn { background: #ffedd5; color: #9a3412; }
.badge-danger { background: #fee2e2; color: #991b1b; }
.meta-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .9rem 1rem; }
.meta-grid.compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.identity-grid {
  grid-template-columns: minmax(0, .88fr) minmax(0, .88fr) minmax(0, 1.24fr);
}

.identity-grid .identity-display-name .value-static {
  word-break: normal;
  overflow-wrap: anywhere;
}

.label { display: block; font-size: .78rem; color: #6b7280; margin-bottom: .18rem; }
.value { font-weight: 600; }
.value-inline { font-weight: 500; }


.value-static {
  box-sizing: border-box;
  display: block;
  min-height: 2.15rem;
  padding: .48rem .55rem;
  border: 1px solid transparent;
  border-radius: 8px;
  line-height: 1.3;
}


.meta-grid > div,
.mini-card-body > div {
  min-width: 0;
}

.meta-grid > div {
  display: grid;
  gap: .18rem;
  align-content: start;
}

.meta-grid .label,
.mini-card-body .label {
  margin-bottom: 0;
}

.meta-grid .value,
.meta-grid .value-inline,
.meta-grid .value-static {
  display: block;
  min-width: 0;
  word-break: break-word;
}

.contract-inline-row {
  display: grid;
  gap: .18rem;
}

.contract-amount-inline {
  display: inline-flex;
  align-items: baseline;
  gap: .28rem;
  white-space: nowrap;
  max-width: 100%;
}

.contract-currency {
  color: #475569;
  font-weight: 600;
}

.contract-amount-inline .value-inline[data-inline-edit="1"] {
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  line-height: 1;
}

.contract-amount-inline .value-inline[data-inline-edit="1"]:hover {
  background: transparent;
  border-color: transparent;
}

.contract-amount-inline .inline-editor,
.contract-amount-inline .inline-input {
  min-width: 0;
  width: auto;
}

.mini-card-body > div {
  display: grid;
  gap: .2rem;
}

.mini-card-body > .workflow-list-badges,
.mini-card-body > .iban-actions-inline {
  display: flex;
}
.text-block { background: #f8fafc; border: 1px solid #e5e7eb; border-radius: 8px; padding: .75rem; min-height: 2.5rem; }
.stack-sm > * + * { margin-top: .5rem; }
.stack-md > * + * { margin-top: .85rem; }
.stack-lg > * + * { margin-top: 1.1rem; }
.mt-sm { margin-top: .5rem; }
.mb-sm { margin-bottom: .5rem; }
.mt-md { margin-top: 1rem; }
.card-header-row { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin-bottom: .85rem; }
.card-header-row h2 { margin: 0; font-size: 1.05rem; }
.subhead { font-size: .82rem; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: #475569; margin-bottom: .35rem; }
.inline-row { display: flex; gap: .6rem; align-items: center; flex-wrap: wrap; padding: .3rem 0; }
.tag, .link-pill { background: #f1f5f9; border-radius: 999px; padding: .18rem .55rem; font-size: .82rem; text-decoration: none; color: #0f172a; }
.address-block { background: #f8fafc; border: 1px solid #e5e7eb; border-radius: 8px; padding: .65rem; }
.contact-channel-section { display: grid; gap: .55rem; padding-top: .2rem; }
.contact-channel-list { display: grid; gap: .45rem; }
.contact-channel-row { margin: 0; padding: .1rem 0; }
.address-inline-block { display: grid; gap: .15rem; }
.contact-page .add-details summary { font-weight: 600; }
.contact-page .compact-add-form { margin-top: .45rem; }
.contact-page .form-actions.tight { margin-top: .75rem; }
.enrollment-form-block { display: grid; gap: .7rem; }
.enrollment-workflow-list { display: grid; gap: .4rem; }
.enrollment-workflow-item { padding: .65rem 0; }
.contract-list-stack { display: grid; gap: .55rem; }

.contract-card {
  padding: .85rem .95rem;
}

.contract-card-head {
  align-items: flex-start;
  margin-bottom: .75rem;
}

.contract-card-title {
  min-width: 0;
}

.contract-card-title strong {
  font-size: 1.02rem;
  line-height: 1.2;
}

.contract-card-actions {
  display: grid;
  justify-items: end;
  gap: .45rem;
  flex: 0 0 auto;
}

.contract-card-body {
  display: grid;
  gap: .75rem;
}

.contract-field {
  display: grid;
  gap: .18rem;
  align-content: start;
}

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

.contract-field-value {
  padding-left: .22rem;
  min-width: 0;
}

.contract-card-body .label {
  margin-bottom: 0;
}

.contract-card-body .value-inline,
.contract-card-body .value-static {
  display: inline-block;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  line-height: 1.28;
  font-weight: 600;
  max-width: 100%;
  word-break: break-word;
}

.contract-card-body .value-inline[data-inline-edit="1"] {
  min-height: 0;
  padding: .08rem 0;
}

.contract-card-body .value-inline[data-inline-edit="1"]:hover {
  background: transparent;
  border-color: transparent;
}

.contract-inline-row {
  display: grid;
  gap: .18rem;
}

.contract-amount-inline {
  width: fit-content;
}

.contract-iban-line {
  display: flex;
  align-items: center;
  gap: .55rem;
  flex-wrap: wrap;
}

.contract-card .add-details {
  margin-top: .4rem;
}

.contract-card .add-details summary {
  font-weight: 600;
}

@media (max-width: 720px) {
  .contract-meta-grid {
    grid-template-columns: 1fr;
  }
}

.contract-iban-line .btn-inline {
  margin-left: 0;
}
.mini-card.muted-card { background: #fafafa; }
.relationships-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.compact-list { margin: 0; padding-left: 1rem; display: grid; gap: .35rem; }
.mini-card { background: #f8fafc; border: 1px solid #e5e7eb; border-radius: 8px; padding: .65rem; }
.mini-card-head { display: flex; align-items: center; justify-content: space-between; gap: .5rem; margin-bottom: .35rem; }
.mini-card-body { display: grid; gap: .25rem; }
.row-2 { display: grid; grid-template-columns: .9fr 1.4fr; gap: .75rem; margin-top: .45rem; }
.form-actions { display: flex; gap: .75rem; margin-top: 1rem; }
.header-metrics { display: grid; grid-template-columns: 1fr; gap: .5rem; }
.metric-card { background: #f8fafc; border: 1px solid #e5e7eb; border-radius: 10px; padding: .7rem; }
.metric-label { display: block; font-size: .78rem; color: #64748b; }
.metric-value { display: block; font-size: 1.25rem; font-weight: 700; margin-top: .2rem; }
.header-actions { display: grid; gap: .45rem; justify-items: stretch; align-content: start; }
.contact-header-card { padding-top: .95rem; padding-bottom: .95rem; }
.contact-header-card .meta-grid.compact { gap: .7rem .85rem; }
.contact-page .detail-card .card-header-row { margin-bottom: .75rem; }
.contact-page .detail-card .card-header-row h2 { font-size: 1rem; }
.contact-page .detail-card .subhead { margin-bottom: .42rem; }
.muted { color: #6b7280; }
@media (max-width: 960px) { .cards, .contact-layout, .contact-header-grid, .relationships-grid, .form-grid.two-cols, .meta-grid { grid-template-columns: 1fr; } .container { margin: 1rem; padding: 1rem; } .header-actions { justify-items: start; } .contact-header-card .meta-grid.compact { grid-template-columns: 1fr 1fr; } }

.inline-empty {
  color: #64748b;
  border-bottom: 1px dashed #cbd5e1;
}
[data-inline-edit="1"] {
  cursor: pointer;
  border-bottom: 1px dashed transparent;
}
[data-inline-edit="1"]:hover {
  border-bottom-color: #cbd5e1;
  background: #f8fafc;
}
.inline-editor {
  display: inline-block;
  min-width: 12rem;
}
.inline-input {
  width: 100%;
  padding: .45rem .55rem;
  border: 1px solid #94a3b8;
  border-radius: 8px;
  font: inherit;
}


/* stable click-to-edit */
[data-inline-edit="1"] {
  box-sizing: border-box;
  display: inline-block;
  min-height: 2rem;
  padding: .45rem .55rem;
  border: 1px solid transparent;
  border-radius: 8px;
  line-height: 1.3;
  vertical-align: top;
}

.value[data-inline-edit="1"] {
  min-width: 10rem;
}

.text-block[data-inline-edit="1"] {
  display: block;
  width: 100%;
  min-height: 3.25rem;
}

[data-inline-edit="1"]:hover {
  border-bottom-color: transparent;
  background: #f8fafc;
}

.inline-editor {
  box-sizing: border-box;
  display: inline-block;
  vertical-align: top;
}

.inline-editor.block {
  display: block;
  width: 100%;
}

.inline-input {
  box-sizing: border-box;
  display: block;
  width: 100%;
  min-height: 2rem;
  padding: .45rem .55rem;
  border: 1px solid transparent;
  border-radius: 8px;
  font: inherit;
  line-height: 1.3;
  outline: none;
  box-shadow: 0 0 0 1px #94a3b8;
  background: #fff;
}

textarea.inline-input {
  resize: vertical;
  min-height: 3.25rem;
}

.address-inline-block .value { display: inline-block; }
.compact-inline { width: auto; min-width: 4ch; }
.wrap { flex-wrap: wrap; }
.gap-sm { gap: .35rem; }


.subhead.with-action { display:flex; align-items:center; justify-content:space-between; gap:.75rem; }
.add-details { font-size:.82rem; }
.add-details summary { cursor:pointer; color:#2563eb; list-style:none; }
.add-details summary::-webkit-details-marker { display:none; }
.compact-add-form { margin-top:.5rem; padding:.65rem; background:#f8fafc; border:1px solid #e5e7eb; border-radius:8px; }
.form-actions.tight { margin-top:.5rem; }

.muted-card { opacity: .9; }

.btn-link{background:none;border:none;color:#2563eb;padding:0;cursor:pointer;font:inherit}.btn-inline{margin-left:.5rem}.form-hint{font-size:.85rem;color:#666;margin-top:.35rem}.iban-mask{letter-spacing:.04em}

.group-page {
  gap: .75rem;
}

.group-page .group-header-card {
  padding: .9rem 1rem;
}

.group-page .group-header-grid {
  grid-template-columns: minmax(0, 1.5fr) minmax(320px, .95fr);
  gap: .75rem 1rem;
}

.group-header-main {
  min-width: 0;
}

.group-header-side {
  display: grid;
  gap: .65rem;
  align-content: start;
}

.group-layout {
  grid-template-columns: 1.35fr .95fr;
  gap: .75rem;
}

.compact-searchbar {
  margin: 0;
}

.compact-table th,
.compact-table td {
  vertical-align: top;
}

.table-actions {
  white-space: nowrap;
}

.compact-meta-list > div {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
}

.max-list-scroll {
  max-height: 32rem;
  overflow: auto;
}

.search-results {
  margin-top: .5rem;
  border: 1px solid #dbe3ef;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .08);
  max-height: 16rem;
  overflow: auto;
}
.search-result-item {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .15rem;
  padding: .65rem .75rem;
  border: 0;
  background: #fff;
  color: #111827;
  text-align: left;
  cursor: pointer;
}
.search-result-item + .search-result-item {
  border-top: 1px solid #eef2f7;
}
.search-result-item:hover {
  background: #f8fafc;
}

.search-result-item .result-title {
  color: #111827 !important;
  font-weight: 700;
}
.group-enrollment-search .search-result-item .result-title {
  color: #111827 !important;
}
.search-result-item .result-meta {
  color: #64748b !important;
  font-size: .84rem;
}
.search-result-item span {
  color: #64748b;
  font-size: .84rem;
}
.selected-contact {
  margin-top: .65rem;
  padding: .65rem .75rem;
  border: 1px solid #dbe3ef;
  border-radius: 10px;
  background: #f8fafc;
}
.selected-contact-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
}
.small { font-size: .84rem; }
.enrollment-search-form input[name="contact_search"] {
  width: 100%;
}

.search-result-item.is-active {
  background: #eef4ff;
  box-shadow: inset 0 0 0 1px #7aa7ff;
}

.search-result-item.is-disabled {
  opacity: 0.72;
}

.search-result-item.is-disabled .result-title {
  color: #6b7280;
}

.result-badge {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  margin-top: 0.35rem;
  padding: 0.15rem 0.45rem;
  border-radius: 999px;
  background: #f3f4f6;
  color: #6b7280;
  font-size: 0.8rem;
  font-weight: 600;
}

.checkbox-row {
  display: flex;
  gap: 0.55rem;
  align-items: center;
  margin-top: 0.8rem;
  color: #374151;
}

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

.payment-inline {
  min-width: 12rem;
}

.stack-xs > * + * {
  margin-top: 0.2rem;
}

.inline-add-payment-details summary {
  cursor: pointer;
  color: #1f2937;
}

.compact-inline-form input,
.compact-inline-form select {
  width: 100%;
}

.bulk-payment-bar {
  margin-bottom: 1rem;
}
.bulk-payment-form {
  margin-top: .75rem;
}
.group-participant-select {
  width: 1rem;
  height: 1rem;
}
.inline-row.spaced {
  justify-content: space-between;
}
.stack-xs > * + * {
  margin-top: .25rem;
}

.selection-tools {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.status-menu {
  position: relative;
  display: inline-block;
}
.status-menu summary {
  list-style: none;
  cursor: pointer;
}
.status-menu summary::-webkit-details-marker { display:none; }
.status-menu-panel {
  position: absolute;
  z-index: 10;
  top: calc(100% + .35rem);
  left: 0;
  min-width: 8rem;
  padding: .35rem;
  border: 1px solid #dbe3ef;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(15,23,42,.08);
}
.status-option {
  width: 100%;
  display: block;
  background: #fff;
  color: #111827;
  border: 0;
  border-radius: 8px;
  padding: .45rem .55rem;
  text-align: left;
  cursor: pointer;
}
.status-option:hover {
  background: #f8fafc;
}

.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
}

.page-header h1 {
  margin: 0;
}

.table-like {
  display: flex;
  flex-direction: column;
}

.table-head,
.table-row {
  display: grid;
  align-items: start;
  gap: 0.75rem;
  padding: 0.85rem 1rem;
}

.table-head {
  font-weight: 600;
  color: #4b5563;
  border-bottom: 1px solid #e5e7eb;
}

.table-row {
  border-bottom: 1px solid #eef2f7;
}

.break-grid {
  grid-template-columns: 1.4fr 0.8fr 1fr 1fr 0.7fr 0.9fr;
}

.small {
  font-size: 0.85rem;
}

.actions-compact {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.empty-state {
  padding: 1rem;
  color: #6b7280;
}

.btn-danger {
  background: #b91c1c;
  color: #fff;
}

.btn-danger:hover {
  background: #991b1b;
}

.break-grid .compact-dates .value-inline[data-inline-edit="1"] {
  min-width: 8rem;
}
.break-grid .text-block[data-inline-edit="1"] {
  min-height: 2.25rem;
  margin-top: .4rem;
}
select.inline-input {
  appearance: auto;
  background: #fff;
}

.group-title-stack { display: grid; gap: .2rem; }
.handle-line, .designation-line { display: flex; align-items: baseline; gap: .5rem; flex-wrap: wrap; }
.inline-title[data-inline-edit="1"] { font-size: 1.8rem; font-weight: 700; padding: .15rem .35rem; min-height: auto; }
.inline-subtitle[data-inline-edit="1"] { font-size: 1rem; color: #475569; padding: .15rem .35rem; min-height: auto; }
.inline-subtitle .inline-empty, .inline-title .inline-empty { border-bottom-style: dashed; }
.group-designation-cell { color: #475569; }


.schedule-page { display: grid; gap: 1rem; }
.schedule-header-card { margin-bottom: 0; }
.schedule-summary-grid { display: grid; gap: .75rem; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); margin-top: 1rem; }
.schedule-layout { display: grid; grid-template-columns: minmax(0, 2fr) minmax(260px, .8fr); gap: 1rem; align-items: start; }
.schedule-main, .schedule-side { display: grid; gap: 1rem; }
.rule-row, .session-row { display: flex; justify-content: space-between; gap: .75rem; border: 1px solid #e5e7eb; border-radius: 12px; padding: .8rem .9rem; background: #fff; }
.rule-row.compact, .session-row.compact { padding: .7rem .85rem; }
.rule-row-main, .session-row-main { min-width: 0; display: grid; gap: .3rem; }
.rule-title-line, .session-row-title { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.rule-meta-line { display: flex; gap: .35rem; flex-wrap: wrap; color: #475569; font-size: .93rem; }
.rule-row-actions, .wrap-actions { display: flex; align-items: flex-start; gap: .5rem; flex-wrap: wrap; justify-content: flex-end; }
.compact-edit-page { max-width: 980px; margin: 0 auto; }
.schedule-edit-form .form-grid { grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); }
.max-list-scroll { max-height: 340px; overflow: auto; }
.past-session-row { opacity: .92; }
@media (max-width: 900px) { .schedule-layout { grid-template-columns: 1fr; } }

.currency { color: #475569; font-weight: 600; margin-left: .15rem; }
.compact-table-tight th, .compact-table-tight td { padding-top: .35rem; padding-bottom: .35rem; }
.schedule-side .mini-card { border-radius: 12px; }

.bulk-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin: 1rem 0;
  padding: .85rem 1rem;
}
.bulk-toolbar-left {
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
}
.bulk-toolbar-actions {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.checkbox-col {
  width: 2rem;
  text-align: center;
}
.bulk-groups-form table input[type=checkbox] {
  width: 1rem;
  height: 1rem;
}
@media (max-width: 900px) {
  .bulk-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .bulk-toolbar-actions {
    justify-content: flex-start;
  }
}

.attendance-inline-summary { margin-top: .15rem; }

.attendance-matrix-table {
  width: 100%;
  table-layout: fixed;
}
.attendance-matrix-table .matrix-col-select { width: 2.5rem; }
.attendance-matrix-table .matrix-col-summary { width: 6.6rem; }
.attendance-matrix-table .matrix-col-attendance { width: 3.25rem; }
.attendance-matrix-table .matrix-col-payment { width: 7.4rem; }
.attendance-matrix-table .matrix-col-partners { width: 10.5rem; }
.attendance-matrix-table .matrix-col-actions { width: 3rem; }
.attendance-matrix-table th,
.attendance-matrix-table td {
  overflow-wrap: anywhere;
}
.attendance-matrix-table .attendance-col,
.attendance-matrix-table .attendance-cell,
.attendance-matrix-table .attendance-pair-cell {
  width: 3.25rem;
  min-width: 3.25rem;
  max-width: 3.25rem;
}
.compact-summary-card .compact-meta-list { display: grid; gap: .2rem; }
.attendance-session-card .link-list { margin-top: .35rem; }

.attendance-window-note { margin-bottom: .5rem; }
.attendance-matrix-table th,
.attendance-matrix-table td { vertical-align: middle; }
.attendance-col { text-align: center; min-width: 3rem; font-size: .78rem; white-space: nowrap; }
.attendance-cell,
.attendance-pair-cell { text-align: center; }
.attendance-pair-cell { min-width: 2.8rem; }
.attendance-pair-cell .attendance-dot + .attendance-dot { margin-top: .2rem; }
.attendance-dot {
  display: inline-block;
  width: .7rem;
  height: .7rem;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  background: #fff;
}
.attendance-dot.is-present {
  background: #16a34a;
  border-color: #15803d;
}
.attendance-dot.is-empty {
  background: #f8fafc;
  border-color: #cbd5e1;
}

.attendance-summary-cell {
  text-align: center;
  min-width: 4.2rem;
  white-space: nowrap;
}
.attendance-summary-badge {
  display: inline-block;
  padding: .18rem .45rem;
  border-radius: 999px;
  background: #f8fafc;
  border: 1px solid #dbe3ef;
  color: #334155;
  font-size: .72rem;
  font-weight: 600;
}
.row-actions-menu summary {
  padding: .05rem .35rem;
  min-width: 1.75rem;
  text-align: center;
}

.row-actions-menu {
  position: relative;
  display: inline-block;
}
.row-actions-menu summary {
  list-style: none;
  cursor: pointer;
  padding: .1rem .45rem;
  border: 1px solid #dbe3ef;
  border-radius: 999px;
  background: #fff;
  color: #475569;
  line-height: 1.1;
}
.row-actions-menu summary::-webkit-details-marker { display: none; }
.row-actions-menu[open] summary { background: #f8fafc; }
.row-actions-popover {
  position: absolute;
  right: 0;
  top: calc(100% + .35rem);
  z-index: 20;
  min-width: 8.5rem;
  display: grid;
  gap: .35rem;
  padding: .5rem;
  border: 1px solid #dbe3ef;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .12);
}
.row-actions-popover form { margin: 0; }
.compact-actions-cell { width: 1%; white-space: nowrap; }
.compact-link-list { gap: .25rem; }
.inline-details-summary {
  cursor: pointer;
  list-style: none;
}
.inline-details-summary::-webkit-details-marker { display: none; }
.inline-details-summary::after {
  content: '▾';
  color: #64748b;
  margin-left: auto;
}
.pair-matrix-table td:nth-last-child(3),
.pair-matrix-table td:nth-last-child(2),
.single-dance-table td:nth-last-child(2) {
  min-width: 10rem;
}


.payment-compact-cell {
  display: grid;
  gap: .2rem;
  min-width: 0;
}
.payment-compact-line {
  display: flex;
  align-items: center;
  gap: .45rem;
  flex-wrap: wrap;
  line-height: 1.1;
}
.payment-state-menu {
  position: relative;
  display: inline-block;
}
.payment-state-trigger {
  list-style: none;
  cursor: pointer;
  padding: 0;
  border: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
}
.payment-state-trigger::-webkit-details-marker { display:none; }
.payment-state-dot {
  display: inline-block;
  width: .82rem;
  height: .82rem;
  border-radius: 999px;
  border: 1px solid #94a3b8;
  background: #fff;
}
.payment-state-dot.is-paid {
  background: #16a34a;
  border-color: #15803d;
}
.payment-state-dot.is-open {
  background: #f8fafc;
  border-color: #cbd5e1;
}
.payment-amount-inline {
  display: inline-flex;
  align-items: baseline;
  gap: .16rem;
  font-weight: 600;
  color: #111827;
}
.payment-amount-value.value-inline[data-inline-edit="1"] {
  min-height: auto;
  padding: .08rem .16rem;
  border-radius: 6px;
}
.currency-inline {
  color: #475569;
  font-weight: 600;
}
.payment-status-text {
  font-size: .78rem;
  color: #64748b;
  white-space: nowrap;
}
.payment-status-text.is-paid { color: #166534; }
.payment-status-text.is-open { color: #92400e; }
.payment-voucher-line {
  padding-left: 1.25rem;
}
.payment-add-compact summary {
  font-size: .82rem;
  color: #475569;
}
.compact-actions-cell .row-actions-menu summary {
  min-width: 1.4rem;
  padding: 0 .32rem;
  border-color: #e2e8f0;
  color: #64748b;
}
.pair-matrix-table td:nth-last-child(3),
.pair-matrix-table td:nth-last-child(2),
.single-dance-table td:nth-last-child(2) {
  min-width: 7.2rem;
}
.attendance-matrix-table td .payment-compact-cell,
.attendance-matrix-table td .payment-add-compact {
  max-width: 8rem;
}


.monthly-pdf-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .4rem;
  align-items: center;
}

.monthly-pdf-form input[type="month"] {
  min-width: 8.5rem;
  padding: .4rem .5rem;
}

.group-page .eyebrow {
  margin-bottom: .1rem;
}

.group-page .page-title {
  margin: 0;
}

.group-page .group-title-stack {
  gap: .1rem;
}

.group-page .inline-title[data-inline-edit="1"] {
  font-size: 1.45rem;
  padding: .05rem .25rem;
}

.group-page .inline-subtitle[data-inline-edit="1"] {
  font-size: .96rem;
  padding: .05rem .25rem;
}

.group-page .handle-line,
.group-page .designation-line {
  gap: .35rem;
}

.group-page .header-badges {
  margin-top: .35rem;
  gap: .35rem;
}

.group-page .group-header-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .45rem;
}

.group-page .metric-card {
  padding: .45rem .55rem;
  border-radius: 8px;
}

.group-page .metric-label {
  font-size: .72rem;
}

.group-page .metric-value {
  font-size: 1rem;
  margin-top: .05rem;
}

.group-page .group-header-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  justify-content: flex-start;
  align-items: center;
}

.group-page .group-header-actions .btn,
.group-page .group-header-actions button {
  padding: .45rem .72rem;
  font-size: .9rem;
}

.group-page .group-header-actions .compact-form {
  margin: 0;
}

.group-page .monthly-pdf-form {
  display: flex;
  align-items: center;
  gap: .35rem;
  flex-wrap: wrap;
}

.group-page .monthly-pdf-form input[type=month] {
  padding: .4rem .5rem;
  min-width: 8.8rem;
}

.group-page .meta-grid.compact {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .45rem .75rem;
}

.group-page .meta-grid.compact.mt-md {
  margin-top: .6rem;
}

.group-page .label {
  margin-bottom: .06rem;
}

.group-page .card.detail-card {
  padding: .9rem 1rem;
}

.group-page .card-header-row {
  margin-bottom: .55rem;
}

.group-page .searchbar.compact-searchbar {
  gap: .45rem;
}

.group-page table {
  margin-top: .6rem;
}

@media (max-width: 1180px) {
  .group-page .group-header-grid {
    grid-template-columns: 1fr;
  }

  .group-page .meta-grid.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


/* group page width cleanup */
.group-page {
  max-width: 1180px;
  margin: 0 auto;
}

.group-page .contact-layout {
  grid-template-columns: minmax(0, 1fr);
  gap: .9rem;
}

.group-page .contact-side {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: .9rem;
  align-items: start;
}

.group-page .contact-side > .card.detail-card,
.group-page .contact-side > .detail-card {
  margin-top: 0;
}

.group-page .group-header-grid {
  grid-template-columns: minmax(0, 1fr);
}

.group-page .group-header-side {
  gap: .55rem;
}

.group-page .group-header-actions {
  justify-content: flex-start;
}

.group-page .attendance-matrix-table th,
.group-page .attendance-matrix-table td {
  padding: .5rem .45rem;
}

.group-page .attendance-col {
  min-width: 2.35rem;
}

.group-page .attendance-pair-cell {
  min-width: 2.35rem;
}

.group-page .attendance-summary-cell {
  min-width: 3.4rem;
}

.group-page .pair-matrix-table td:nth-last-child(3),
.group-page .pair-matrix-table td:nth-last-child(2),
.group-page .single-dance-table td:nth-last-child(2) {
  min-width: 6.2rem;
}

.group-page .attendance-matrix-table td .payment-compact-cell,
.group-page .attendance-matrix-table td .payment-add-compact {
  max-width: 6.8rem;
}

.group-page .card.detail-card {
  overflow-x: clip;
}

.group-page .searchbar.compact-searchbar {
  flex-wrap: wrap;
}

@media (max-width: 1280px) {
  .group-page {
    max-width: 100%;
  }
}

@media (max-width: 900px) {
  .group-page .contact-side {
    grid-template-columns: 1fr;
  }
}


.small { font-size: .82rem; }
.compact { margin-bottom: 0; }
.span-2 { grid-column: span 2; }
.header-actions-inline { display: flex; gap: .5rem; flex-wrap: wrap; }
.workflow-counts { display: flex; gap: .5rem; flex-wrap: wrap; }
.workflow-filter-grid { max-width: none; }
.workflow-people-grid,
.workflow-review-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}
.workflow-person-card,
.workflow-review-card { padding: 1rem; }
.workflow-inline-note,
.inline-notice {
  margin: .35rem 0 .2rem;
  padding: .75rem .9rem;
  border-radius: 12px;
  border: 1px solid #bbf7d0;
  background: #f0fdf4;
  color: #14532d;
}

.workflow-list-card { padding: .95rem 1rem; }
.workflow-list-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: start;
}
.workflow-list-title { font-size: 1.25rem; margin: .15rem 0; }
.workflow-list-title a { color: inherit; text-decoration: none; }
.workflow-list-title a:hover { text-decoration: underline; }
.workflow-list-badges { display: flex; gap: .5rem; flex-wrap: wrap; justify-content: flex-end; }
.duplicate-choice-list {
  display: grid;
  gap: .6rem;
}
.duplicate-choice-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .75rem;
  align-items: start;
  padding: .75rem;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
}
.duplicate-choice-card:hover { background: #f8fafc; }
.duplicate-choice-card input { margin-top: .2rem; }
.duplicate-choice-head {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  align-items: center;
}
.workflow-result-links { display:flex; gap:.5rem; flex-wrap:wrap; }
@media (max-width: 960px) {
  .workflow-people-grid,
  .workflow-review-grid { grid-template-columns: 1fr; }
  .span-2 { grid-column: span 1; }
  .workflow-list-head { flex-direction: column; }
  .workflow-list-badges { justify-content: flex-start; }
}

.live-duplicate-panel {
  margin-top: .25rem;
  padding: .85rem;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #f8fafc;
  min-height: 5.2rem;
  max-height: 16rem;
  overflow: auto;
}
.live-duplicate-panel[hidden] { display: block; }
.live-duplicate-panel[data-state="idle"],
.live-duplicate-panel[data-state="waiting"],
.live-duplicate-panel[data-state="loading"],
.live-duplicate-panel[data-state="empty"],
.live-duplicate-panel[data-state="error"] {
  scroll-behavior: auto;
}
.live-duplicate-panel .duplicate-choice-list {
  margin-top: .55rem;
}
.duplicate-hint-card {
  padding: .75rem;
  border: 1px solid #dbe3ee;
  border-radius: 10px;
  background: #fff;
}
.duplicate-reasons {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}


.dashboard-trial-layout { display:grid; grid-template-columns: 1fr 1fr; gap:1rem; }
.dashboard-trial-cards { grid-template-columns: repeat(4, 1fr); }
.dashboard-trial-section { padding: 1rem; }
.dashboard-activity-section { padding: 1rem; }
.dashboard-activity-days { display:flex; flex-direction:column; gap:1rem; }
.dashboard-activity-day { border:1px solid #e5e7eb; border-radius:14px; background:#fafafa; overflow:hidden; }
.dashboard-activity-day-head { display:flex; justify-content:space-between; gap:1rem; padding:.85rem 1rem; background:#f3f4f6; border-bottom:1px solid #e5e7eb; }
.dashboard-activity-list { display:flex; flex-direction:column; }
.dashboard-activity-link { color:inherit; text-decoration:none; }
.dashboard-activity-link:hover .dashboard-activity-row { background:#f8fafc; }
.dashboard-activity-row { display:grid; grid-template-columns: 72px minmax(0,1fr) auto; gap:1rem; align-items:flex-start; padding:.9rem 1rem; border-top:1px solid #e5e7eb; }
.dashboard-activity-list > :first-child .dashboard-activity-row,
.dashboard-activity-list > .dashboard-activity-row:first-child { border-top:none; }
.dashboard-activity-time { font-weight:600; color:#111827; }
.dashboard-activity-body { min-width:0; }
.dashboard-activity-topline { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; margin-bottom:.2rem; }
.dashboard-activity-category { font-size:.9rem; color:#4b5563; font-weight:600; }
.dashboard-activity-title { font-weight:700; color:#111827; }
.dashboard-activity-meta { text-align:right; white-space:nowrap; }
.trial-day-list, .trial-upcoming-days { display:flex; flex-direction:column; gap:.75rem; }
.trial-day-card { border:1px solid #e5e7eb; border-radius:14px; padding:.85rem .95rem; background:#fafafa; }
.trial-day-head { display:flex; justify-content:space-between; gap:1rem; margin-bottom:.55rem; }
.trial-row { display:flex; justify-content:space-between; gap:1rem; align-items:flex-start; border-top:1px solid #e5e7eb; padding-top:.75rem; margin-top:.75rem; }
.trial-row:first-child { border-top:none; padding-top:0; margin-top:0; }
.trial-row.compact { padding-top:.55rem; margin-top:.55rem; }
.trial-row-meta { text-align:right; display:flex; flex-direction:column; gap:.35rem; align-items:flex-end; }
.compact-grid { gap:.75rem; }
@media (max-width: 960px) {
  .dashboard-trial-layout,
  .dashboard-trial-cards,
  .dashboard-activity-row { grid-template-columns: 1fr; }
  .trial-row { flex-direction:column; }
  .trial-row-meta,
  .dashboard-activity-meta { align-items:flex-start; text-align:left; }
  .dashboard-activity-time { margin-bottom:-.5rem; }
}

.enrollment-workflow-list { display: grid; gap: .6rem; }
.enrollment-workflow-item { display: flex; align-items: flex-start; justify-content: space-between; gap: .75rem; padding: .55rem 0; border-bottom: 1px solid #e5e7eb; }
.enrollment-workflow-item:last-child { border-bottom: 0; }
.enrollment-workflow-main { min-width: 0; flex: 1 1 auto; }
.enrollment-workflow-head { display: flex; align-items: center; gap: .45rem; flex-wrap: wrap; }
.enrollment-attendance-summary { margin-top: .18rem; }
.workflow-list-badges .btn-small { white-space: nowrap; }
.checkbox-row { display: flex; align-items: center; gap: .55rem; }
.compact-grid { gap: .9rem; }
@media (max-width: 900px) {
  .enrollment-workflow-item { flex-direction: column; }
}


.template-assist-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: .65rem;
  margin-bottom: .85rem;
}

.template-assist-row .field {
  margin: 0;
}

.template-action-row {
  display: flex;
  justify-content: flex-end;
}

.template-action-row .btn {
  margin-left: auto;
}

.field-label {
  display: block;
  margin-bottom: .35rem;
  color: #374151;
  font-size: .93rem;
  font-weight: 600;
}

.search-field-with-results {
  position: relative;
}

.search-field-with-results .search-results {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + .35rem);
  margin-top: 0;
  z-index: 30;
}

.group-picker-form {
  display: grid;
  gap: .65rem;
}

.group-picker-form .selected-contact {
  margin-top: 0;
}

.group-picker-form .field,
.workflow-group-picker .field {
  margin-bottom: 0;
}

.workflow-grid-with-picker {
  align-items: start;
}

.group-picker-field {
  display: grid;
  gap: .35rem;
}

.enrollment-workflow-list {
  overflow: visible;
}


.header-status {
  display: grid;
  gap: .35rem;
  align-content: start;
}

.status-link-list {
  gap: .35rem;
}

.card-collapse {
  display: grid;
  gap: 0;
}

.card-collapse-summary {
  list-style: none;
  cursor: pointer;
  margin-bottom: 0;
}

.card-collapse-summary::-webkit-details-marker {
  display: none;
}

.card-summary-indicator {
  color: #64748b;
  font-size: .82rem;
  font-weight: 600;
}

.card-collapse[open] .card-summary-indicator {
  visibility: hidden;
}

.card-collapse-body {
  padding-top: .2rem;
}

.card-collapse:not([open]) .card-collapse-body {
  display: none;
}

.contact-header-grid {
  grid-template-columns: minmax(0, 1.5fr) minmax(12rem, .72fr) minmax(16rem, 1fr);
}

@media (max-width: 960px) {
  .header-status {
    order: 3;
  }
}

.bulk-settings-layout {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: 1rem;
}

.segmented-choice {
  display: flex;
  flex-wrap: wrap;
  gap: .9rem;
  padding: .75rem .9rem;
  background: #f7f8fb;
  border: 1px solid #dfe4ef;
  border-radius: 12px;
}

.segmented-choice label {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-weight: 600;
}

.checkbox-field {
  padding-top: 1.5rem;
}


/* contact page finish pass */
.contact-page .detail-card,
.contact-page .contact-header-card {
  border-radius: 14px;
}

.contact-page .detail-card {
  padding: 1rem 1.05rem;
}

.contact-page .detail-card .card-header-row {
  align-items: flex-start;
}

.contact-page .detail-card .card-header-row h2,
.contact-page .contact-header-card .page-title {
  letter-spacing: -.01em;
}

.contact-page .detail-card .card-header-row h2 {
  line-height: 1.2;
}

.contact-page details.add-details,
.contact-page .detail-card > details.mt-md {
  border-top: 1px solid #edf2f7;
  padding-top: .7rem;
}

.contact-page details.add-details > summary,
.contact-page .detail-card > details.mt-md > summary {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .2rem 0;
  color: #1d4ed8;
  font-weight: 600;
}

.contact-page .detail-card > details.mt-md {
  margin-top: .8rem;
}

.contact-page .detail-card > details.mt-md > summary {
  color: #0f172a;
}

.card-summary-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4.8rem;
  padding: .18rem .5rem;
  border-radius: 999px;
  background: #f1f5f9;
  color: #475569;
  font-size: .76rem;
  font-weight: 700;
}

.card-collapse-summary {
  align-items: center;
}

.card-collapse-body {
  padding-top: .45rem;
}

.contact-channel-section + .contact-channel-section {
  border-top: 1px solid #edf2f7;
  padding-top: .8rem;
}

.contact-channel-list {
  gap: .5rem;
}

.contact-channel-row {
  padding: .18rem 0;
}

.address-inline-block {
  gap: .25rem;
}

.enrollment-workflow-item {
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #f8fafc;
  padding: .7rem .8rem;
}

.enrollment-workflow-item:last-child {
  border-bottom: 1px solid #e5e7eb;
}

.enrollment-workflow-main {
  display: grid;
  gap: .2rem;
}

.workflow-list-badges {
  align-items: flex-start;
}

.compact-summary-card {
  padding: .7rem .8rem;
}

.mini-card-head {
  align-items: flex-start;
}

.mini-card-body {
  gap: .32rem;
}

.status-link-list {
  gap: .4rem;
}

.link-pill {
  background: #eff6ff;
  color: #1e3a8a;
}

@media (max-width: 1100px) {
  .contact-layout {
    grid-template-columns: minmax(0, 1.05fr) minmax(21.5rem, .95fr);
  }
}

@media (max-width: 960px) {
  .enrollment-workflow-item:last-child {
    border-bottom: 1px solid #e5e7eb;
  }
}


/* v66 contact header + payment card refinements */
.compact-header-grid {
  grid-template-columns: minmax(0, 1.45fr) minmax(22rem, 1fr);
}

.payment-card {
  padding: .85rem .95rem;
}

.payment-card .contract-card-head {
  margin-bottom: .75rem;
}

.payment-card-body {
  display: grid;
  gap: .75rem;
}

.payment-card-body .label {
  margin-bottom: 0;
}

.payment-card-body .value-inline,
.payment-card-body .value-static {
  display: inline-block;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  line-height: 1.28;
  font-weight: 600;
  max-width: 100%;
  word-break: break-word;
}

.payment-card-body .value-inline[data-inline-edit="1"] {
  min-height: 0;
  padding: .08rem 0;
}

.payment-card .status-menu {
  justify-self: end;
}

@media (max-width: 1100px) {
  .compact-header-grid {
    grid-template-columns: 1fr;
  }
}

.contact-directory-page {
  display: grid;
  gap: .85rem;
}

.contact-directory-form {
  max-width: none;
}

.contact-directory-actions {
  justify-content: space-between;
  align-items: center;
}

.contact-directory-empty {
  padding: .95rem 1rem;
  border: 1px dashed #cbd5e1;
  border-radius: 12px;
  background: #f8fafc;
}

.contact-directory-results .table-wrap {
  margin-top: 0;
}

.contact-directory-table td,
.contact-directory-table th {
  vertical-align: top;
}

.contact-group-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}

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

.group-trial-quick-form {
  align-items: start;
}

.group-trial-form-grid {
  max-width: none;
}

@media (max-width: 720px) {
  .contact-age-filter-grid {
    grid-template-columns: 1fr;
  }

  .contact-directory-actions {
    flex-direction: column;
    align-items: flex-start;
  }
}

.topbar-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; max-width: 1360px; margin: 0 auto; }
.topbar nav { display: flex; flex-wrap: wrap; gap: .8rem; }
.topbar a { margin-right: 0; }
.topbar-user { display: flex; align-items: center; gap: .8rem; color: white; }
.topbar-user-meta { display: inline-flex; align-items: center; gap: .5rem; font-size: .95rem; }
.topbar-role { display: inline-flex; align-items: center; border-radius: 999px; padding: .12rem .5rem; background: rgba(255,255,255,.14); font-size: .78rem; text-transform: uppercase; letter-spacing: .03em; }
.topbar-login-link { color: white; text-decoration: none; font-weight: 600; }
.topbar-logout-form { margin: 0; }
.container-narrow { max-width: 36rem; }
.auth-shell { display: grid; place-items: center; min-height: calc(100vh - 12rem); }
.auth-card { width: min(100%, 30rem); background: #f8fafc; border: 1px solid #e5e7eb; border-radius: 16px; padding: 1.4rem; box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08); }
.auth-copy { margin-top: 0; color: #475569; }
.auth-form { max-width: none; }
.auth-actions { margin-top: .25rem; }
@media (max-width: 900px) {
  .topbar-inner { flex-direction: column; align-items: stretch; }
  .topbar-user { justify-content: space-between; }
}

.two-col-span { grid-column: 1 / -1; }
.subtle-copy { color: #475569; margin: .25rem 0 0; }
.user-admin-page .detail-card { background: #fff; }
.user-admin-table td:last-child, .user-admin-table th:last-child { width: 1%; white-space: nowrap; }
.user-admin-actions { gap: .45rem; }
.user-admin-form { max-width: none; }
.user-admin-checkbox { align-items: center; gap: .6rem; }
.user-admin-checkbox input[type="checkbox"] { width: 1rem; height: 1rem; }
.user-admin-edit-grid { grid-template-columns: minmax(0, 1.35fr) minmax(20rem, .95fr); }
.user-admin-panel { min-width: 0; }
.user-admin-meta { margin: 0; }
.user-admin-meta dd { margin: 0; }
.user-admin-side-form { margin: 0; }
.generated-password-card { background: #fff7ed; border-color: #fdba74; }
.generated-password-value { padding: .8rem .9rem; border-radius: 10px; background: #111827; color: #f8fafc; font-size: 1.15rem; overflow-x: auto; }
.generated-password-value code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
@media (max-width: 960px) {
  .user-admin-edit-grid { grid-template-columns: 1fr; }
  .two-col-span { grid-column: auto; }
}

.grid-two { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.form-grid.two-columns { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.stack-gap { display: grid; gap: 1rem; }
.summary-list.compact { display: grid; gap: .75rem; margin: 0; }
.summary-list.compact dt { font-size: .8rem; color: #667085; margin-bottom: .15rem; }
.summary-list.compact dd { margin: 0; font-weight: 600; }
.inline-flash { margin: 0; }
@media (max-width: 960px) {
  .grid-two, .form-grid.two-columns { grid-template-columns: 1fr; }
}

.job-message {
  max-width: 26rem;
  white-space: normal;
}
