/* 
 * Academic Modernist Design System 
 * Font: Manrope (Headings), Inter (Body)
 */

:root {
  /* Colors */
  --surface: #f8f9ff;
  --surface-dim: #cbdbf5;
  --surface-bright: #f8f9ff;
  --surface-container-lowest: #ffffff;
  --surface-container-low: #eff4ff;
  --surface-container: #e5eeff;
  --surface-container-high: #dce9ff;
  --surface-container-highest: #d3e4fe;
  --on-surface: #0b1c30;
  --on-surface-variant: #45464d;
  --inverse-surface: #213145;
  --inverse-on-surface: #eaf1ff;
  --outline: #76777d;
  --outline-variant: #c6c6cd;
  --surface-tint: #565e74;
  --primary: #000000;
  --on-primary: #ffffff;
  --primary-container: #131b2e;
  --on-primary-container: #7c839b;
  --inverse-primary: #bec6e0;
  --secondary: #006a61;
  --on-secondary: #ffffff;
  --secondary-container: #86f2e4;
  --on-secondary-container: #006f66;
  --tertiary: #000000;
  --on-tertiary: #ffffff;
  --tertiary-container: #191c1e;
  --on-tertiary-container: #818486;
  --error: #ba1a1a;
  --on-error: #ffffff;
  --error-container: #ffdad6;
  --on-error-container: #93000a;
  --primary-fixed: #dae2fd;
  --primary-fixed-dim: #bec6e0;
  --on-primary-fixed: #131b2e;
  --on-primary-fixed-variant: #3f465c;
  --secondary-fixed: #89f5e7;
  --secondary-fixed-dim: #6bd8cb;
  --on-secondary-fixed: #00201d;
  --on-secondary-fixed-variant: #005049;
  --tertiary-fixed: #e0e3e5;
  --tertiary-fixed-dim: #c4c7c9;
  --on-tertiary-fixed: #191c1e;
  --on-tertiary-fixed-variant: #444749;
  --background: #f8f9ff;
  --on-background: #0b1c30;
  --surface-variant: #d3e4fe;

  /* Typography */
  --font-manrope: 'Manrope', sans-serif;
  --font-inter: 'Inter', sans-serif;

  /* Rounded / Shape */
  --rounded-sm: 0.25rem; /* 4px */
  --rounded-base: 0.5rem; /* 8px */
  --rounded-md: 0.75rem; /* 12px */
  --rounded-lg: 1rem; /* 16px */
  --rounded-xl: 1.5rem; /* 24px */
  --rounded-pill: 9999px;

  /* Spacing */
  --spacing-unit: 4px;
  --spacing-container-max: 1280px;
  --spacing-gutter: 24px;
  --spacing-margin-mobile: 16px;
  --spacing-margin-desktop: 40px;
  --spacing-stack-sm: 8px;
  --spacing-stack-md: 16px;
  --spacing-stack-lg: 32px;

  /* Shadows */
  --shadow-level-1: 0px 4px 20px rgba(15, 23, 42, 0.05);
  --shadow-level-2: 0px 10px 30px rgba(15, 23, 42, 0.1);

  /* Overriding existing theme properties to match this palette */
  --ot-primary: var(--primary);
  --ot-secondary: var(--secondary);
  --ot-primary-title: var(--on-surface);
  --ot-paragraph: var(--on-surface-variant);
  --ot-bg-body: var(--background);
}

/* Base Body Styles */
body {
  font-family: var(--font-inter) !important;
  background-color: var(--background) !important;
  color: var(--on-background) !important;
  line-height: 1.5 !important;
}

/* Typography Hierarchy */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6, .title {
  font-family: var(--font-manrope) !important;
  color: var(--on-surface) !important;
  letter-spacing: -0.01em;
}

h1 { font-size: 40px !important; font-weight: 700 !important; line-height: 48px !important; letter-spacing: -0.02em !important; }
h2 { font-size: 32px !important; font-weight: 600 !important; line-height: 40px !important; }
h3 { font-size: 24px !important; font-weight: 600 !important; line-height: 32px !important; }
h4 { font-size: 20px !important; font-weight: 600 !important; line-height: 28px !important; }

p {
  font-family: var(--font-inter) !important;
  font-size: 16px; 
  font-weight: 400;
  line-height: 24px;
  color: var(--on-surface-variant) !important;
}
.text-body-lg { font-size: 18px !important; line-height: 28px !important; }
.text-body-md { font-size: 16px !important; line-height: 24px !important; }
.text-body-sm { font-size: 14px !important; line-height: 20px !important; }

@media (max-width: 768px) {
  h1 { font-size: 32px !important; line-height: 40px !important; }
  h2 { font-size: 28px !important; line-height: 36px !important; }
}

/* Shadows and Surfaces */
.surface-level-0 {
  background-color: var(--background);
}
.surface-level-1 {
  background-color: var(--surface-container-lowest); /* pure white */
  box-shadow: var(--shadow-level-1);
}
.surface-level-2 {
  background-color: var(--surface-container-lowest);
  box-shadow: var(--shadow-level-2);
}

/* Components Standardization */
/* Containers & Cards */
.card, .custom-category-card, .view-wrapper .single-courses {
  border-radius: var(--rounded-lg) !important;
  box-shadow: var(--shadow-level-1) !important;
  border: none !important;
  background-color: var(--surface-container-lowest) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover, .custom-category-card:hover, .view-wrapper .single-courses:hover {
    box-shadow: var(--shadow-level-2) !important;
}

/* Buttons */
.btn {
  font-family: var(--font-inter) !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  border-radius: var(--rounded-base) !important;
  padding: 12px 24px !important;
  transition: all 0.2s ease;
}

.btn-primary, .btn-primary-fill, .theme-btn, .btn-theme {
  background-color: var(--secondary) !important;
  color: var(--on-secondary) !important;
  border: none !important;
}
.btn-primary:hover, .btn-primary-fill:hover, .theme-btn:hover, .btn-theme:hover {
  background-color: var(--on-secondary-container) !important;
}

.btn-secondary, .btn-outline {
  background-color: transparent !important;
  color: var(--primary) !important;
  border: 1px solid var(--primary) !important;
}

.btn-ghost {
  background-color: transparent !important;
  color: var(--primary) !important;
  border: none !important;
}
.btn-ghost:hover {
  background-color: var(--surface-container) !important;
}

/* Outlines for inputs */
.form-control, .form-select, input, select, textarea {
  border: 1px solid var(--outline-variant) !important;
  border-radius: var(--rounded-base) !important;
  box-shadow: none !important;
}
.form-control:focus, .form-select:focus, input:focus, textarea:focus {
  border-color: var(--primary) !important;
  outline: none !important;
}

/* Pills */
.badge, .pill, .status-badge {
  border-radius: var(--rounded-pill) !important;
}

/* --- GLOBAL THEME INTERCEPTIONS --- */

/* Typography Utilities Override */
.font-400, .font-500 { font-weight: 400 !important; }
.font-600 { font-weight: 600 !important; }
.font-700, .font-800 { font-weight: 700 !important; }

/* Force Inter on legacy texts, explicitly excluding icons */
.text-12:not(i), .text-13:not(i), .text-14:not(i), .text-15:not(i), .text-16:not(i), .text-18:not(i), .text-color:not(i) {
  font-family: var(--font-inter) !important;
}

/* Force Manrope on legacy headings */
.section-tittle h2, .section-tittle h3, .section-tittle h4, .course-title, .title {
  font-family: var(--font-manrope) !important;
}

/* Base Sections */
.section-padding, .main-content, .bg-alice-blue {
  background-color: var(--background) !important;
}

/* Aggressive Card Overrides */
.single-courses, .instructor-card, .blog-card, .white-bg, .checkout-section .card, .cart-section .card, .profile-card, .dashboard-card {
  border-radius: var(--rounded-lg) !important;
  box-shadow: var(--shadow-level-1) !important;
  border: none !important;
  background-color: var(--surface-container-lowest) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.single-courses:hover, .instructor-card:hover, .blog-card:hover {
  box-shadow: var(--shadow-level-2) !important;
  transform: translateY(-4px) !important;
}

/* Aggressive Button Overrides */
.ot-btn, .submit-btn, .btn-primary-fill, .btn-theme, .btn-main {
  background-color: var(--secondary) !important;
  color: var(--on-secondary) !important;
  border: none !important;
  font-family: var(--font-inter) !important;
  font-weight: 600 !important;
  border-radius: var(--rounded-base) !important;
  padding: 12px 24px !important;
}
.ot-btn:hover, .submit-btn:hover, .btn-primary-fill:hover, .btn-theme:hover, .btn-main:hover {
  background-color: var(--on-secondary-container) !important;
  color: var(--on-secondary) !important;
}

.btn-primary-outline, .btn-outline {
  background-color: transparent !important;
  color: var(--primary) !important;
  border: 1px solid var(--primary) !important;
  border-radius: var(--rounded-base) !important;
}

/* Badges & Pills */
.category-tag, .status, .badge-success, .badge-warning, .badge-danger, .badge-primary {
  border-radius: var(--rounded-pill) !important;
  font-family: var(--font-inter) !important;
  font-weight: 500 !important;
  padding: 4px 12px !important;
}

/* Modals & Dropdowns (Level 2) */
.dropdown-menu, .modal-content {
  border-radius: var(--rounded-lg) !important;
  box-shadow: var(--shadow-level-2) !important;
  border: 1px solid var(--surface-container-high) !important;
}

/* --- COMPONENT REFINEMENTS (Header & Course Card) --- */

/* Header Search Bar */
.header-search.header-search-pill .input-form {
  border: none !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  background: transparent !important;
}

.header-search:not(.header-search-pill) .input-form {
  border: 1px solid var(--outline-variant) !important;
  border-radius: var(--rounded-base) !important;
  box-shadow: none !important;
  background: var(--surface) !important;
}

.header-search .input-form input {
  border: none !important;
  background: transparent !important;
  color: var(--on-surface) !important;
}

.header-search.header-search-pill .input-form input {
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 999px !important;
  background: #ffffff !important;
}

/* Header Sticky Shadow */
.header-sticky.sticky {
  box-shadow: var(--shadow-level-1) !important;
  background: rgba(255, 255, 255, 0.95) !important;
  backdrop-filter: blur(10px);
}

/* Course Widget Refinement */
.course-widget {
  padding: 16px !important;
  display: flex;
  flex-direction: column;
  background: linear-gradient(135deg, #ffffff 0%, #ecfdf5 100%) !important; /* Soft Emerald Green Background */
  border: 1px solid #d1fae5 !important;
}
.course-widget .btn-primary-outline, .course-widget .btn-primary-fill, .course-widget .btn {
  background-color: #10b981 !important; /* Vibrant Emerald Green */
  color: #ffffff !important;
  border: none !important;
}
.course-widget .btn-primary-outline:hover, .course-widget .btn-primary-fill:hover, .course-widget .btn:hover {
  background-color: #059669 !important;
}
.course-widget-img {
  border-radius: var(--rounded-md) !important;
  overflow: hidden;
  margin-bottom: 16px;
}
.course-widget-info-title .title {
  font-size: 18px !important;
  line-height: 1.4 !important;
  margin-top: 8px !important;
  font-weight: 700 !important;
}
.course-widget-author {
  padding-top: 16px;
  border-top: 1px solid var(--surface-container-high);
  margin-top: 16px;
}
.course-widget .widget-footer {
  padding-top: 16px;
  border-top: 1px solid var(--surface-container-high);
  margin-top: 16px;
}
.course-badge {
  top: 12px !important;
  left: 12px !important;
  border-radius: var(--rounded-pill) !important;
  padding: 6px 12px !important;
  font-family: var(--font-inter) !important;
}
.course-widget-info_rating h5 {
  font-family: var(--font-inter) !important;
}

/* Header Links Hover State */
.main-menu nav ul.listing li.single-list a.single,
.main-menu nav ul.listing li a {
  border-radius: var(--rounded-base) !important;
  padding: 8px 16px !important;
  transition: all 0.2s ease !important;
  color: var(--on-surface) !important;
}

/* Header Links Hover State */
.main-menu nav ul.listing li.single-list a.single:hover,
.main-menu nav ul.listing li:hover > a {
  background-color: var(--surface-container-high) !important;
  color: var(--secondary) !important;
}

/* Header Links Active State */
.main-menu nav ul.listing li.single-list.active a.single,
.main-menu nav ul.listing li.active > a,
.main-menu nav ul.listing li > a.active {
  background-color: transparent !important;
  color: var(--secondary) !important;
}

/* ==========================================================================
   COURSES CATALOG PAGE REDESIGN
   ========================================================================== */

/* 1. Breadcrumb Redesign (Pristine White & Premium Navy Glow) */
.ot-bradcam-area {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%) !important; /* Rich Dark Navy */
  padding: 30px 0 !important;
  position: relative !important;
  overflow: hidden !important;
}

.ot-bradcam-area::after {
  content: '' !important;
  position: absolute !important;
  top: -50% !important;
  right: -20% !important;
  width: 400px !important;
  height: 400px !important;
  background: radial-gradient(circle, rgba(16, 185, 129, 0.1) 0%, transparent 75%) !important; /* Soft Emerald highlight */
  pointer-events: none !important;
}

.ot-bradcam-area .title,
.ot-bradcam-area h3.title,
.ot-bradcam-area .bradcam-text h3 {
  color: #ffffff !important;
  font-family: var(--font-manrope) !important;
  font-weight: 800 !important;
  font-size: 32px !important;
  letter-spacing: -0.03em !important;
  margin: 0 0 8px 0 !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

.ot-bradcam-area .bradcamb-links,
.ot-bradcam-area .bradcamb-links a,
.ot-bradcam-area .bradcamb-links span {
  color: rgba(255, 255, 255, 0.85) !important;
  font-family: var(--font-inter) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  transition: all 0.2s ease !important;
}

.ot-bradcam-area .bradcamb-links a:hover {
  color: #86f2e4 !important; /* Glow on hover */
  text-decoration: none !important;
}

.ot-bradcam-area .bradcamb-links a:not(:first-child)::before {
  color: rgba(255, 255, 255, 0.4) !important;
}

/* 2. Subcategory Cards (Center-aligned, Rounded 16px, Modern Ambient Glow) */
.ot-filter-course.section-padding2 {
  padding-top: 30px !important; /* Significantly reduce top padding to pull subcategories up */
  margin-top: 0 !important;
}

.ot-subcategory-cards {
  padding: 0 0 12px 0 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 16px !important;
  overflow-x: auto !important;
  scrollbar-width: none !important; /* Hide scrollbar Firefox */
}

.ot-subcategory-cards::-webkit-scrollbar {
  display: none !important; /* Hide scrollbar Chrome/Safari */
}

.ot-subcategory-card {
  width: 150px !important;
  background-color: var(--surface-container-lowest) !important;
  border: 1px solid var(--outline-variant) !important;
  border-radius: var(--rounded-lg) !important; /* 16px */
  padding: 16px !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: var(--shadow-level-1) !important;
  cursor: pointer !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.ot-subcategory-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-level-2) !important;
  border-color: #10b981 !important; /* Emerald color border on hover */
}

.ot-subcategory-card__thumb {
  width: 100% !important;
  height: 80px !important;
  border-radius: var(--rounded-md) !important; /* 12px */
  overflow: hidden !important;
  margin-bottom: 12px !important;
  background-color: var(--surface-container-low) !important;
  transition: transform 0.3s ease !important;
}

.ot-subcategory-card:hover .ot-subcategory-card__thumb {
  transform: scale(1.05) !important;
}

.ot-subcategory-card span {
  font-family: var(--font-manrope) !important;
  font-weight: 700 !important;
  color: var(--on-surface) !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
  text-align: center !important;
  transition: color 0.3s ease !important;
}

.ot-subcategory-card:hover span {
  color: #10b981 !important;
}

/* Active State for Subcategory Cards */
.ot-subcategory-card.is-active {
  background: linear-gradient(135deg, #ecfdf5 0%, #ffffff 100%) !important;
  border: 2px solid #10b981 !important; /* Solid emerald green active border */
  box-shadow: 0 10px 25px -5px rgba(16, 185, 129, 0.25) !important;
}

.ot-subcategory-card.is-active span {
  color: #047857 !important;
  font-weight: 800 !important;
}

/* 3. Sidebar Category Menu Redesign & Custom Checkboxes */
.sidebar-wrapper {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
}

.ot-sidebar {
  background-color: var(--surface-container-lowest) !important;
  border-radius: var(--rounded-lg) !important;
  box-shadow: var(--shadow-level-1) !important;
  padding: 20px !important;
  border: 1px solid var(--surface-container-high) !important;
}

.ot-sidebar .accordion-item {
  border: none !important;
  background: transparent !important;
  margin-bottom: 16px !important;
  border-bottom: 1px solid var(--surface-container-high) !important;
  border-radius: 0 !important;
  padding-bottom: 12px !important;
}

.ot-sidebar .accordion-item:last-child {
  border-bottom: none !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.ot-sidebar .accordion-button {
  background: transparent !important;
  color: var(--on-surface) !important;
  font-family: var(--font-manrope) !important;
  font-weight: 800 !important;
  font-size: 16px !important;
  padding: 12px 4px !important;
  box-shadow: none !important;
}

.ot-sidebar .accordion-button:not(.collapsed) {
  color: var(--secondary) !important;
}

/* Categories Section Sidebar Menu Style */
#collapseOne {
  background-color: transparent !important;
}

#collapseOne .ot-checkbox-dropdown-list {
  padding: 8px 0 !important;
  margin: 0 !important;
  list-style: none !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

#collapseOne .ot-checkbox-dropdown-list li {
  padding: 0 !important;
  margin: 0 !important;
}

#collapseOne .ot-checkbox-dropdown-list label {
  display: flex !important;
  align-items: center !important;
  padding: 10px 14px !important;
  border-radius: var(--rounded-base) !important; /* 8px */
  background-color: transparent !important;
  color: var(--on-surface-variant) !important;
  font-family: var(--font-inter) !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  cursor: pointer !important;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: relative !important;
  border-left: 3px solid transparent !important;
  margin-bottom: 0 !important;
  width: 100% !important;
}

/* Hide checkboxes/radios and checkmarks in the menu */
#collapseOne .ot-checkbox-dropdown-list label input.ot-checkbox,
#collapseOne .ot-checkbox-dropdown-list label .ot-checkmark {
  display: none !important;
}

/* Hover Category Menu Item */
#collapseOne .ot-checkbox-dropdown-list label:hover {
  background-color: var(--surface-container-low) !important;
  color: var(--secondary) !important;
  border-left-color: var(--surface-dim) !important;
  padding-left: 18px !important;
}

/* Active Category Menu Item */
#collapseOne .ot-checkbox-dropdown-list label:has(input:checked) {
  background-color: var(--surface-container-high) !important;
  color: var(--secondary) !important;
  font-weight: 700 !important;
  border-left-color: var(--secondary) !important;
  padding-left: 18px !important;
}

/* Drilldown back button */
#category-branch-back-to-root {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 12px !important;
  border-radius: var(--rounded-base) !important;
  background-color: var(--surface-container) !important;
  color: var(--on-surface) !important;
  font-family: var(--font-manrope) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  transition: all 0.2s ease !important;
  border: none !important;
  margin-left: 4px !important;
}

#category-branch-back-to-root:hover {
  background-color: var(--surface-container-high) !important;
  color: var(--secondary) !important;
}

#category-branch-parent-label,
#category-branch-sub-title {
  font-family: var(--font-manrope) !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  color: var(--on-surface) !important;
  margin: 12px 0 8px 14px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  opacity: 0.6 !important;
}

/* Sidebar Custom Checkboxes & Radios for other filter sections */
.ot-sidebar .ot-checkbox-dropdown-list li {
  margin-bottom: 4px !important;
}

.ot-sidebar .filter-options,
.ot-sidebar .filter-options-radio {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  color: var(--on-surface-variant) !important;
  font-family: var(--font-inter) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  position: relative !important;
  padding: 8px 12px 8px 36px !important;
  border-radius: var(--rounded-base) !important;
  transition: background-color 0.2s ease !important;
}

.ot-sidebar .filter-options:hover,
.ot-sidebar .filter-options-radio:hover {
  background-color: var(--surface-container-low) !important;
}

.ot-sidebar .filter-options input.ot-checkbox,
.ot-sidebar .filter-options-radio input.ot-checkbox {
  position: absolute !important;
  opacity: 0 !important;
  cursor: pointer !important;
  height: 0 !important;
  width: 0 !important;
}

.ot-sidebar .filter-options .ot-checkmark {
  position: absolute !important;
  top: 50% !important;
  left: 12px !important;
  transform: translateY(-50%) !important;
  height: 18px !important;
  width: 18px !important;
  background-color: var(--surface-container-lowest) !important;
  border: 1px solid var(--outline-variant) !important;
  border-radius: 4px !important;
  transition: all 0.2s ease !important;
}

.ot-sidebar .filter-options-radio .ot-checkmark {
  border-radius: 50% !important;
}

.ot-sidebar .filter-options:hover input ~ .ot-checkmark,
.ot-sidebar .filter-options-radio:hover input ~ .ot-checkmark {
  border-color: var(--secondary) !important;
}

.ot-sidebar .filter-options input:checked ~ .ot-checkmark,
.ot-sidebar .filter-options-radio input:checked ~ .ot-checkmark {
  background-color: var(--secondary) !important;
  border-color: var(--secondary) !important;
}

.ot-sidebar .filter-options .ot-checkmark::after {
  content: "" !important;
  position: absolute !important;
  display: none !important;
  left: 5px !important;
  top: 2px !important;
  width: 6px !important;
  height: 10px !important;
  border: solid white !important;
  border-width: 0 2px 2px 0 !important;
  transform: rotate(45deg) !important;
}

.ot-sidebar .filter-options-radio .ot-checkmark::after {
  content: "" !important;
  position: absolute !important;
  display: none !important;
  top: 5px !important;
  left: 5px !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: white !important;
}

.ot-sidebar .filter-options input:checked ~ .ot-checkmark::after,
.ot-sidebar .filter-options-radio input:checked ~ .ot-checkmark::after {
  display: block !important;
}

/* Choose Subject / Department Grid Styling */
.subject-card:hover {
  transform: translateY(-6px) !important;
  border-color: var(--secondary) !important;
  box-shadow: 0 12px 24px -10px rgba(0, 106, 97, 0.15), var(--shadow-level-2) !important;
}

.subject-card:hover .subject-card-icon-wrap {
  background-color: var(--secondary) !important;
  color: #ffffff !important;
  transform: rotate(6deg) scale(1.05) !important;
}

.subject-card:hover .subject-card-title {
  color: var(--secondary) !important;
}

.subject-card:hover .subject-explore-link {
  color: var(--secondary) !important;
}

.subject-card:hover .subject-explore-link i {
  transform: translateX(4px) !important;
}

/* Footer Heading Overrides */
footer h4.title,
.footer-caption .title {
  color: #ffffff !important;
}
