/**
 * Shared surface patterns built from design_tokens.css (no raw palette hex).
 */

/* ── Layout utilities (portal + public + auth) ───────────────── */
.te-narrow-card {
  max-width: 600px;
}

.te-form-actions-plain {
  border-top: none;
  margin-top: 0;
  padding-top: 0;
}

.te-select-auto-width {
  width: auto;
}

/* ── Topbar (portal-style standalone layout) ───────────────────── */
.topbar {
  background-color: var(--color-topbar-bg);
  border-bottom: 1px solid var(--color-border);
}

/* ── Search ────────────────────────────────────────────────────── */
.search-input {
  background-color: #000000;
  color: var(--color-text-on-dark);
  border: 1px solid transparent;
  border-radius: 20px;
}

.search-input::placeholder {
  color: rgba(255, 255, 255, 0.55);
}

.search-input:focus {
  outline: 2px solid color-mix(in srgb, var(--color-accent-strong) 55%, transparent);
  outline-offset: 1px;
}

/* ── Dashboard cards ───────────────────────────────────────────── */
.card-soft {
  background-color: var(--color-accent-soft);
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--color-accent-soft) 65%, var(--color-border));
}

.card-light {
  background-color: var(--color-accent-light);
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--color-accent-light) 70%, var(--color-border));
}

.card-strong {
  background-color: var(--color-accent-strong);
  color: var(--color-text-on-dark);
  border-radius: 12px;
  border: none;
}

.card-strong a {
  color: inherit;
  text-decoration: underline;
}

.card-default {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: 12px;
}

/* ── Status badges ─────────────────────────────────────────────── */
.badge-active {
  background-color: var(--color-accent-strong);
  color: var(--color-text-on-dark);
}

.badge-inactive {
  background-color: var(--color-secondary);
  color: var(--color-text-on-dark);
}

/* ── Layout ────────────────────────────────────────────────────── */
.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 20px;
  padding: 20px;
}

@media (max-width: 991.98px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 16px;
  }
}

/* ── Inline SVG charts (avoid stroke hex in templates) ─────────── */
svg.te-chart-sparkline {
  color: var(--color-chart-primary);
}

/* ── Payment method selection (tenant billing) ──────────────────── */
.payment-method-card {
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.payment-method-card:hover {
  border-color: var(--color-accent-strong) !important;
  box-shadow: 0 0 0 0.125rem color-mix(in srgb, var(--color-accent-strong) 18%, transparent);
}

.payment-method-card:has(input:checked) {
  border-color: var(--color-accent-strong) !important;
  box-shadow: 0 0 0 0.125rem color-mix(in srgb, var(--color-accent-strong) 28%, transparent);
  background-color: color-mix(in srgb, var(--color-accent-soft) 35%, var(--color-bg-card));
}
