
.s360-ui-card,
.s360-ui-section-card,
.s360-ui-stat-card,
.s360-ui-card {
  background: var(--s360-color-surface);
  border: 1px solid var(--s360-color-border);
  border-radius: var(--s360-radius-xl);
  box-shadow: var(--s360-shadow-sm);
}

.s360-ui-card,
.s360-ui-section-card {
  padding: var(--s360-component-card-padding);
}

.s360-ui-stat-card {
  padding: var(--s360-card-stat-padding, var(--s360-statcard-padding, calc(var(--s360-component-card-padding) - 2px)));
}

/* .s360-ui-card--flush removed (0 markup usage, duplicate of .s360-m-0 utility). */

.s360-ui-card__title-reset,
.s360-h4-reset {
  margin-bottom: var(--s360-space-sm);
}

.s360-section-title {
  margin: 0 0 var(--s360-component-card-padding);
  padding-bottom: var(--s360-space-xs);
  border-bottom: 1px solid var(--s360-color-border-soft);
}

.s360-form-field {
  margin-bottom: var(--s360-space-md);
}

.s360-prose p {
  margin: 0 0 var(--s360-space-xs);
}

.s360-prose p:last-child,
.s360-prose ul:last-child,
.s360-prose li:last-child {
  margin-bottom: 0;
}

.s360-stat-value {
  display: block;
  font-size: var(--s360-card-stat-value-size, var(--s360-statcard-value-size, 24px));
  line-height: 1;
  font-weight: var(--s360-statcard-value-weight, var(--s360-font-weight-bold));
  margin-bottom: var(--s360-space-xs);
}

.s360-stat-label {
  color: var(--s360-color-text-label, var(--s360-color-text-soft));
  font-size: var(--s360-statcard-label-size, var(--s360-font-size-xs, 12px));
  font-weight: var(--s360-statcard-label-weight, 700);
  line-height: var(--s360-statcard-line-height, 1.2);
}

.s360-ui-section-card--toolbar {
  margin-bottom: calc(var(--s360-component-card-padding) - 2px);
}


/* .s360-ui-card--compact lives in the canonical card-system.css location. */
.s360-ui-stat-card__value {
  display: block;
  font-size: var(--s360-card-stat-value-size, var(--s360-statcard-value-size, 24px));
  line-height: 1;
  font-weight: var(--s360-statcard-value-weight, var(--s360-font-weight-bold));
}
.s360-ui-stat-card__value--success { color: var(--s360-color-success); }
.s360-ui-stat-card__value--warning { color: var(--s360-color-warning-strong); }
.s360-ui-stat-card__value--danger { color: var(--s360-color-danger-strong); }
.s360-ui-stat-card__label { margin-top: var(--s360-space-2xs); }
.s360-pre {
  background: var(--s360-color-bg-subtle);
  padding: 10px;
  overflow-x: auto;
}
.s360-badge {
  display: inline-block;
  border-radius: var(--s360-component-pill-radius);
  padding: 2px 8px;
  font-size: 11px;
  line-height: 1.5;
}
.s360-badge--danger { background: var(--s360-color-danger-strong); color: var(--s360-color-surface-raised); }
.s360-table-row-strong { font-weight: var(--s360-font-weight-semibold); }
.s360-table-row-error { background: var(--s360-color-danger-bg); }
.s360-table-row-skip { background: var(--s360-color-warning-bg); opacity: 0.85; }
.s360-note-row {
  padding: 12px 0;
  border-bottom: 1px solid var(--s360-color-border-subtle);
}


.s360-heading-md { font-size: 18px; font-weight: var(--s360-font-weight-semibold); }
.s360-subtle-note { margin-top: 6px; color: var(--s360-color-text-muted); }
.s360-stat-strong { display: block; font-size: 24px; }
.s360-inline-checkbox { display: inline-block; min-width: 240px; margin: 0 16px 8px 0; }
.s360-inline-checkbox-sm { display: inline-block; min-width: 130px; margin: 0 16px 8px 0; }
.s360-filter-bar { margin-bottom: var(--s360-space-md); display: flex; gap: var(--s360-space-sm); align-items: end; flex-wrap: wrap; }
.s360-form-stack-compact { display: grid; gap: 6px; min-width: 220px; }
.s360-button-tile { text-align: center; padding: var(--s360-space-xs, 8px) 10px; height: auto; }
.s360-button-shortcut { margin-right: var(--s360-space-xs); margin-bottom: var(--s360-space-xs); }
.s360-status-positive { color: var(--s360-color-success); font-weight: var(--s360-font-weight-semibold); }
.s360-status-negative { color: var(--s360-color-danger-strong); font-weight: var(--s360-font-weight-semibold); }
.s360-ui-section-card__title { margin-top: 0; font-size: var(--s360-font-size-lg); }
.s360-calendar-table { margin-bottom: var(--s360-space-lg); text-align: center; }
.s360-calendar-cell { vertical-align: top; height: 100px; min-width: 110px; }
.s360-calendar-event { background: var(--s360-color-primary); color: var(--s360-color-surface-raised); padding: 2px 4px; margin: 2px 0; font-size: 11px; border-radius: var(--s360-radius-sm); }
.s360-list-disc-padded { list-style: disc; padding-left: 18px; }


.s360-list-disc-block { margin: 0 0 var(--s360-space-md); padding-left: 18px; }
.s360-portal-lead { margin: 0 0 14px; }
.s360-gallery-thumb { width: 100%; height: 180px; object-fit: cover; }
.s360-ui-card[data-s360-portal-card="login"] { max-width: 460px; margin: auto; }
.s360-login-intro { margin-top: -4px; color: var(--s360-color-text-muted); }


.s360-media-picker {
  border: 1px solid var(--s360-color-border-soft);
  border-radius: var(--s360-radius-md);
  padding: var(--s360-space-md);
  background: var(--s360-color-surface-muted);
}

.s360-media-preview {
  min-height: 120px;
}

.s360-school-logo {
  display: inline-block;
  max-width: 100%;
  height: auto;
}

.s360-school-logo--settings {
  max-height: 96px;
}

.s360-school-logo--login,
.s360-school-logo--portal {
  max-height: 72px;
}

.s360-login-logo-wrap,
.s360-portal-logo-wrap {
  margin: 0 0 var(--s360-space-md);
}

.s360-login-logo-wrap {
  text-align: center;
}


.s360-form-row { display: grid; gap: var(--s360-form-row-gap); }
.s360-form-stack { display: grid; gap: var(--s360-form-stack-gap); }
.s360-form-actions { display: flex; flex-wrap: wrap; gap: var(--s360-form-actions-gap); align-items: center; }
.s360-form-actions--end { justify-content: flex-end; }
.s360-form-actions--split { justify-content: space-between; }
.s360-form-label { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: var(--s360-font-weight-bold); letter-spacing: .04em; text-transform: uppercase; color: var(--s360-color-form-label); }
.s360-form-label--stacked { margin-bottom: var(--s360-form-help-gap); }
.s360-form-help,
.s360-field-help { font-size: 12px; line-height: 1.5; color: var(--s360-color-form-help); }
.s360-form-error,
.s360-field-error { font-size: 12px; line-height: 1.5; color: var(--s360-color-form-error); }
.s360-form-status-error { padding: 10px var(--s360-space-sm, 12px); border: 1px solid var(--s360-color-form-error-border); border-radius: var(--s360-radius-lg); background: var(--s360-color-form-error-bg); color: var(--s360-color-form-error); }
.s360-form-read-value { min-height: var(--s360-control-height-md); display: flex; align-items: center; padding: 10px 12px; border: 1px solid var(--s360-color-form-read-border); border-radius: var(--s360-control-radius); background: var(--s360-color-form-read-bg); color: var(--s360-color-text-heading); }
.s360-form-read-value--multiline { min-height: calc(var(--s360-control-height-lg) + 12px); align-items: flex-start; }

.s360-table-toolbar-panel {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--s360-table-toolbar-gap);
  padding: var(--s360-table-toolbar-padding-y) var(--s360-table-toolbar-padding-x);
  border: var(--s360-table-border-width) solid var(--s360-color-border-muted);
  border-radius: var(--s360-table-radius);
  background: var(--s360-table-toolbar-bg);
}

.s360-table-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s360-table-meta-gap-y) var(--s360-table-meta-gap-x);
  color: var(--s360-color-text-secondary);
  font-size: var(--s360-font-size-sm);
}

.s360-table-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s360-table-actions-gap);
}


/* Phase 9 — legacy bridge defaults (low-specificity, rollback-friendly) */
:where(.s360-ui-card,.s360-ui-section-card,.s360-ui-card--summary,.s360-ui-stat-card) {
  background: var(--s360-color-surface-raised);
  border: 1px solid var(--s360-color-border);
  border-radius: var(--s360-radius-2xl);
  box-shadow: var(--s360-shadow-sm);
}

:where(.s360-ui-grid,.s360-ui-grid--summary,.s360-ui-grid--wide) {
  display: grid;
  gap: var(--s360-layout-grid-gap);
}

:where(.school360-inline-actions) {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s360-component-toolbar-gap);
}

:where(.s360-empty-state) {
  padding: var(--s360-component-empty-state-padding);
  border-radius: var(--s360-radius-xl);
  border: 1px dashed var(--s360-color-border-muted);
  background: var(--s360-color-bg-subtle);
  color: var(--s360-color-text-secondary);
}

:where(.s360-muted) {
  color: var(--s360-color-text-tertiary);
}
