/* Custom Power Pages Theme - Updated */
@import url("https://fonts.cdnfonts.com/css/sofia-pro?styles=17636,17637,17630,17640,17631,17641,17632,17633,17634,17635,17638,17639,17628,17629,17626,17627");

:root {
  --primary-color: #3D338C;
  --secondary-color: #575757;
  --accent-color1: #00A6A1;
  --accent-color2: #E91B63;
  --accent-color3: #F69D1E;
  --accent-color4: #FBDF00;
  --neutral-dark: #2B2B2B;
  --neutral-medium: #575757;
  --neutral-light: #D4D4D4;
  --neutral-lighter: #E7E7E7;
  --neutral-white: #FFFFFF;

  /* Box Shadow */
  --box-shadow: 0px 10px 15px -3px rgba(0, 0, 0, 0.1);

  /* Border Radius */
  --border-radius: 8px;
}

/* Typography */
body {
  font-family: "Sofia Pro", sans-serif, "Font Awesome 6 Free" !important;
  color: var(--neutral-dark);
}

.fw-light { font-weight: 300 !important; }
.fw-normal { font-weight: 400 !important; }
.fw-medium { font-weight: 500 !important; }
.fw-semibold { font-weight: 600 !important; }
.fw-bold { font-weight: 700 !important; }
.fw-bolder { font-weight: 800 !important; }

/* Custom Text Sizes */
.text-xl { font-size: 36px; line-height: 44px; }
.text-lg { font-size: 30px; line-height: 38px; }
.text-md { font-size: 24px; line-height: 32px; }
.text-sm { font-size: 20px; line-height: 28px; }
.text-xs { font-size: 18px; line-height: 26px; }
.text-xxs { font-size: 16px; line-height: 24px; }
.text-base { font-size: 16px; line-height: 24px; }

@media (max-width: 768px) {
  .text-xl { font-size: 28px; line-height: 36px; }
  .text-lg { font-size: 24px; line-height: 32px; }
  .text-md { font-size: 20px; line-height: 28px; }
  .text-sm { font-size: 18px; line-height: 26px; }
  .text-xs { font-size: 16px; line-height: 24px; }
  .text-xxs { font-size: 14px; line-height: 22px; }
}

/* ✅ Text Colors */
.text-primary {
  color: var(--primary-color) !important;
}
.text-secondary {
  color: var(--secondary-color) !important;
}
.text-muted {
  color: var(--neutral-medium) !important;
}
.text-light {
  color: var(--neutral-light) !important;
}
.text-white {
  color: var(--neutral-white) !important;
}

/* ✅ Buttons */
.btn-primary {
  background-color: var(--primary-color);
  color: var(--neutral-white);
  border-radius: var(--border-radius);
  box-shadow: var(--box-shadow);
  padding: 10px 20px;
  font-size: 16px;
  font-weight: 600;
  border: none;
}
.btn-primary:hover {
  background-color: var(--secondary-color);
}
.btn-primary:disabled {
  background-color: var(--neutral-light);
  color: var(--neutral-medium);
  box-shadow: none;
  cursor: not-allowed;
}

/* ✅ Outline Buttons */
.btn-outline-primary {
  background-color: transparent;
  color: var(--primary-color);
  border: 2px solid var(--primary-color);
  border-radius: var(--border-radius);
  padding: 10px 20px;
  font-size: 16px;
  font-weight: 600;
}
.btn-outline-primary:hover {
  background-color: var(--primary-color);
  color: var(--neutral-white);
}

/* ✅ Links */
a {
  color: var(--primary-color);
  text-decoration: underline;
  font-weight: 500;
}
a:hover {
  color: var(--secondary-color);
  text-decoration: none;
}

/* ✅ Cards */
.card {
  background-color: var(--neutral-white) !important;
  border-radius: var(--border-radius) !important;
  box-shadow: var(--box-shadow) !important;
  padding: 20px;
}

/* ✅ Navbar */
.navbar {
  background-color: var(--neutral-white);
  box-shadow: none !important;
}
.navbar a {
  color: var(--primary-color);
  font-weight: 500;
  text-decoration: none;
}
.navbar a:hover {
  color: var(--secondary-color);
  text-decoration: underline;
}

/* ✅ Form Controls */
.form-control {
  background-color: var(--neutral-white);
  color: var(--neutral-dark);
  border: 1px solid var(--neutral-light);
  border-radius: var(--border-radius);
}
.form-control:focus {
  border-color: var(--primary-color);
  box-shadow: var(--box-shadow);
}

/* ✅ Custom Select Styling */
.form-select {
  background-color: var(--neutral-white);
  color: var(--neutral-dark);
  border: 2px solid var(--neutral-light);
  border-radius: var(--border-radius);
  font-size: 16px;
  font-weight: 400;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.form-select:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(61, 51, 140, 0.3);
  outline: none;
}
.form-select:hover {
  border-color: var(--secondary-color);
  background-color: var(--neutral-lighter);
}
.form-select option {
  background-color: var(--neutral-white);
  color: var(--neutral-dark);
}
.form-select option:hover {
  background-color: var(--neutral-light);
}

/* ✅ Breadcrumbs */
.breadcrumb a {
  color: var(--primary-color);
  text-decoration: underline;
}
.breadcrumb a:hover {
  color: var(--secondary-color);
  text-decoration: none;
}

/* ✅ Table Styling */
.table-striped > tbody > tr:nth-of-type(odd) {
  background-color: var(--neutral-lighter);
}

/* ✅ Dropdowns */
.dropdown-menu {
  background-color: var(--neutral-white);
  box-shadow: var(--box-shadow);
}
.dropdown-menu a {
  color: var(--neutral-dark);
}
.dropdown-menu a:hover {
  background-color: var(--neutral-lighter);
  color: var(--primary-color);
}

/* ✅ Footer */
footer {
  background-color: var(--neutral-dark);
  color: var(--neutral-white);
  padding: 20px;
}

/* ✅ Badges */
.badge-primary {
  background-color: var(--primary-color);
  color: var(--neutral-white);
  font-weight: 600;
  padding: 6px 10px;
  border-radius: var(--border-radius);
}
.badge-secondary {
  background-color: var(--secondary-color);
  color: var(--neutral-white);
  font-weight: 600;
  padding: 6px 10px;
  border-radius: var(--border-radius);
}

.alert-danger {
  color: var(--bs-alert-color) !important; /* Bootstrap’s intended red, overriding as some weird behaviour is happening with this defaulting to black by bootstrap... */
  background-color: var(--bs-alert-bg) !important;
  border-color: var(--bs-alert-border-color) !important;
}

/* ✅ Custom Checkboxes */
.form-check-input {
  width: 1.25rem;
  height: 1.25rem;
  background-color: var(--neutral-white);
  border: 2px solid var(--neutral-light);
  border-radius: 4px; /* Adjust for rounder or square edges */
  transition: all 0.2s ease-in-out;
}

.form-check-input:checked {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}

.form-check-input:focus {
  box-shadow: 0 0 0 3px rgba(61, 51, 140, 0.3);
  outline: none;
}

/* ✅ Disabled Checkbox */
.form-check-input:disabled {
  background-color: var(--neutral-light);
  border-color: var(--neutral-medium);
  cursor: not-allowed;
  opacity: 0.6;
}

.disabled{
  background-color: var(--neutral-light) !important;
  border-color: var(--neutral-light) !important;
  color: var(--neutral-medium) !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}
