/*
  App Theme Layer
  - Uses CSS variables defined in Views/Shared/_Layout.cshtml
  - Works for light/dark mode
  - Keeps Bootstrap components consistent
*/

/* Improve native control theming */
:root{ color-scheme: light; }
html.dark-mode{ color-scheme: dark; }
body.dark-mode{ color-scheme: dark; }

body{
  --bs-body-bg: var(--bg-color);
  --bs-body-color: var(--text-color);
  --bs-border-color: var(--border-color);
  --bs-link-color: var(--primary-color);
  --bs-link-hover-color: color-mix(in srgb, var(--primary-color) 80%, var(--text-color));
  --app-control-background: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color));
  --app-control-inset-shadow: 2px -20px 20px 13px color-mix(in srgb, var(--surface-color) 72%, #e9dfdf) inset;
}

/* Typography */
html, body{
  font-family: var(--app-font-family, 'Tajawal', 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif);
}

/* Surfaces */
.card,
.modal-content,
.dropdown-menu,
.offcanvas,
.list-group{
  background-color: var(--surface-color) !important;
  color: var(--text-color) !important;
  border-color: var(--border-color) !important;
  border-radius: var(--radius-lg, 14px);
}

.card-header,
.card-footer{
  background-color: color-mix(in srgb, var(--surface-color) 92%, var(--hover-color)) !important;
  border-color: var(--border-color) !important;
}

/* Text helpers */
.text-muted{ color: var(--secondary-text) !important; }

/* Background helpers */
.bg-light{ background-color: var(--hover-color) !important; }
.bg-white{ background-color: var(--surface-color) !important; }

/* Forms */
.form-control,
.form-select,
.form-control:focus,
.form-select:focus,
.input-group-text{
  background-color: var(--app-control-background) !important;
  color: var(--text-color) !important;
  border-color: var(--border-color) !important;
  border-radius: 0 !important;
  box-shadow: var(--app-control-inset-shadow) !important;
}

.form-control::placeholder{ color: color-mix(in srgb, var(--secondary-text) 75%, transparent); }

.form-control:focus,
.form-select:focus{
  box-shadow:
    var(--app-control-inset-shadow),
    0 0 0 .2rem color-mix(in srgb, var(--primary-color) 22%, transparent) !important;
}

.form-check-input{
  border-color: var(--border-color) !important;
}

.form-check-input:checked{
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
}

input[type="checkbox"],
input[type="radio"]{ accent-color: var(--primary-color); }

/* Buttons */
.btn{
  border-radius: var(--radius-md, 12px);
}

.btn-primary{
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
}

.btn-primary:hover{
  background-color: color-mix(in srgb, var(--primary-color) 86%, #000) !important;
  border-color: color-mix(in srgb, var(--primary-color) 86%, #000) !important;
}

.btn-outline-primary{
  color: var(--primary-color) !important;
  border-color: color-mix(in srgb, var(--primary-color) 65%, var(--border-color)) !important;
}

.btn-outline-primary:hover{
  background-color: color-mix(in srgb, var(--primary-color) 14%, transparent) !important;
}

.btn-outline-secondary{
  color: var(--text-color) !important;
  border-color: var(--border-color) !important;
}

.btn-outline-secondary:hover{
  background-color: var(--hover-color) !important;
}

/* Tables */
.table{
  --bs-table-color: var(--text-color);
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--border-color);
}

.table thead th{
  color: var(--secondary-text);
}

.table-light{
  --bs-table-bg: var(--hover-color) !important;
  --bs-table-striped-bg: color-mix(in srgb, var(--hover-color) 80%, var(--surface-color));
  --bs-table-hover-bg: color-mix(in srgb, var(--hover-color) 70%, transparent);
}

.table-hover > tbody > tr:hover{
  background-color: color-mix(in srgb, var(--hover-color) 70%, transparent) !important;
}

/* Alerts */
.alert{
  border-radius: var(--radius-md, 12px);
  border-color: var(--border-color);
}

/* Badges */
.badge{ border-radius: 999px; }

/* Page wrappers (nice default spacing) */
.app-page{ padding-top: .5rem; }

.app-page-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin: .75rem 0 1rem;
}

.app-page-title{
  margin: 0;
  font-weight: 800;
}

/* HR quick polish */
.hr-filters .card{ border-style: dashed; }
