/* Base styles */
:root {
    --primary-color: #ff6b35;
    --primary-hover: #e85a2a;
    --secondary-color: #2ec4b6;
    --accent-color: #ff9f1c;
    --light-bg: #f8f9fa;
    --dark-bg: #212529;
    --dark-card: #2a2d31;
    --text-light: #f8f9fa;
    --text-dark: #212529;
    --border-light: #dee2e6;
    --border-dark: #495057;
}


}
/* Dark mode styles */
[data-bs-theme="dark"] {
    --bs-body-bg: var(--dark-bg);
    --bs-body-color: var(--text-light);
    --bs-border-color: var(--border-dark);
}

/* Light mode styles */
[data-bs-theme="light"] {
    --bs-body-bg: var(--light-bg);
    --bs-body-color: var(--text-dark);
    --bs-border-color: var(--border-light);
}

/* Theme icons */
.theme-icon-light {
    display: none;
}

.theme-icon-dark {
    display: inline-block;
}

[data-bs-theme="dark"] .theme-icon-light {
    display: inline-block;
}

[data-bs-theme="dark"] .theme-icon-dark {
    display: none;
}

/* General styles */
body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

main {
    flex: 1;
}

/* Navbar styles */
.navbar-brand i {
    color: var(--primary-color);
}

/* Fix for dropdown menus on mobile */
@media (max-width: 767.98px) {
    .dropdown-menu-end-forced .dropdown-menu {
        position: absolute !important;
        right: auto !important;
        left: 0 !important;
        top: 100% !important;
        transform: none !important;
        float: right !important;
        min-width: 10rem;
        margin: 0.125rem 0 0;
        will-change: auto !important;
    }
    
    /* Ensure dropdowns don't go off-screen */
    .dropdown {
        position: static !important;
    }
    
    .navbar .dropdown-menu {
        width: auto;
        max-width: 100%;
    }
    
    /* Fix for language and theme dropdowns */
    .navbar-collapse .dropdown {
        position: relative !important;
    }
}

/* Calculator styles */
.factor-container {
    margin-bottom: 1.5rem;
}

.factor-label {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
}

.factor-value {
    font-weight: 500;
    color: var(--primary-color);
}

/* Slider labels */
.slider-labels {
    display: flex;
    justify-content: space-between;
    margin-top: 0.25rem;
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
}

/* Form step styles */
.form-step {
    display: none; /* Hide all steps by default */
    animation: fadeIn 0.3s ease-in-out;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* Gender selection */
.gender-options {
    display: flex;
    gap: 1rem;
    margin-bottom: 2rem;
}

.gender-option {
    flex: 1;
    text-align: center;
    padding: 1.5rem;
    border: 2px solid var(--bs-border-color);
    border-radius: 0.5rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.gender-option:hover {
    border-color: var(--primary-color);
}

.gender-option.selected {
    border-color: var(--primary-color);
    background-color: rgba(var(--bs-primary-rgb), 0.1);
}

.gender-option i {
    font-size: 2rem;
    margin-bottom: 0.5rem;
    color: var(--primary-color);
}

/* Result styles */
.result-card {
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
    border-radius: 1rem;
    overflow: hidden;
    transition: transform 0.3s ease;
}

[data-bs-theme="dark"] .result-card {
    background: linear-gradient(135deg, #2a2d31 0%, #212529 100%);
}

.result-card:hover {
    transform: translateY(-5px);
}

.result-icon {
    color: var(--primary-color);
}

/* Ad container */
.ad-container {
    background-color: #f0f0f0;
    padding: 1rem;
    border-radius: 0.5rem;
    text-align: center;
}

[data-bs-theme="dark"] .ad-container {
    background-color: #2a2d31;
}

/* RTL support for Arabic */
html[dir="rtl"] .me-1 {
    margin-right: 0 !important;
    margin-left: 0.25rem !important;
}

html[dir="rtl"] .me-2 {
    margin-right: 0 !important;
    margin-left: 0.5rem !important;
}

html[dir="rtl"] .me-3 {
    margin-right: 0 !important;
    margin-left: 1rem !important;
}

html[dir="rtl"] .ms-1 {
    margin-left: 0 !important;
    margin-right: 0.25rem !important;
}

html[dir="rtl"] .ms-2 {
    margin-left: 0 !important;
    margin-right: 0.5rem !important;
}

html[dir="rtl"] .ms-3 {
    margin-left: 0 !important;
    margin-right: 1rem !important;
}

/* Progress bar animation */
.progress-bar {
    transition: width 0.4s ease;
}

/* Responsive adjustments */
@media (max-width: 576px) {
    .display-5 {
        font-size: 2rem;
    }
    
    .display-1 {
        font-size: 3.5rem;
    }
    
    .gender-options {
        flex-direction: column;
    }
    
    /* Smaller font for slider labels on mobile */
    .slider-labels {
        font-size: 0.7rem;
    }
}

/* Custom Range Slider Styling */
.form-range.factor-slider {
  height: 1.5rem;
  padding: 0;
  background: transparent;
}

/* Styling for the track (the line) */
.form-range.factor-slider::-webkit-slider-runnable-track {
  width: 100%;
  height: 0.5rem;
  background: #e9ecef;
  border-radius: 1rem;
  border: none;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
  cursor: pointer;
}

.form-range.factor-slider::-moz-range-track {
  width: 100%;
  height: 0.5rem;
  background: #e9ecef;
  border-radius: 1rem;
  border: none;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
  cursor: pointer;
}

/* Styling for the thumb (the handle) */
.form-range.factor-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  height: 1.25rem;
  width: 1.25rem;
  border-radius: 50%;
  background: #0d6efd; /* Bootstrap primary color */
  border: 2px solid #fff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  cursor: pointer;
  margin-top: -0.375rem; /* Centers the thumb on the track */
  transition: all 0.2s ease;
}

.form-range.factor-slider::-moz-range-thumb {
  height: 1.25rem;
  width: 1.25rem;
  border-radius: 50%;
  background: #0d6efd; /* Bootstrap primary color */
  border: 2px solid #fff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  cursor: pointer;
  transition: all 0.2s ease;
}

/* Hover effects */
.form-range.factor-slider:hover::-webkit-slider-thumb {
  background: #0b5ed7; /* Slightly darker on hover */
  transform: scale(1.1);
}

.form-range.factor-slider:hover::-moz-range-thumb {
  background: #0b5ed7; /* Slightly darker on hover */
  transform: scale(1.1);
}

/* Focus styles */
.form-range.factor-slider:focus {
  outline: none;
}

.form-range.factor-slider:focus::-webkit-slider-thumb {
  box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.25); /* Bootstrap focus shadow */
}

.form-range.factor-slider:focus::-moz-range-thumb {
  box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.25); /* Bootstrap focus shadow */
}

/* Dark mode adjustments */
[data-bs-theme="dark"] .form-range.factor-slider::-webkit-slider-runnable-track,
.dark .form-range.factor-slider::-webkit-slider-runnable-track {
  background: #343a40;
}

[data-bs-theme="dark"] .form-range.factor-slider::-moz-range-track,
.dark .form-range.factor-slider::-moz-range-track {
  background: #343a40;
}

[data-bs-theme="dark"] .form-range.factor-slider::-webkit-slider-thumb,
.dark .form-range.factor-slider::-webkit-slider-thumb {
  border-color: #212529;
}

[data-bs-theme="dark"] .form-range.factor-slider::-moz-range-thumb,
.dark .form-range.factor-slider::-moz-range-thumb {
  border-color: #212529;
}

/* For browsers that support it, we can add a filled track effect */
.form-range.factor-slider {
  --range-progress: 50%; /* Default value, will be updated by JS */
  --primary-color: #0d6efd;
  --track-height: 0.5rem;
}

/* This creates the filled track effect for WebKit browsers */
.form-range.factor-slider::-webkit-slider-runnable-track {
  background: linear-gradient(to right, var(--primary-color) var(--range-progress), #e9ecef var(--range-progress));
}

[data-bs-theme="dark"] .form-range.factor-slider::-webkit-slider-runnable-track,
.dark .form-range.factor-slider::-webkit-slider-runnable-track {
  background: linear-gradient(to right, var(--primary-color) var(--range-progress), #343a40 var(--range-progress));
}

