/* Custom styles for this website */

/* ============================================
   Bootstrap CSS Variables Override - Logo Colors
   ============================================ */

/* Light Mode Bootstrap Overrides */
:root,
body.theme-light,
html:not([data-theme="dark"]) {
  --bs-primary: #485F7C;
  --bs-primary-rgb: 72, 95, 124;
  --bs-secondary: #5BA3C5;
  --bs-secondary-rgb: 91, 163, 197;
  --bs-success: #7ED8C3;
  --bs-success-rgb: 126, 216, 195;
  --bs-info: #5BA3C5;
  --bs-info-rgb: 91, 163, 197;
  --bs-link-color: #485F7C;
  --bs-link-hover-color: #364759;
  --bs-primary-border-subtle: rgba(72, 95, 124, 0.3);
  --bs-primary-bg-subtle: rgba(72, 95, 124, 0.1);
  --bs-primary-text-emphasis: #364759;
}

/* Dark Mode Bootstrap Overrides */
body.theme-dark,
[data-theme="dark"] {
  --bs-primary: #5BA3C5;
  --bs-primary-rgb: 91, 163, 197;
  --bs-secondary: #7ED8C3;
  --bs-secondary-rgb: 126, 216, 195;
  --bs-success: #9FE7D6;
  --bs-success-rgb: 159, 231, 214;
  --bs-info: #5BA3C5;
  --bs-info-rgb: 91, 163, 197;
  --bs-link-color: #5BA3C5;
  --bs-link-hover-color: #7ED8C3;
  --bs-primary-border-subtle: rgba(91, 163, 197, 0.3);
  --bs-primary-bg-subtle: rgba(91, 163, 197, 0.15);
  --bs-primary-text-emphasis: #7ED8C3;
}

/* ============================================
   Component-Specific Color Overrides
   ============================================ */

/* Buttons - Light Mode */
:root,
body.theme-light,
html:not([data-theme="dark"]) {
  .btn-primary {
    --bs-btn-bg: #485F7C;
    --bs-btn-border-color: #485F7C;
    --bs-btn-hover-bg: #364759;
    --bs-btn-hover-border-color: #364759;
    --bs-btn-active-bg: #2D3A47;
    --bs-btn-active-border-color: #2D3A47;
    --bs-btn-disabled-bg: #485F7C;
    --bs-btn-disabled-border-color: #485F7C;
  }
  
  .btn-outline-primary {
    --bs-btn-color: #485F7C;
    --bs-btn-border-color: #485F7C;
    --bs-btn-hover-bg: #485F7C;
    --bs-btn-hover-border-color: #485F7C;
    --bs-btn-active-bg: #364759;
    --bs-btn-active-border-color: #364759;
  }
  
  .btn-secondary {
    --bs-btn-bg: #5BA3C5;
    --bs-btn-border-color: #5BA3C5;
    --bs-btn-hover-bg: #4A8AA8;
    --bs-btn-hover-border-color: #4A8AA8;
    --bs-btn-active-bg: #3F7A91;
    --bs-btn-active-border-color: #3F7A91;
  }
}

/* Buttons - Dark Mode */
body.theme-dark,
[data-theme="dark"] {
  .btn-primary {
    --bs-btn-bg: #5BA3C5;
    --bs-btn-border-color: #5BA3C5;
    --bs-btn-hover-bg: #7ED8C3;
    --bs-btn-hover-border-color: #7ED8C3;
    --bs-btn-active-bg: #9FE7D6;
    --bs-btn-active-border-color: #9FE7D6;
    --bs-btn-disabled-bg: #5BA3C5;
    --bs-btn-disabled-border-color: #5BA3C5;
  }
  
  .btn-outline-primary {
    --bs-btn-color: #5BA3C5;
    --bs-btn-border-color: #5BA3C5;
    --bs-btn-hover-bg: #5BA3C5;
    --bs-btn-hover-border-color: #5BA3C5;
    --bs-btn-active-bg: #7ED8C3;
    --bs-btn-active-border-color: #7ED8C3;
  }
  
  .btn-secondary {
    --bs-btn-bg: #7ED8C3;
    --bs-btn-border-color: #7ED8C3;
    --bs-btn-hover-bg: #9FE7D6;
    --bs-btn-hover-border-color: #9FE7D6;
    --bs-btn-active-bg: #B0EFE0;
    --bs-btn-active-border-color: #B0EFE0;
  }
}

/* Form Controls Focus */
.form-control:focus,
.form-select:focus {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Badges */
.badge.bg-primary {
  background-color: var(--bs-primary) !important;
}

.badge.bg-secondary {
  background-color: var(--bs-secondary) !important;
}

/* Alerts */
.alert-primary {
  --bs-alert-bg: rgba(var(--bs-primary-rgb), 0.1);
  --bs-alert-border-color: rgba(var(--bs-primary-rgb), 0.3);
  --bs-alert-color: var(--bs-primary);
}

/* Progress Bars */
.progress-bar {
  background-color: var(--bs-primary);
}

/* Spinners */
.spinner-border.text-primary,
.spinner-grow.text-primary {
  color: var(--bs-primary) !important;
}

/* Navigation Pills & Tabs */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  background-color: var(--bs-primary);
}

.nav-tabs .nav-link:focus,
.nav-tabs .nav-link:hover {
  border-color: rgba(var(--bs-primary-rgb), 0.3);
}

.nav-tabs .nav-link.active {
  border-color: var(--bs-primary);
  color: var(--bs-primary);
}

/* Pagination */
.page-link {
  color: var(--bs-primary);
}

.page-link:hover {
  color: var(--bs-link-hover-color);
  background-color: rgba(var(--bs-primary-rgb), 0.1);
  border-color: var(--bs-primary);
}

.page-item.active .page-link {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
}

/* List Groups */
.list-group-item-primary {
  --bs-list-group-color: var(--bs-primary);
  --bs-list-group-bg: rgba(var(--bs-primary-rgb), 0.1);
  --bs-list-group-border-color: rgba(var(--bs-primary-rgb), 0.3);
}

.list-group-item-action:hover,
.list-group-item-action:focus {
  background-color: rgba(var(--bs-primary-rgb), 0.05);
}

/* ============================================
   Navigation & Hero Sections - Logo Colors
   ============================================ */

/* Navigation Active States - Light Mode */
:root .navigation-menu > li.active > a,
:root .navigation-menu > li:hover > a,
body.theme-light .navigation-menu > li.active > a,
body.theme-light .navigation-menu > li:hover > a,
html:not([data-theme="dark"]) .navigation-menu > li.active > a,
html:not([data-theme="dark"]) .navigation-menu > li:hover > a {
  color: #485F7C !important;
}

/* Navigation Active States - Dark Mode */
body.theme-dark .navigation-menu > li.active > a,
body.theme-dark .navigation-menu > li:hover > a,
[data-theme="dark"] .navigation-menu > li.active > a,
[data-theme="dark"] .navigation-menu > li:hover > a {
  color: #5BA3C5 !important;
}

/* Submenu Active Links - Light Mode */
:root .navigation-menu .submenu li.active > a,
body.theme-light .navigation-menu .submenu li.active > a,
html:not([data-theme="dark"]) .navigation-menu .submenu li.active > a {
  color: #485F7C !important;
}

/* Submenu Active Links - Dark Mode */
body.theme-dark .navigation-menu .submenu li.active > a,
[data-theme="dark"] .navigation-menu .submenu li.active > a {
  color: #5BA3C5 !important;
}

/* Hero Sections & Page Headers */
.bg-half,
.bg-half-170,
.bg-half-260 {
  position: relative;
}

/* Light Mode Hero Background */
:root .bg-half,
:root .bg-half-170,
:root .bg-half-260,
body.theme-light .bg-half,
body.theme-light .bg-half-170,
body.theme-light .bg-half-260,
html:not([data-theme="dark"]) .bg-half,
html:not([data-theme="dark"]) .bg-half-170,
html:not([data-theme="dark"]) .bg-half-260 {
  background: linear-gradient(135deg, #F8FAFC 0%, #E8F4F8 100%);
}

/* Dark Mode Hero Background */
body.theme-dark .bg-half,
body.theme-dark .bg-half-170,
body.theme-dark .bg-half-260,
[data-theme="dark"] .bg-half,
[data-theme="dark"] .bg-half-170,
[data-theme="dark"] .bg-half-260 {
  background: linear-gradient(135deg, #1E2834 0%, #2B3544 100%);
}

/* Primary Text Color */
.text-primary {
  color: var(--bs-primary) !important;
}

/* Primary Background */
.bg-primary {
  background-color: var(--bs-primary) !important;
}

/* Secondary Background */
.bg-secondary {
  background-color: var(--bs-secondary) !important;
}

/* Accent Highlights - Light Mode */
:root .text-accent,
body.theme-light .text-accent,
html:not([data-theme="dark"]) .text-accent {
  color: #5BA3C5 !important;
}

/* Accent Highlights - Dark Mode */
body.theme-dark .text-accent,
[data-theme="dark"] .text-accent {
  color: #7ED8C3 !important;
}

/* Feature Icons */
.icon-primary {
  color: var(--bs-primary) !important;
}

.icon-secondary {
  color: var(--bs-secondary) !important;
}

/* Icon Backgrounds */
.icon-bg-primary {
  background-color: rgba(var(--bs-primary-rgb), 0.1) !important;
  color: var(--bs-primary) !important;
}

.icon-bg-secondary {
  background-color: rgba(var(--bs-secondary-rgb), 0.1) !important;
  color: var(--bs-secondary) !important;
}

/* Borders */
.border-primary {
  border-color: var(--bs-primary) !important;
}

.border-secondary {
  border-color: var(--bs-secondary) !important;
}

/* Logo visibility based on theme - prevent duplication */
/* Default: show light logo, hide dark logo */
.logo .logo-dark-mode {
  display: none !important;
}

.logo .logo-light-mode {
  display: block !important;
}

/* Dark theme: show dark logo, hide light logo */
[data-theme="dark"] .logo .logo-dark-mode,
body.theme-dark .logo .logo-dark-mode,
html[data-theme="dark"] .logo .logo-dark-mode {
  display: block !important;
}

[data-theme="dark"] .logo .logo-light-mode,
body.theme-dark .logo .logo-light-mode,
html[data-theme="dark"] .logo .logo-light-mode {
  display: none !important;
}

/* Light theme: show light logo, hide dark logo */
[data-theme="light"] .logo .logo-light-mode,
body.theme-light .logo .logo-light-mode,
html[data-theme="light"] .logo .logo-light-mode {
  display: block !important;
}

[data-theme="light"] .logo .logo-dark-mode,
body.theme-light .logo .logo-dark-mode,
html[data-theme="light"] .logo .logo-dark-mode {
  display: none !important;
}

/* Company Logo Styling - MUCH LARGER sizes for perfect visibility */
.company-logo {
  height: 180px !important;
  width: auto !important;
  object-fit: contain;
  display: block;
  transition: all 0.3s ease;
}

/* Single logo display - no duplicates */
.logo img.company-logo {
  display: block !important;
}

/* Ensure navbar items are on same row - compact height */
#topnav #navigation {
  display: flex !important;
  align-items: center !important;
  height: 70px !important;
}

#topnav .navigation-menu {
  display: flex !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  height: 70px !important;
}

/* Logo in navbar - VERY LARGE logo with compact navbar */
#topnav {
  display: flex !important;
  align-items: center !important;
  padding: 5px 0 !important;
  min-height: 70px !important;
  max-height: 70px !important;
}

#topnav .container {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  padding: 0 15px !important;
  height: 70px !important;
}

#topnav .logo {
  display: flex !important;
  align-items: center !important;
  line-height: 1 !important;
  padding: 0 !important;
  height: 70px !important;
  font-size: 0 !important;
  margin: 0 !important;
  float: none !important;
  overflow: visible !important;
}

#topnav .logo a {
  display: flex !important;
  align-items: center !important;
  line-height: 1 !important;
  padding: 0 !important;
  height: 100% !important;
}

#topnav .logo .company-logo {
  height: 180px !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

/* Override any height constraints from base CSS */
#topnav .logo img.company-logo {
  height: 180px !important;
  width: auto !important;
  max-width: none !important;
  object-fit: contain;
  vertical-align: middle !important;
}

/* Single logo - ensure proper display */
#topnav .logo img.company-logo {
  display: block !important;
  visibility: visible !important;
}

/* Responsive logo sizing - keep navbar compact but logo large */
@media (max-width: 1200px) {
  .company-logo {
    height: 160px !important;
  }
  
  #topnav {
    min-height: 65px !important;
    max-height: 65px !important;
  }
  
  #topnav .container {
    height: 65px !important;
  }
  
  #topnav #navigation {
    height: 65px !important;
  }
  
  #topnav .navigation-menu {
    height: 65px !important;
  }
  
  #topnav .logo {
    height: 65px !important;
  }
  
  #topnav .logo .company-logo {
    height: 160px !important;
  }
}

@media (max-width: 992px) {
  .company-logo {
    height: 140px !important;
  }
  
  #topnav {
    min-height: 60px !important;
    max-height: 60px !important;
  }
  
  #topnav .container {
    height: 60px !important;
  }
  
  #topnav #navigation {
    height: 60px !important;
  }
  
  #topnav .navigation-menu {
    height: 60px !important;
  }
  
  #topnav .logo {
    height: 60px !important;
  }
  
  #topnav .logo .company-logo {
    height: 140px !important;
  }
}

@media (max-width: 768px) {
  .company-logo {
    height: 120px !important;
  }
  
  #topnav {
    min-height: 55px !important;
    max-height: 55px !important;
  }
  
  #topnav .container {
    height: 55px !important;
  }
  
  #topnav #navigation {
    height: 55px !important;
  }
  
  #topnav .navigation-menu {
    height: 55px !important;
  }
  
  #topnav .logo {
    height: 55px !important;
  }
  
  #topnav .logo .company-logo {
    height: 120px !important;
  }
}

@media (max-width: 480px) {
  .company-logo {
    height: 100px !important;
  }
  
  #topnav {
    min-height: 50px !important;
    max-height: 50px !important;
  }
  
  #topnav .container {
    height: 50px !important;
  }
  
  #topnav #navigation {
    height: 50px !important;
  }
  
  #topnav .navigation-menu {
    height: 50px !important;
  }
  
  #topnav .logo {
    height: 50px !important;
  }
  
  #topnav .logo .company-logo {
    height: 100px !important;
  }
}

/* Logo in offcanvas */
.offcanvas-header .company-logo {
  max-height: 60px !important;
  height: auto !important;
}

/* Logo in footer - SAME SIZE AS HEADER (180px) */
.company-logo-footer {
  height: 180px !important;
  width: auto !important;
  object-fit: contain;
  transition: opacity 0.3s ease;
  display: block !important;
}

.footer .logo-footer {
  display: flex !important;
  align-items: center !important;
  padding: 0 !important;
  height: auto !important;
  overflow: visible !important;
}

.footer .logo-footer img.company-logo-footer {
  height: 180px !important;
  width: auto !important;
}

/* Footer container adjustments for larger logo */
.footer-bar {
  min-height: 70px !important;
  display: flex !important;
  align-items: center !important;
  padding: 5px 0 !important;
}

.footer-bar .col-lg-3 {
  display: flex !important;
  align-items: center !important;
  overflow: visible !important;
}

.company-logo-footer:hover {
  opacity: 0.8;
}

@media (max-width: 1200px) {
  .company-logo-footer {
    height: 160px !important;
  }
  
  .footer .logo-footer img.company-logo-footer {
    height: 160px !important;
  }
}

@media (max-width: 992px) {
  .company-logo-footer {
    height: 140px !important;
  }
  
  .footer .logo-footer img.company-logo-footer {
    height: 140px !important;
  }
}

@media (max-width: 768px) {
  .company-logo-footer {
    height: 120px !important;
  }
  
  .footer .logo-footer img.company-logo-footer {
    height: 120px !important;
  }
}

@media (max-width: 480px) {
  .company-logo-footer {
    height: 100px !important;
  }
  
  .footer .logo-footer img.company-logo-footer {
    height: 100px !important;
  }

}

/* Ensure logo container doesn't break layout */
.logo {
  display: flex !important;
  align-items: center !important;
  line-height: 1 !important;
  font-size: 0 !important;
  padding: 0 !important;
}

.logo img.company-logo {
  vertical-align: middle !important;
}

/* Smooth hover effects */
.logo:hover .company-logo {
  transform: scale(1.05);
}

/* Fix navbar height - COMPACT navbar */
#topnav.defaultscroll {
  min-height: 70px !important;
  max-height: 70px !important;
  padding: 5px 0 !important;
  display: flex !important;
  align-items: center !important;
}

#topnav.defaultscroll .logo {
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 !important;
  height: 70px !important;
  overflow: visible !important;
}

/* Ensure proper spacing around logo */
#topnav .container > div:first-child {
  display: flex;
  align-items: center;
  padding: 0 !important;
  height: 70px !important;
  overflow: visible !important;
}

/* Override base logo CSS that might constrain size */
.logo {
  font-weight: normal !important;
  font-size: 0 !important;
  margin-right: 30px !important;
  padding: 0 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  height: 70px !important;
  display: flex !important;
  align-items: center !important;
  overflow: visible !important;
}

/* Ensure navigation menu is aligned with logo - compact height */
#topnav #navigation .navigation-menu {
  display: flex !important;
  align-items: center !important;
  height: 70px !important;
}

#topnav #navigation .navigation-menu > li {
  display: flex !important;
  align-items: center !important;
  height: 70px !important;
}

#topnav #navigation .navigation-menu > li > a {
  display: flex !important;
  align-items: center !important;
  height: 70px !important;
}

/* Modern Professional Footer Styles */
.footer {
  background: var(--bs-body-bg, #ffffff);
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}

/* Light Mode Specific Styles */
html:not([data-theme="dark"]) .footer,
body:not([data-theme="dark"]) .footer,
[data-theme="light"] .footer {
  background: #ffffff;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .footer-head,
html:not([data-theme="dark"]) .footer-head,
body:not([data-theme="dark"]) .footer-head {
  color: #212529 !important;
  font-weight: 600;
}

[data-theme="light"] .footer .text-foot,
html:not([data-theme="dark"]) .footer .text-foot,
body:not([data-theme="dark"]) .footer .text-foot {
  color: #495057 !important;
}

[data-theme="light"] .footer .text-foot:hover,
html:not([data-theme="dark"]) .footer .text-foot:hover,
body:not([data-theme="dark"]) .footer .text-foot:hover {
  color: var(--bs-primary) !important;
}

[data-theme="light"] .footer .text-muted,
html:not([data-theme="dark"]) .footer .text-muted,
body:not([data-theme="dark"]) .footer .text-muted {
  color: #6c757d !important;
}

/* Dark Mode Styles */
[data-theme="dark"] .footer {
  background: var(--bs-body-bg, #1a1a1a);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-main {
  padding: 3rem 0 !important;
}

.footer-head {
  font-size: 1.1rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
  color: var(--bs-body-color);
  letter-spacing: 0.5px;
}

.footer-list li a {
  transition: all 0.3s ease;
  display: inline-block;
  font-size: 0.95rem;
  color: inherit;
}

[data-theme="light"] .footer-list li a,
html:not([data-theme="dark"]) .footer-list li a,
body:not([data-theme="dark"]) .footer-list li a {
  color: #495057 !important;
}

.footer-list li a:hover {
  color: var(--bs-primary) !important;
  transform: translateX(5px);
  text-decoration: none;
}

.footer-contact p {
  font-size: 0.95rem;
  line-height: 1.8;
  color: inherit;
}

.footer-contact a {
  transition: color 0.3s ease;
  color: inherit;
}

[data-theme="light"] .footer-contact a,
html:not([data-theme="dark"]) .footer-contact a,
body:not([data-theme="dark"]) .footer-contact a {
  color: #495057 !important;
}

.footer-contact a:hover {
  color: var(--bs-primary) !important;
  text-decoration: none;
}

.footer-bar {
  border-top: 1px solid rgba(0, 0, 0, 0.08) !important;
  padding: 1.5rem 0 !important;
}

[data-theme="light"] .footer-bar,
html:not([data-theme="dark"]) .footer-bar,
body:not([data-theme="dark"]) .footer-bar {
  border-top: 1px solid rgba(0, 0, 0, 0.08) !important;
}

[data-theme="dark"] .footer-bar {
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.footer-bar .text-foot {
  font-size: 0.9rem;
  transition: color 0.3s ease;
  color: inherit;
}

.footer-bar .text-foot:hover {
  color: var(--bs-primary) !important;
  text-decoration: none;
}

/* Social Icons - Light Mode */
html:not([data-theme="dark"]) .foot-social-icon a,
body:not([data-theme="dark"]) .foot-social-icon a,
[data-theme="light"] .foot-social-icon a {
  width: 38px;
  height: 38px;
  line-height: 38px;
  text-align: center;
  display: inline-block;
  border-radius: 6px;
  background: rgba(var(--bs-primary-rgb), 0.1);
  color: var(--bs-primary) !important;
  transition: all 0.3s ease;
}

html:not([data-theme="dark"]) .foot-social-icon a:hover,
body:not([data-theme="dark"]) .foot-social-icon a:hover,
[data-theme="light"] .foot-social-icon a:hover {
  background: var(--bs-primary);
  color: #ffffff !important;
  transform: translateY(-3px);
  box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.3);
}

/* Social Icons - Dark Mode */
[data-theme="dark"] .foot-social-icon a {
  width: 38px;
  height: 38px;
  line-height: 38px;
  text-align: center;
  display: inline-block;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.8) !important;
  transition: all 0.3s ease;
}

[data-theme="dark"] .foot-social-icon a:hover {
  background: var(--bs-primary);
  color: #ffffff !important;
  transform: translateY(-3px);
  box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.3);
}

/* Footer Subscribe Form */
.footer-subscribe .form-control {
  border-radius: 6px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  padding: 0.5rem 0.75rem;
  font-size: 0.9rem;
  transition: all 0.3s ease;
}

[data-theme="dark"] .footer-subscribe .form-control {
  border-color: rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.9);
}

[data-theme="light"] .footer-subscribe .form-control,
html:not([data-theme="dark"]) .footer-subscribe .form-control {
  border-color: rgba(0, 0, 0, 0.15);
  background: #ffffff;
  color: #212529;
}

.footer-subscribe .form-control:focus {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.15);
  outline: none;
}

.footer-subscribe .btn {
  border-radius: 6px;
  font-weight: 500;
  transition: all 0.3s ease;
}

.footer-subscribe .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.3);
}

.footer-subscribe #newsletter-message {
  font-size: 0.85rem;
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
}

/* Responsive Footer */
@media (max-width: 768px) {
  .footer-main {
    padding: 2rem 0 !important;
  }
  
  .footer-head {
    margin-bottom: 1rem;
    margin-top: 1.5rem;
  }
  
  .footer-head:first-child {
    margin-top: 0;
  }
  
  .footer-bar .d-flex {
    flex-direction: column;
    align-items: flex-start !important;
    gap: 0.5rem !important;
  }
}

/* ============================================
   Modern Homepage Design Styles
   ============================================ */

/* Hover Card Effect */
.hover-card {
  transition: all 0.3s ease;
}

.hover-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 35px rgba(0, 0, 0, 0.15) !important;
}

[data-theme="dark"] .hover-card:hover {
  box-shadow: 0 12px 35px rgba(0, 0, 0, 0.4) !important;
}

/* Icon Box Soft Background */
.bg-soft-primary {
  background-color: rgba(var(--bs-primary-rgb), 0.1);
}

[data-theme="dark"] .bg-soft-primary {
  background-color: rgba(var(--bs-primary-rgb), 0.15);
}

/* Gradient Primary Background */
.bg-gradient-primary {
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);
}

[data-theme="dark"] .bg-gradient-primary {
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
}

/* Section Spacing */
.section {
  position: relative;
}

/* Hero Section Enhancements */
.heading {
  letter-spacing: -0.02em;
  line-height: 1.2;
}

/* Service Cards */
.card {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.card.shadow-sm {
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08) !important;
}

[data-theme="dark"] .card.shadow-sm {
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3) !important;
  background: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .card.border-0 {
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* Icon Boxes */
.icon-box {
  transition: all 0.3s ease;
}

.hover-card:hover .icon-box {
  transform: scale(1.1);
}

/* Button Enhancements */
.btn-lg {
  padding: 0.875rem 2rem;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.3px;
  transition: all 0.3s ease;
}

.btn-lg:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}

/* Z-index helper */
.z-index-1 {
  z-index: 1;
}

/* Text White 50 */
.text-white-50 {
  color: rgba(255, 255, 255, 0.75) !important;
}

/* Rounded Enhancements */
.rounded-3 {
  border-radius: 1rem !important;
}

.rounded-4 {
  border-radius: 1.5rem !important;
}

/* Why Choose Section - Check Icons */
.bg-primary.bg-gradient {
  background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
}

[data-theme="dark"] .bg-primary.bg-gradient {
  background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
}

/* Smooth Scrolling */
html {
  scroll-behavior: smooth;
}

/* Enhanced Shadows */
.shadow-lg {
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175) !important;
}

[data-theme="dark"] .shadow-lg {
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.4) !important;
}

/* Image Enhancements */
img.img-fluid {
  max-width: 100%;
  height: auto;
}

/* Responsive Typography */
@media (max-width: 991px) {
  .heading {
    font-size: 2.25rem !important;
  }
  
  h2 {
    font-size: 1.875rem;
  }
  
  h5 {
    font-size: 1.125rem;
  }
}

@media (max-width: 767px) {
  .heading {
    font-size: 1.875rem !important;
  }
  
  h2 {
    font-size: 1.625rem;
  }
  
  .btn-lg {
    padding: 0.75rem 1.5rem;
    font-size: 0.9375rem;
  }
  
  section[style*="padding: 80px 0"] {
    padding: 60px 0 !important;
  }
  
  section[style*="padding: 100px 0 80px"] {
    padding: 80px 0 60px !important;
  }
}

/* Animation for page load */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.title-heading,
.hover-card {
  animation: fadeInUp 0.6s ease-out;
}

