/*
 * settings.css — Settings, Pricing & Permissions module (Wasla Ops)
 * Spec: 009-settings-pricing-permissions
 *
 * COMPOSITION-ONLY rules. All visual primitives inherited from
 * tokens.css / base.css / components.css / dashboard.css /
 * orders.css / merchants.css / settlements.css / returns.css / reports.css.
 *
 * No new design tokens. No raw hex or px literals.
 */

/* ==========================================================================
   Hub
   ========================================================================== */

.settings-hub {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.settings-hub__hero {
  padding: var(--space-8) var(--space-6);
  background: linear-gradient(135deg, var(--color-primary-50), var(--color-info-50));
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-primary-100);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-6);
}

.settings-hub__hero-text {
  flex: 1;
  min-inline-size: 0;
}

.settings-hub__hero-title {
  font-size: var(--type-display-size);
  font-weight: var(--type-display-weight);
  line-height: var(--type-display-lh);
  color: var(--color-neutral-900);
  margin: 0;
}

.settings-hub__hero-description {
  font-size: var(--type-body-size);
  color: var(--color-neutral-600);
  margin-block-start: var(--space-2);
}

.settings-hub__category-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

.settings-hub-card {
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  text-decoration: none;
  color: inherit;
  transition: box-shadow var(--motion-fast), border-color var(--motion-fast);
  border-block-start: 3px solid transparent;
}

.settings-hub-card:hover {
  border-color: var(--color-primary-400);
  box-shadow: var(--shadow-md);
}

.settings-hub-card--general {
  border-block-start-color: var(--color-primary-600);
}

.settings-hub-card--delivery {
  border-block-start-color: var(--color-info-600);
}

.settings-hub-card--access {
  border-block-start-color: var(--color-warning-600);
}

.settings-hub-card--system {
  border-block-start-color: var(--color-neutral-600);
}

.settings-hub-card__title {
  font-size: var(--type-h3-size);
  font-weight: var(--type-h3-weight);
  color: var(--color-neutral-800);
  margin: 0;
}

.settings-hub-card__description {
  font-size: var(--type-small-size);
  color: var(--color-neutral-500);
}

.settings-hub-card__link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-primary-600);
  text-decoration: none;
}

.settings-hub-card__link:hover {
  text-decoration: underline;
}

.settings-hub-card__meta {
  font-size: var(--type-small-size);
  color: var(--color-neutral-400);
  margin-block-start: auto;
}

@media (max-width: 1023.98px) {
  .settings-hub__category-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 639.98px) {
  .settings-hub__category-grid {
    grid-template-columns: 1fr;
  }
}

.settings-hub-quickstart {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.settings-hub-quickstart__title {
  font-size: var(--type-h3-size);
  font-weight: var(--type-h3-weight);
  color: var(--color-neutral-800);
  margin: 0;
}

.settings-hub-quickstart__row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

@media (max-width: 1023.98px) {
  .settings-hub-quickstart__row {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 639.98px) {
  .settings-hub-quickstart__row {
    grid-template-columns: 1fr;
  }
}

.settings-hub-quickstart__card {
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: inherit;
  transition: box-shadow var(--motion-fast), border-color var(--motion-fast);
}

.settings-hub-quickstart__card:hover {
  border-color: var(--color-primary-400);
  box-shadow: var(--shadow-md);
}

.settings-hub-quickstart__card-icon {
  inline-size: 36px;
  block-size: 36px;
  border-radius: var(--radius-md);
  background: var(--color-primary-50);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-600);
  flex-shrink: 0;
}

.settings-hub-quickstart__card-title {
  font-size: var(--type-body-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-800);
}

.settings-hub-quickstart__card-meta {
  font-size: var(--type-small-size);
  color: var(--color-neutral-400);
}

.settings-hub-activity {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.settings-hub-activity__title {
  font-size: var(--type-h3-size);
  font-weight: var(--type-h3-weight);
  color: var(--color-neutral-800);
  margin: 0;
}

.settings-hub-activity__row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
}

@media (max-width: 1023.98px) {
  .settings-hub-activity__row {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 639.98px) {
  .settings-hub-activity__row {
    grid-template-columns: 1fr;
  }
}

.settings-hub-activity__item {
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--type-small-size);
}

.settings-hub-activity__item-icon {
  inline-size: 32px;
  block-size: 32px;
  border-radius: var(--radius-md);
  background: var(--color-neutral-50);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-neutral-400);
  flex-shrink: 0;
}

.settings-hub-activity__item-text {
  color: var(--color-neutral-600);
}

.settings-hub-activity__item-time {
  color: var(--color-neutral-400);
  font-size: 11px;
}

/* ==========================================================================
   Shared Page Chassis
   ========================================================================== */

.settings-page {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  min-block-size: 0;
}

.settings-page__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-neutral-200);
  background: var(--color-neutral-0);
  box-shadow: var(--shadow-sm);
}

.settings-page__header--general {
  border-inline-start: 4px solid var(--color-primary-600);
}

.settings-page__header--delivery {
  border-inline-start: 4px solid var(--color-info-600);
}

.settings-page__header--access {
  border-inline-start: 4px solid var(--color-warning-600);
}

.settings-page__header--system {
  border-inline-start: 4px solid var(--color-neutral-600);
}

.settings-page__header-info {
  flex: 1;
  min-inline-size: 0;
}

.settings-page__header-category-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  margin-block-end: var(--space-1);
}

.settings-page__header--general .settings-page__header-category-badge {
  background: var(--color-primary-50);
  color: var(--color-primary-700);
}

.settings-page__header--delivery .settings-page__header-category-badge {
  background: var(--color-info-50);
  color: var(--color-info-700);
}

.settings-page__header--access .settings-page__header-category-badge {
  background: var(--color-warning-50);
  color: var(--color-warning-700);
}

.settings-page__header--system .settings-page__header-category-badge {
  background: var(--color-neutral-100);
  color: var(--color-neutral-700);
}

.settings-page__header-title {
  font-size: var(--type-h1-size);
  font-weight: var(--type-h1-weight);
  line-height: var(--type-h1-lh);
  color: var(--color-neutral-900);
  margin: 0;
}

.settings-page__header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}

.settings-page__summary-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

@media (max-width: 1023.98px) {
  .settings-page__summary-strip {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 639.98px) {
  .settings-page__summary-strip {
    grid-template-columns: 1fr;
  }
}

.settings-page__filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  flex-wrap: wrap;
}

.settings-page__active-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.settings-page__active-chips.is-empty {
  display: none;
}

.settings-page__active-chips__chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-neutral-100);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-700);
  white-space: nowrap;
}

.settings-page__active-chips__chip [data-chip-dismiss] {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: var(--color-neutral-400);
  font-size: 14px;
  line-height: 1;
  transition: color var(--motion-fast);
}

.settings-page__active-chips__chip [data-chip-dismiss]:hover {
  color: var(--color-danger-600);
}

.settings-page__empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-10) var(--space-6);
  text-align: center;
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.settings-page__empty-state__heading {
  font-size: var(--type-h3-size);
  font-weight: var(--type-h3-weight);
  color: var(--color-neutral-700);
  margin: 0 0 var(--space-2);
}

.settings-page__empty-state__description {
  font-size: var(--type-body-size);
  color: var(--color-neutral-500);
  max-inline-size: 400px;
  margin-block-end: var(--space-4);
}

.settings-page__empty-state__cta {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  border: none;
  background: var(--color-primary-600);
  color: var(--color-neutral-0);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.settings-page__empty-state__cta:hover {
  background: var(--color-primary-700);
}

.settings-page__no-results {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-6);
  text-align: center;
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
}

.settings-page__no-results__heading {
  font-size: var(--type-body-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  margin: 0 0 var(--space-2);
}

.settings-page__no-results__action {
  font-size: var(--type-small-size);
  color: var(--color-primary-600);
  cursor: pointer;
  background: none;
  border: none;
  font-weight: var(--type-label-weight);
}

/* ==========================================================================
   Form Chassis
   ========================================================================== */

.settings-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.settings-form__unsaved-banner {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-lg);
  background: var(--color-warning-50);
  border: 1px solid var(--color-warning-500);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-warning-700);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.settings-form__section {
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.settings-form__section-title {
  font-size: var(--type-h3-size);
  font-weight: var(--type-h3-weight);
  color: var(--color-neutral-800);
  margin: 0;
  padding-block-end: var(--space-3);
  border-block-end: 1px solid var(--color-neutral-100);
}

.settings-form__section-subtitle {
  font-size: var(--type-small-size);
  color: var(--color-neutral-500);
  margin: 0;
}
.settings-form__section-subtitle--spaced {
  margin-block-end: var(--space-4);
}

.settings-form__grid {
  display: grid;
  gap: var(--space-5);
}

.settings-form__grid--two-col {
  grid-template-columns: repeat(2, 1fr);
}

.settings-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-form__field-label {
  font-size: var(--type-label-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-700);
  letter-spacing: var(--type-label-tracking);
}

.settings-form__field-label .required {
  color: var(--color-danger-600);
  margin-inline-start: var(--space-1);
}

.settings-form__field-helper {
  font-size: var(--type-small-size);
  color: var(--color-neutral-500);
}

.settings-form__field-error {
  font-size: var(--type-small-size);
  color: var(--color-danger-700);
  display: none;
}

.settings-form__field-error.is-visible {
  display: block;
}

.settings-form__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.settings-form__footer--sticky {
  position: sticky;
  bottom: 0;
  z-index: 10;
}

.settings-form__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.settings-form__danger-zone {
  background: var(--color-danger-50);
  border: 1px solid var(--color-danger-500);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.settings-form__danger-zone header {
  font-size: var(--type-h3-size);
  font-weight: var(--type-h3-weight);
  color: var(--color-danger-700);
  margin: 0;
}

.settings-form__danger-zone-action {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

@media (max-width: 1023.98px) {
  .settings-form__grid--two-col {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767.98px) {
  .settings-page__header {
    flex-direction: column;
    align-items: flex-start;
  }

  .settings-page__filter-bar {
    flex-wrap: wrap;
  }

  .settings-form__section {
    padding: var(--space-4);
  }
}

/* ==========================================================================
   Zones
   ========================================================================== */

.settings-zones-table {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-body-size);
  line-height: var(--type-body-lh);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.settings-zones-table thead {
  background: var(--color-neutral-50);
  border-bottom: 1px solid var(--color-neutral-200);
}

.settings-zones-table th {
  padding: var(--space-3) var(--space-4);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: start;
  white-space: nowrap;
}

.settings-zones-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-neutral-100);
  vertical-align: middle;
}

.settings-zones-table tbody tr:last-child td {
  border-bottom: none;
}

.settings-zones-table tbody tr:hover {
  background: var(--color-neutral-50);
}

.settings-zones-table__missing-price-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
  background: var(--color-warning-50);
  color: var(--color-warning-700);
  font-size: 11px;
  font-weight: var(--type-label-weight);
}

.settings-zone-groups-panel {
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-zone-groups-panel__title {
  font-size: var(--type-body-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-800);
  padding-block-end: var(--space-2);
  border-block-end: 1px solid var(--color-neutral-100);
}

.settings-zone-groups-panel__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--type-small-size);
  color: var(--color-neutral-700);
}

.settings-zone-groups-panel__item:hover {
  background: var(--color-neutral-50);
}

.settings-zone-form__boundary-placeholder {
  background: var(--color-neutral-50);
  border: 2px dashed var(--color-neutral-300);
  border-radius: var(--radius-lg);
  padding: var(--space-10);
  text-align: center;
  color: var(--color-neutral-400);
  font-size: var(--type-body-size);
}

/* ==========================================================================
   Pricing
   ========================================================================== */

.settings-pricing-table {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-body-size);
  line-height: var(--type-body-lh);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.settings-pricing-table thead {
  background: var(--color-neutral-50);
  border-bottom: 1px solid var(--color-neutral-200);
}

.settings-pricing-table th {
  padding: var(--space-3) var(--space-4);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: start;
  white-space: nowrap;
}

.settings-pricing-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-neutral-100);
  vertical-align: middle;
}

.settings-pricing-table tbody tr:last-child td {
  border-bottom: none;
}

.settings-pricing-table tbody tr:hover {
  background: var(--color-neutral-50);
}

.settings-pricing-table__zone-chips {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.settings-pricing-form__model-selector {
  display: inline-flex;
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.settings-pricing-form__model-selector button {
  padding: var(--space-2) var(--space-3);
  border: none;
  background: var(--color-neutral-0);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  cursor: pointer;
  transition: background var(--motion-fast), color var(--motion-fast);
}

.settings-pricing-form__model-selector button:not(:last-child) {
  border-inline-end: 1px solid var(--color-neutral-200);
}

.settings-pricing-form__model-selector button:hover {
  background: var(--color-neutral-50);
}

.settings-pricing-form__model-selector button.is-selected {
  background: var(--color-primary-50);
  color: var(--color-primary-700);
  font-weight: 600;
}

.settings-pricing-form__model-inputs {
  display: none;
}

.settings-pricing-form__model-inputs.is-active {
  display: block;
}

.settings-pricing-form__model-inputs--flat,
.settings-pricing-form__model-inputs--weight,
.settings-pricing-form__model-inputs--size,
.settings-pricing-form__model-inputs--distance {
}

.settings-pricing-form__calc-preview {
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-pricing-form__calc-preview__title {
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
}

.settings-pricing-form__calc-preview__breakdown {
  font-size: var(--type-body-size);
  color: var(--color-neutral-700);
}

/* ==========================================================================
   COD & Fees
   ========================================================================== */

.settings-cod__tier-table {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-body-size);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.settings-cod__tier-table th {
  padding: var(--space-3) var(--space-4);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: start;
  background: var(--color-neutral-50);
  border-bottom: 1px solid var(--color-neutral-200);
}

.settings-cod__tier-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-neutral-100);
  vertical-align: middle;
}

.settings-cod__tier-table tbody tr:last-child td {
  border-bottom: none;
}

.settings-cod__tier-value-suffix {
  font-size: var(--type-small-size);
  color: var(--color-neutral-500);
  margin-inline-start: var(--space-1);
}

.settings-cod__extra-fees-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-cod__extra-fees-list__row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-neutral-50);
}

.settings-cod__extra-fees-list__label {
  flex: 1;
  font-size: var(--type-body-size);
  color: var(--color-neutral-700);
}

.settings-cod__extra-fees-list__amount {
  font-size: var(--type-body-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-800);
  font-variant-numeric: tabular-nums;
}

.settings-cod__calc-preview {
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.settings-cod__calc-preview__title {
  font-size: var(--type-body-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-800);
}

.settings-cod__calc-preview__line {
  display: flex;
  justify-content: space-between;
  font-size: var(--type-small-size);
  color: var(--color-neutral-600);
}

.settings-cod__calc-preview__total {
  display: flex;
  justify-content: space-between;
  padding-block-start: var(--space-2);
  border-block-start: 1px solid var(--color-neutral-200);
  font-weight: 600;
  color: var(--color-neutral-900);
}

/* ==========================================================================
   Roles
   ========================================================================== */

.settings-roles-table {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-body-size);
  line-height: var(--type-body-lh);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.settings-roles-table thead {
  background: var(--color-neutral-50);
  border-bottom: 1px solid var(--color-neutral-200);
}

.settings-roles-table th {
  padding: var(--space-3) var(--space-4);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: start;
  white-space: nowrap;
}

.settings-roles-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-neutral-100);
  vertical-align: middle;
}

.settings-roles-table tbody tr:last-child td {
  border-bottom: none;
}

.settings-roles-table tbody tr:hover {
  background: var(--color-neutral-50);
}

.settings-roles-table__system-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
  background: var(--color-info-50);
  color: var(--color-info-700);
  font-size: 11px;
  font-weight: var(--type-label-weight);
}

.settings-roles-table__custom-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
  background: var(--color-neutral-100);
  color: var(--color-neutral-700);
  font-size: 11px;
  font-weight: var(--type-label-weight);
}

.settings-role-form__capability-accordion {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-role-form__capability-accordion details {
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.settings-role-form__capability-accordion-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  background: var(--color-neutral-50);
  font-size: var(--type-body-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-800);
  cursor: pointer;
}

.settings-role-form__capability-count {
  font-size: var(--type-small-size);
  color: var(--color-neutral-500);
}

.settings-role-form__scope-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.settings-role-form__linked-users-preview {
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-role-form__linked-users-preview__user {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--type-small-size);
  color: var(--color-neutral-700);
}

/* ==========================================================================
   Permissions Matrix
   ========================================================================== */

.permissions-matrix {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-body-size);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.permissions-matrix thead {
  background: var(--color-neutral-50);
  border-bottom: 1px solid var(--color-neutral-200);
}

.permissions-matrix th {
  padding: var(--space-3) var(--space-4);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: center;
  white-space: nowrap;
}

.permissions-matrix th:first-child {
  text-align: start;
}

.permissions-matrix__sticky-roles {
  position: sticky;
  top: 0;
  z-index: 5;
}

.permissions-matrix__role-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
}

.permissions-matrix__role-header-chip {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  white-space: nowrap;
}

.permissions-matrix__category-row td {
  padding: var(--space-2) var(--space-4);
  background: var(--color-neutral-50);
  font-size: var(--type-small-size);
  font-weight: 600;
  color: var(--color-neutral-700);
  border-block-end: 1px solid var(--color-neutral-200);
}

.permissions-matrix__capability-row td {
  padding: var(--space-2) var(--space-4);
  border-block-end: 1px solid var(--color-neutral-100);
  text-align: center;
  vertical-align: middle;
}

.permissions-matrix__capability-row td:first-child {
  text-align: start;
  font-size: var(--type-body-size);
  color: var(--color-neutral-700);
}

.permission-cell {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 28px;
  block-size: 28px;
  border-radius: var(--radius-full);
  font-size: 14px;
  font-weight: 600;
}

.permission-cell--full {
  background: var(--color-success-50);
  color: var(--color-success-600);
}

.permission-cell--read {
  background: var(--color-info-50);
  color: var(--color-info-500);
}

.permission-cell--none {
  background: var(--color-neutral-100);
  color: var(--color-neutral-400);
}

.permissions-matrix__legend {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  font-size: var(--type-small-size);
  color: var(--color-neutral-500);
}

.permissions-matrix__legend-item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.permissions-matrix__export {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-neutral-200);
  background: var(--color-neutral-0);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-600);
  cursor: pointer;
}

.permissions-matrix__export:hover {
  background: var(--color-neutral-50);
}

.permissions-matrix--mobile {
  display: none;
}

.permissions-matrix--mobile__role-picker {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: var(--space-3) 0;
}

.permissions-matrix--mobile__role-picker button {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-neutral-200);
  background: var(--color-neutral-0);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-600);
  cursor: pointer;
  transition: background var(--motion-fast), border-color var(--motion-fast);
}

.permissions-matrix--mobile__role-picker button.is-active {
  background: var(--color-primary-50);
  border-color: var(--color-primary-400);
  color: var(--color-primary-700);
}

.permissions-matrix--mobile dl {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.permissions-matrix--mobile dt {
  padding: var(--space-2) var(--space-3);
  font-size: var(--type-small-size);
  font-weight: 600;
  color: var(--color-neutral-700);
  background: var(--color-neutral-50);
  border-block-end: 1px solid var(--color-neutral-200);
}

.permissions-matrix--mobile dd {
  display: none;
  padding: var(--space-2) var(--space-3);
  font-size: var(--type-body-size);
  color: var(--color-neutral-600);
  border-block-end: 1px solid var(--color-neutral-100);
}

.permissions-matrix--mobile dd.is-visible {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media (max-width: 767.98px) {
  .permissions-matrix:not(.permissions-matrix--mobile) {
    display: none;
  }

  .permissions-matrix--mobile {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    background: var(--color-neutral-0);
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-xl);
    padding: var(--space-4);
    box-shadow: var(--shadow-sm);
  }
}

/* ==========================================================================
   Users
   ========================================================================== */

.users-table {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-body-size);
  line-height: var(--type-body-lh);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.users-table thead {
  background: var(--color-neutral-50);
  border-bottom: 1px solid var(--color-neutral-200);
}

.users-table th {
  padding: var(--space-3) var(--space-4);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: start;
  white-space: nowrap;
}

.users-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-neutral-100);
  vertical-align: middle;
}

.users-table tbody tr:last-child td {
  border-bottom: none;
}

.users-table tbody tr:hover {
  background: var(--color-neutral-50);
}

.users-table__avatar {
  inline-size: 32px;
  block-size: 32px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--type-small-size);
  font-weight: 600;
  flex-shrink: 0;
}

.users-table__status-chip {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: var(--type-label-weight);
}

.user-detail__identity {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.user-detail__identity-avatar {
  inline-size: 56px;
  block-size: 56px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--type-h2-size);
  font-weight: 700;
  flex-shrink: 0;
}

.user-detail__identity-info {
  flex: 1;
  min-inline-size: 0;
}

.user-detail__identity-name {
  font-size: var(--type-h2-size);
  font-weight: var(--type-h2-weight);
  color: var(--color-neutral-900);
}

.user-detail__identity-role {
  margin-inline-start: var(--space-2);
}

.user-detail__effective-permissions {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.user-detail__activity-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.user-detail__activity-timeline__row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-block-end: 1px solid var(--color-neutral-100);
  font-size: var(--type-small-size);
}

.user-detail__activity-timeline__row:last-child {
  border-block-end: none;
}

.user-detail__sessions-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.user-detail__sessions-list__row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-block-end: 1px solid var(--color-neutral-100);
  font-size: var(--type-small-size);
}

.user-detail__sessions-list__row:last-child {
  border-block-end: none;
}

.user-detail__sessions-list__row.is-current {
  background: var(--color-primary-50);
}

.user-detail__sessions-list__row.is-terminated {
  opacity: 0.4;
}

/* ==========================================================================
   Notifications
   ========================================================================== */

.settings-notifications__channels {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-notifications__channel-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-neutral-50);
}

.settings-notifications__channel-row--coming-soon {
  opacity: 0.6;
}

.settings-notifications__channel-row--coming-soon button {
  cursor: not-allowed;
}

.settings-notifications__event-matrix {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-small-size);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.settings-notifications__event-matrix th {
  padding: var(--space-2) var(--space-3);
  background: var(--color-neutral-50);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: center;
}

.settings-notifications__event-matrix th:first-child {
  text-align: start;
}

.settings-notifications__event-matrix td {
  padding: var(--space-2) var(--space-3);
  text-align: center;
  border-block-end: 1px solid var(--color-neutral-100);
}

.settings-notifications__event-matrix td:first-child {
  text-align: start;
}

.settings-notifications__event-matrix__pinned {
  opacity: 0.7;
}

.settings-notifications__templates {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-notifications__quiet-hours {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* ==========================================================================
   Security
   ========================================================================== */

.settings-security__password-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.settings-security__2fa-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
}

.settings-security__sessions-table {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-body-size);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.settings-security__sessions-table th {
  padding: var(--space-3) var(--space-4);
  background: var(--color-neutral-50);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: start;
  border-block-end: 1px solid var(--color-neutral-200);
}

.settings-security__sessions-table td {
  padding: var(--space-3) var(--space-4);
  border-block-end: 1px solid var(--color-neutral-100);
  vertical-align: middle;
}

.settings-security__sessions-table tbody tr:last-child td {
  border-block-end: none;
}

.settings-security__sessions-table tr.is-current {
  background: var(--color-primary-50);
}

.settings-security__sessions-table tr.is-current td:first-child {
  font-weight: 600;
}

.settings-security__sessions-table tr.is-terminated {
  opacity: 0.4;
}

.settings-security__policy {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

@media (max-width: 767.98px) {
  .settings-security__policy {
    grid-template-columns: 1fr;
  }
}

.settings-security__audit-log {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.settings-security__audit-log__row {
  display: grid;
  grid-template-columns: auto 1fr auto auto auto;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-2) var(--space-4);
  border-block-end: 1px solid var(--color-neutral-100);
  font-size: var(--type-small-size);
}

.settings-security__audit-log__row:last-child {
  border-block-end: none;
}

.settings-security__api-keys {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-security__api-keys__row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-neutral-50);
  font-size: var(--type-small-size);
}

/* ==========================================================================
   Modals & Toasts
   ========================================================================== */

.settings-modal {
  border: none;
  border-radius: var(--radius-xl);
  padding: 0;
  max-inline-size: 520px;
  inline-size: 90vw;
  box-shadow: var(--shadow-xl);
  position: fixed;
  inset: 0;
  margin: auto;
}

.settings-modal::backdrop {
  background: rgba(16, 24, 40, 0.4);
}

.settings-modal__header {
  padding: var(--space-5) var(--space-6);
  border-block-end: 1px solid var(--color-neutral-100);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.settings-modal__title {
  font-size: var(--type-h3-size);
  font-weight: var(--type-h3-weight);
  color: var(--color-neutral-900);
  margin: 0;
}

.settings-modal__close {
  background: none;
  border: none;
  padding: var(--space-2);
  cursor: pointer;
  color: var(--color-neutral-400);
  border-radius: var(--radius-md);
  position: absolute;
  inset-inline-start: var(--space-4);
  top: var(--space-4);
}

.settings-modal__close:hover {
  background: var(--color-neutral-50);
  color: var(--color-neutral-600);
}

.settings-modal__body {
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.settings-modal__typed-confirm {
  background: var(--color-danger-50);
  border: 1px solid var(--color-danger-500);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.settings-modal__typed-confirm p {
  font-size: var(--type-body-size);
  color: var(--color-danger-700);
  margin: 0;
}

.settings-modal__typed-confirm-input {
  block-size: 40px;
  padding-inline: var(--space-3);
  border: 1px solid var(--color-neutral-300);
  border-radius: var(--radius-md);
  background: var(--color-neutral-0);
  font-size: var(--type-body-size);
  color: var(--color-neutral-700);
  inline-size: 100%;
  direction: rtl;
}

.settings-modal__typed-confirm-input:focus {
  border-color: var(--color-primary-600);
  outline: var(--focus-ring-width) solid var(--focus-ring-color);
  outline-offset: var(--focus-ring-offset);
}

.settings-modal__footer {
  padding: var(--space-4) var(--space-6);
  border-block-start: 1px solid var(--color-neutral-100);
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  position: relative;
}

.settings-toast {
  position: fixed;
  bottom: var(--space-6);
  inset-inline-start: 50%;
  transform: translateX(-50%) translateY(120%);
  padding: var(--space-3) var(--space-5);
  background: var(--color-neutral-800);
  color: var(--color-neutral-0);
  border-radius: var(--radius-lg);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  box-shadow: var(--shadow-xl);
  z-index: 100;
  opacity: 0;
  transition: transform var(--motion-base), opacity var(--motion-base);
  pointer-events: none;
}

.settings-toast.is-visible {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
  pointer-events: auto;
}

@media (prefers-reduced-motion: reduce) {
  .settings-toast,
  .settings-modal {
    transition: none;
  }
}

/* ==========================================================================
   Company Profile
   ========================================================================== */

.settings-company__branches-table {
  inline-size: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--type-body-size);
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.settings-company__branches-table th {
  padding: var(--space-3) var(--space-4);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-neutral-500);
  text-align: start;
  background: var(--color-neutral-50);
  border-block-end: 1px solid var(--color-neutral-200);
}

.settings-company__branches-table td {
  padding: var(--space-3) var(--space-4);
  border-block-end: 1px solid var(--color-neutral-100);
}

.settings-company__branches-table tbody tr:last-child td {
  border-block-end: none;
}

.settings-company__currency-warning {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-warning-50);
  border: 1px solid var(--color-warning-500);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-warning-700);
}

/* ==========================================================================
   Branding
   ========================================================================== */

.settings-branding__swatches {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-3);
}

@media (max-width: 767.98px) {
  .settings-branding__swatches {
    grid-template-columns: repeat(3, 1fr);
  }
}

.settings-branding__swatch {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-neutral-200);
  background: var(--color-neutral-0);
}

.settings-branding__swatch-color {
  inline-size: 48px;
  block-size: 48px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-neutral-200);
}

.settings-branding__swatch-label {
  font-size: 11px;
  color: var(--color-neutral-500);
}

.settings-branding__preview {
  background: var(--color-neutral-0);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: grid;
  grid-template-columns: 1fr 200px;
  gap: var(--space-5);
}

@media (max-width: 767.98px) {
  .settings-branding__preview {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   Operational
   ========================================================================== */

.settings-operational__working-hours {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.settings-operational__working-hours__row {
  display: grid;
  grid-template-columns: 100px 1fr 1fr auto;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-2) 0;
  font-size: var(--type-body-size);
}

@media (max-width: 767.98px) {
  .settings-operational__working-hours__row {
    grid-template-columns: 80px 1fr 1fr;
  }
}

.settings-operational__copy-all-helper {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px dashed var(--color-primary-400);
  background: var(--color-primary-50);
  font-size: var(--type-small-size);
  font-weight: var(--type-label-weight);
  color: var(--color-primary-700);
  cursor: pointer;
}

.settings-operational__copy-all-helper:hover {
  background: var(--color-primary-100);
}

.settings-operational__order-preview {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
}

.settings-operational__order-preview__label {
  font-size: var(--type-small-size);
  color: var(--color-neutral-500);
}

.settings-operational__order-preview__value {
  font-size: var(--type-h2-size);
  font-weight: var(--type-h2-weight);
  color: var(--color-primary-600);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
}

/* ==========================================================================
   Print
   ========================================================================== */

@media print {
  .app-sidebar,
  .app-topbar,
  .settings-page__filter-bar,
  .settings-page__active-chips,
  .settings-form__footer,
  .settings-form__unsaved-banner,
  .settings-form__danger-zone,
  .settings-toast,
  .settings-modal {
    display: none !important;
  }

  .app-main {
    margin: 0 !important;
    padding: 0 !important;
  }

  .app-content {
    inline-size: 100% !important;
    max-inline-size: 100% !important;
    padding: 0 !important;
  }

  body {
    background: white !important;
    color: black !important;
  }

  * {
    box-shadow: none !important;
  }

  .permissions-matrix {
    font-size: 10px;
  }

  .permission-cell {
    inline-size: 20px;
    block-size: 20px;
    font-size: 11px;
  }

  @page {
    size: A4 landscape;
    margin: 10mm;
  }
}

.badge--soft {
  background: var(--color-neutral-100);
  color: var(--color-neutral-700);
}

/* Spec 033 — form field polish (additive, non-structural) */
.form-field__hint {
  font-size: 12px;
  color: var(--color-neutral-500);
  margin-block-start: 4px;
  line-height: 1.5;
}

.form-field__error {
  font-size: 12px;
  color: var(--color-danger-700);
  margin-block-start: 4px;
  line-height: 1.5;
}

.create-form__field--error input,
.create-form__field--error select,
.create-form__field--error textarea {
  border-color: var(--color-danger-500);
  outline-color: var(--color-danger-500);
}

.create-form-error-banner {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  background: var(--color-danger-50);
  color: var(--color-danger-700);
  border: 1px solid var(--color-danger-500);
  border-radius: 8px;
  margin-block-end: 16px;
}

.create-form-error-banner__msg {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
}

/* ==========================================================================
   COD tier table — input widths (Spec 033 / design polish)
   ========================================================================== */

.settings-cod__tier-input {
  inline-size: 110px;
}

.settings-cod__tier-input--value {
  inline-size: 90px;
}

.settings-cod__tier-select {
  inline-size: 130px;
}

/* ==========================================================================
   Permissions matrix — alternate row striping & system role chip
   ========================================================================== */

.permissions-matrix__capability-row--alt td {
  background: var(--color-neutral-50);
}

.permissions-matrix__role-header-chip--system {
  background: var(--color-warning-50);
  color: var(--color-warning-700);
  border: 1px solid var(--color-warning-200);
}

/* ==========================================================================
   Settings form — required / optional inline markers (used in user forms)
   ========================================================================== */

.settings-form__field .required {
  color: var(--color-danger-600);
}

.settings-form__field .optional {
  font-size: var(--type-small-size);
  font-weight: normal;
  color: var(--color-neutral-400);
  margin-inline-start: var(--space-1);
}

/* ==========================================================================
   Confirm-delete modal  (<dialog> element, used on all settings pages)
   ========================================================================== */

.confirm-modal {
  border: none;
  border-radius: var(--radius-lg);
  padding: 0;
  box-shadow: var(--shadow-xl);
  inline-size: min(420px, 90vw);
  max-block-size: 90vh;
  overflow-y: auto;
  position: fixed;
  inset: 0;
  margin: auto;
}

.confirm-modal::backdrop {
  background: rgba(0, 0, 0, 0.45);
}

.confirm-modal__box {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.confirm-modal__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 48px;
  block-size: 48px;
  border-radius: 50%;
  background: var(--color-danger-50);
  color: var(--color-danger-600);
  margin-block-end: var(--space-1);
}

.confirm-modal__title {
  font-size: var(--type-label-size);
  font-weight: 600;
  color: var(--color-neutral-900);
  margin: 0;
}

.confirm-modal__body {
  color: var(--color-neutral-600);
  font-size: var(--type-body-size);
  line-height: 1.6;
  margin: 0;
}

.confirm-modal__footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: var(--space-3);
  padding-block-start: var(--space-2);
  border-block-start: 1px solid var(--color-neutral-100);
  margin-block-start: var(--space-2);
}
