/* Kairableu brand theme — values from tailwind.config.js */
:root {
  --brand-primary: #2b71e1;
  --brand-accent: #70b5fa;
  --brand-warm: #bfdbfe;
  --brand-black: #060606;
  --brand-card: #0d0d0d;
  --brand-border: #1a1a1a;
  --brand-muted: #444444;
  --brand-white: #ffffff;
  --brand-radius-sm: 12px;
  --brand-radius-md: 18px;
  --brand-radius-lg: 28px;
  --brand-radius-pill: 100px;
  --brand-glow: 0 8px 28px rgba(43, 113, 225, 0.4);
  --brand-tight: -0.05em;
  --brand-wide: 0.15em;
}
.font-display,
.font-body {
  font-family: 'Roboto', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.font-mono {
  font-family: "DM Mono", monospace;
}
.font-black {
  font-weight: 900;
}
.font-extrabold {
  font-weight: 800;
}
.tracking-brand-tight {
  letter-spacing: var(--brand-tight);
}
.tracking-brand-wide {
  letter-spacing: var(--brand-wide);
}

.bg-brand-black {
  background-color: var(--brand-black);
}
/* Light theme: cards and content areas are white */
.bg-brand-card {
  background-color: #ffffff;
  border-color: #e5e7eb;
}
.bg-brand-primary {
  background-color: var(--brand-primary);
}
.bg-brand-primary-gradient {
  background-color: #ffffff;
  background-image: linear-gradient(135deg, #eff6ff 0%, #ffffff 70%);
}
.bg-brand-accent {
  background-color: var(--brand-accent);
}
.border-brand-border {
  border-color: #e5e7eb;
}
.bg-brand-border {
  background-color: #e5e7eb;
}
.bg-brand-muted {
  background-color: #d1d5db;
}
.hover\:bg-brand-muted:hover {
  background-color: #d1d5db;
}
.hover\:bg-brand-border:hover {
  background-color: #e5e7eb;
}
/* Nav dropdown keeps dark border */
.app-top-nav .border-brand-border {
  border-color: #374151;
}
.text-brand-white {
  color: var(--brand-white);
}
.text-brand-muted {
  color: var(--brand-muted);
}
.text-brand-primary {
  color: var(--brand-primary);
}
.text-black {
  color: #000;
}

.rounded-brand-sm {
  border-radius: var(--brand-radius-sm);
}
.rounded-brand-md {
  border-radius: var(--brand-radius-md);
}
.rounded-brand-lg {
  border-radius: var(--brand-radius-lg);
}
.rounded-brand-pill {
  border-radius: var(--brand-radius-pill);
}
.shadow-brand-glow {
  box-shadow: var(--brand-glow);
}
.shadow-brand-subtle {
  box-shadow: 0 2px 8px rgba(43, 113, 225, 0.1);
}

.hover\:bg-brand-accent:hover {
  background-color: var(--brand-accent);
}
.nav-active {
  background-color: rgba(0, 0, 0, 0.25) !important;
  color: #fff !important;
}
.focus\:ring-brand-primary:focus {
  --tw-ring-color: rgba(43, 113, 225, 0.5);
}

/* Form controls: white background, black text (all inputs app-wide) */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
textarea,
select {
  background-color: #ffffff !important;
  color: #000000 !important;
  border: 1px solid #d1d5db;
  border-radius: 0 !important;
  padding: 0.5rem 0.75rem;
  font-size: 0.95rem;
}
input::placeholder,
textarea::placeholder {
  color: #6b7280;
}
input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--brand-primary);
  box-shadow: 0 0 0 3px rgba(43, 113, 225, 0.2);
}
/* Select option text stays black in dropdown */
select option {
  background-color: #ffffff;
  color: #000000;
}

/* Tables on light cards */
.bg-brand-card table thead tr {
  background-color: #f9fafb;
}
.bg-brand-card table th {
  color: #374151;
}
.bg-brand-card table td {
  color: #111827;
  border-color: #e5e7eb;
}
.bg-brand-card table tbody tr {
  border-color: #e5e7eb;
}
.bg-brand-card .text-brand-white {
  color: #111827;
}
.bg-brand-card .text-brand-muted {
  color: #6b7280;
}
.bg-brand-card .text-gray-500 {
  color: #6b7280;
}
.bg-brand-card .text-gray-600 {
  color: #374151;
}
.bg-brand-card .text-gray-700 {
  color: #111827;
}

/* Status badges (light theme) */
.badge-approved {
  background: #d1fae5;
  color: #065f46;
}
.badge-rejected {
  background: #fee2e2;
  color: #991b1b;
}
.badge-pending {
  background: #fef3c7;
  color: #92400e;
}

/* Small "dashboard card" style count badge (for table headers) */
.ka-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 3px 8px;
  border-radius: 999px;
  font-family: "DM Mono", monospace;
  font-size: 10px;
  letter-spacing: 1px;
  font-weight: 700;
  background: rgba(43, 113, 225, 0.09);
  border: 1px solid rgba(43, 113, 225, 0.18);
  color: #2b71e1;
  line-height: 1.1;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* Templates top note – always visible blue info box */
.templates-note {
  background-color: #eff6ff !important;
  border: 1px solid #bfdbfe !important;
  color: #1e40af !important;
}

/*
 * Create/edit template: 60% form (left) / 40% credit rates (right).
 * Tailwind v2 CDN has no arbitrary grid utilities (e.g. grid-cols-[3fr_2fr]).
 */
.template-form-split-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  align-items: start;
}
@media (min-width: 768px) {
  .template-form-split-layout {
    grid-template-columns: 3fr 2fr;
    gap: 2rem;
  }
}

/*
 * App modals: backdrop must fill the viewport. Padding belongs only on the centering shell.
 * When overlays live inside <main>, some browsers still tie fixed layout to ancestors — we
 * also reparent these nodes to document.body from layouts/app.php (see script there).
 */
.app-modal-overlay {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
  margin: 0 !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.22s ease,
    visibility 0.22s ease;
}
.app-modal-overlay.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
#templatesModal.app-modal-overlay {
  z-index: 1040;
}
#templateFormModal.app-modal-overlay,
#templateViewModal.app-modal-overlay {
  z-index: 1050;
}
#addCreditModal.app-modal-overlay {
  z-index: 1060;
}
.app-modal-overlay__backdrop {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  background: rgba(0, 0, 0, 0.6);
}
.app-modal-overlay__shell {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  box-sizing: border-box;
  pointer-events: none;
}
.app-modal-overlay__panel {
  pointer-events: auto;
  width: 100%;
  transform: scale(0.96) translateY(0.75rem);
  transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
}
.app-modal-overlay.is-open .app-modal-overlay__panel {
  transform: scale(1) translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .app-modal-overlay,
  .app-modal-overlay__panel {
    transition-duration: 0.01ms !important;
  }
}
