/*!
 * Reali Premium Theme for Bootstrap 5
 * Modern Bootstrap CSS theme for Razor Pages
 * Copyright 2024 Reali Premium
 */

/* Import Bootstrap Icons */
@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css");

/* Import Google Fonts - Inter for modern look */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");

/* =======================================================
   BOOTSTRAP CUSTOM VARIABLES (Reali Premium Brand)
   Override Bootstrap's default variables with Reali colors
   ======================================================= */

:root {
  /* Reali Premium Brand Colors */
  --rp-navy: #121d36;
  --rp-navy-2: #213048;
  --rp-primary: #2e74cb;
  --rp-primary-2: #2d60a4;
  --rp-primary-100: #acc3e8;
  
  /* Bootstrap color overrides */
  --bs-primary: #2e74cb;
  --bs-primary-rgb: 46, 116, 203;
  --bs-secondary: #213048;
  --bs-secondary-rgb: 33, 48, 72;
  --bs-success: #16a34a;
  --bs-success-rgb: 22, 163, 74;
  --bs-warning: #f59e0b;
  --bs-warning-rgb: 245, 158, 11;
  --bs-danger: #ef4444;
  --bs-danger-rgb: 239, 68, 68;
  --bs-info: #3b82f6;
  --bs-info-rgb: 59, 130, 246;
  
  /* Light mode surfaces */
  --bs-body-bg: #f6f8fc;
  --bs-body-bg-rgb: 246, 248, 252;
  --bs-body-color: #0f172a;
  --bs-body-color-rgb: 15, 23, 42;
  
  /* Card and surfaces */
  --rp-card-bg: #ffffff;
  --rp-surface-2: #f2f5fb;
  --bs-border-color: #e5eaf3;
  --bs-border-color-rgb: 229, 234, 243;
  
  /* Text colors */
  --rp-text-muted: #64748b;
  --bs-secondary-color: #64748b;
  
  /* Radius - Modern rounded corners */
  --bs-border-radius: 0.75rem;
  --bs-border-radius-sm: 0.5rem;
  --bs-border-radius-lg: 1rem;
  --bs-border-radius-xl: 1.25rem;
  
  /* Shadows - Elevated and modern */
  --bs-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  --bs-box-shadow-sm: 0 6px 18px rgba(15, 23, 42, 0.06);
  --bs-box-shadow-lg: 0 16px 34px rgba(15, 23, 42, 0.12);
  
  /* Font family */
  --bs-font-sans-serif: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --bs-body-font-family: var(--bs-font-sans-serif);
  
  /* Font weights */
  --bs-body-font-weight: 400;
  --bs-headings-font-weight: 600;
}

/* =======================================================
   DARK MODE SUPPORT
   ======================================================= */

[data-bs-theme="dark"] {
  /* Dark mode surfaces */
  --bs-body-bg: #020617;
  --bs-body-bg-rgb: 2, 6, 23;
  --bs-body-color: #e2e8f0;
  --bs-body-color-rgb: 226, 232, 240;
  
  /* Card and surfaces in dark mode */
  --rp-card-bg: #0b1220;
  --rp-surface-2: #101828;
  --bs-border-color: #1e293b;
  --bs-border-color-rgb: 30, 41, 59;
  
  /* Text colors in dark mode */
  --rp-text-muted: #94a3b8;
  --bs-secondary-color: #94a3b8;
  
  /* Adjust shadows for dark mode */
  --bs-box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
  --bs-box-shadow-sm: 0 6px 18px rgba(0, 0, 0, 0.2);
  --bs-box-shadow-lg: 0 16px 34px rgba(0, 0, 0, 0.45);
}

/* =======================================================
   GLOBAL STYLES
   ======================================================= */

body {
  font-family: var(--bs-font-sans-serif);
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  font-weight: var(--bs-body-font-weight);
  line-height: 1.6;
}

/* =======================================================
   TYPOGRAPHY ENHANCEMENTS
   ======================================================= */

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-weight: var(--bs-headings-font-weight);
  color: var(--bs-body-color);
}

h1, .h1 { font-size: 2.5rem; }
h2, .h2 { font-size: 2rem; }
h3, .h3 { font-size: 1.75rem; }
h4, .h4 { font-size: 1.5rem; }
h5, .h5 { font-size: 1.25rem; }
h6, .h6 { font-size: 1rem; }

.text-muted {
  color: var(--rp-text-muted) !important;
}

/* =======================================================
   CARD ENHANCEMENTS
   ======================================================= */

.card {
  background-color: var(--rp-card-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  box-shadow: var(--bs-box-shadow-sm);
  transition: all 0.3s ease;
}

.card:hover {
  box-shadow: var(--bs-box-shadow);
  transform: translateY(-2px);
}

.card-header {
  background-color: transparent;
  border-bottom: 1px solid var(--bs-border-color);
  padding: 1.25rem 1.5rem;
  font-weight: 600;
}

.card-body {
  padding: 1.5rem;
}

.card-footer {
  background-color: var(--rp-surface-2);
  border-top: 1px solid var(--bs-border-color);
  padding: 1rem 1.5rem;
}

/* =======================================================
   BUTTON ENHANCEMENTS
   ======================================================= */

.btn {
  border-radius: var(--bs-border-radius-sm);
  font-weight: 500;
  padding: 0.625rem 1.25rem;
  transition: all 0.2s ease;
  border: none;
}

.btn-primary {
  background-color: var(--bs-primary);
  color: white;
}

.btn-primary:hover {
  background-color: var(--rp-primary-2);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(46, 116, 203, 0.3);
}

.btn-lg {
  padding: 0.875rem 1.75rem;
  font-size: 1.125rem;
  border-radius: var(--bs-border-radius);
}

.btn-sm {
  padding: 0.375rem 0.875rem;
  font-size: 0.875rem;
}

/* =======================================================
   FORM ENHANCEMENTS
   ======================================================= */

.form-control,
.form-select {
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius-sm);
  padding: 0.625rem 0.875rem;
  background-color: var(--rp-card-bg);
  color: var(--bs-body-color);
  transition: all 0.2s ease;
}

.form-control:focus,
.form-select:focus {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 0.25rem rgba(46, 116, 203, 0.15);
  background-color: var(--rp-card-bg);
}

.form-label {
  font-weight: 500;
  margin-bottom: 0.5rem;
  color: var(--bs-body-color);
}

/* =======================================================
   NAVBAR ENHANCEMENTS
   ======================================================= */

.navbar {
  background: linear-gradient(90deg, var(--rp-navy), var(--rp-navy-2));
  padding: 1rem 0;
  box-shadow: var(--bs-box-shadow-sm);
}

.navbar-brand {
  font-weight: 700;
  font-size: 1.5rem;
  color: white !important;
}

.navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.85) !important;
  font-weight: 500;
  padding: 0.5rem 1rem;
  transition: all 0.2s ease;
}

.navbar-nav .nav-link:hover {
  color: white !important;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: var(--bs-border-radius-sm);
}

.navbar-nav .nav-link.active {
  color: white !important;
  background-color: rgba(255, 255, 255, 0.15);
  border-radius: var(--bs-border-radius-sm);
}

/* =======================================================
   TABLE ENHANCEMENTS
   ======================================================= */

.table {
  color: var(--bs-body-color);
}

.table thead th {
  background-color: var(--rp-surface-2);
  border-bottom: 2px solid var(--bs-border-color);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  padding: 1rem;
}

.table tbody tr {
  border-bottom: 1px solid var(--bs-border-color);
  transition: background-color 0.2s ease;
}

.table tbody tr:hover {
  background-color: var(--rp-surface-2);
}

.table tbody td {
  padding: 1rem;
  vertical-align: middle;
}

/* =======================================================
   BADGE ENHANCEMENTS
   ======================================================= */

.badge {
  border-radius: var(--bs-border-radius-sm);
  padding: 0.375rem 0.75rem;
  font-weight: 500;
  font-size: 0.75rem;
}

/* =======================================================
   MODAL ENHANCEMENTS
   ======================================================= */

.modal-content {
  border: none;
  border-radius: var(--bs-border-radius-lg);
  box-shadow: var(--bs-box-shadow-lg);
  background-color: var(--rp-card-bg);
}

.modal-header {
  border-bottom: 1px solid var(--bs-border-color);
  padding: 1.5rem;
}

.modal-body {
  padding: 1.5rem;
}

.modal-footer {
  border-top: 1px solid var(--bs-border-color);
  padding: 1rem 1.5rem;
}

/* =======================================================
   ALERT ENHANCEMENTS
   ======================================================= */

.alert {
  border-radius: var(--bs-border-radius);
  border: none;
  padding: 1rem 1.25rem;
}

/* =======================================================
   BREADCRUMB ENHANCEMENTS
   ======================================================= */

.breadcrumb {
  background-color: transparent;
  padding: 0;
  margin-bottom: 1.5rem;
}

.breadcrumb-item + .breadcrumb-item::before {
  content: "›";
  font-size: 1.25rem;
  color: var(--rp-text-muted);
}

.breadcrumb-item a {
  color: var(--bs-primary);
  text-decoration: none;
}

.breadcrumb-item.active {
  color: var(--bs-body-color);
  font-weight: 500;
}

/* =======================================================
   PAGINATION ENHANCEMENTS
   ======================================================= */

.pagination {
  gap: 0.25rem;
}

.page-link {
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius-sm);
  color: var(--bs-body-color);
  background-color: var(--rp-card-bg);
  padding: 0.5rem 0.875rem;
  transition: all 0.2s ease;
}

.page-link:hover {
  background-color: var(--rp-surface-2);
  border-color: var(--bs-primary);
  color: var(--bs-primary);
}

.page-item.active .page-link {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
  color: white;
}

/* =======================================================
   DROPDOWN ENHANCEMENTS
   ======================================================= */

.dropdown-menu {
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  box-shadow: var(--bs-box-shadow-lg);
  background-color: var(--rp-card-bg);
  padding: 0.5rem;
}

.dropdown-item {
  border-radius: var(--bs-border-radius-sm);
  padding: 0.5rem 1rem;
  color: var(--bs-body-color);
  transition: background-color 0.2s ease;
}

.dropdown-item:hover {
  background-color: var(--rp-surface-2);
  color: var(--bs-primary);
}

.dropdown-divider {
  border-color: var(--bs-border-color);
  margin: 0.5rem 0;
}

/* =======================================================
   UTILITIES
   ======================================================= */

.shadow-reali {
  box-shadow: var(--bs-box-shadow) !important;
}

.shadow-reali-sm {
  box-shadow: var(--bs-box-shadow-sm) !important;
}

.shadow-reali-lg {
  box-shadow: var(--bs-box-shadow-lg) !important;
}

.rounded-reali {
  border-radius: var(--bs-border-radius) !important;
}

.rounded-reali-lg {
  border-radius: var(--bs-border-radius-lg) !important;
}

.bg-surface-2 {
  background-color: var(--rp-surface-2) !important;
}

/* =======================================================
   RESPONSIVE UTILITIES
   ======================================================= */

@media (max-width: 768px) {
  h1, .h1 { font-size: 2rem; }
  h2, .h2 { font-size: 1.75rem; }
  h3, .h3 { font-size: 1.5rem; }
  
  .card-body {
    padding: 1.25rem;
  }
}
