/* Custom Theme Variables */
/* Color System CSS Variables */
:root {
  /* Primary Color Palette */
  --primary-50: #e6eef0;
  --primary-100: #b0ccd3;
  --primary-200: #8ab3be;
  --primary-300: #5492a1;
  --primary-400: #2f7b8d;
  --primary-500: #0d556a; /* Primary Base Color */
  --primary-600: #0c4d60;
  --primary-700: #093d4b;
  --primary-800: #072e39;
  --primary-900: #051e25;

  /* Secondary Color Palette */
  --secondary-50: #e8ecf3;
  --secondary-100: #b5c0d8;
  --secondary-200: #91a1c4;
  --secondary-300: #6177a8;
  --secondary-400: #3f5a95;
  --secondary-500: #163566; /* Secondary Base Color */
  --secondary-600: #14305c;
  --secondary-700: #102648;
  --secondary-800: #0c1d37;
  --secondary-900: #081324;
  
  /* Success Color Palette */
  --success-50: #e8f2ed;
  --success-100: #b5d7c7;
  --success-200: #91c4ad;
  --success-300: #61a889;
  --success-400: #3f9571;
  --success-500: #157146; /* Success Base Color */
  --success-600: #13663f;
  --success-700: #105232;
  --success-800: #0c3d26;
  --success-900: #082919;

  /* Info Color Palette */
  --info-50: #f0eef4;
  --info-100: #d0cade;
  --info-200: #b8afcf;
  --info-300: #9a8bbb;
  --info-400: #8474ae;
  --info-500: #6e5d9d; /* Info Base Color */
  --info-600: #63548d;
  --info-700: #4f4371;
  --info-800: #3c3355;
  --info-900: #282238;

  /* Warning & Danger - Use Bootstrap defaults */
  
  /* Semantic Color Mapping */
  --bs-primary: var(--primary-500);
  --bs-primary-rgb: 13, 85, 106;
  --bs-primary-lighter: var(--primary-300);
  --bs-primary-darker: var(--primary-700);
  
  --bs-secondary: var(--secondary-500);
  --bs-secondary-rgb: 22, 53, 102;
  --bs-secondary-lighter: var(--secondary-300);
  --bs-secondary-darker: var(--secondary-700);
  
  --bs-success: var(--success-500);
  --bs-success-rgb: 21, 113, 70;
  --bs-success-lighter: var(--success-300);
  --bs-success-darker: var(--success-700);
  
  --bs-info: var(--info-500);
  --bs-info-rgb: 110, 93, 157;
  --bs-info-lighter: var(--info-300);
  --bs-info-darker: var(--info-700);
  
  /* UI Element Colors */
  --input-border-color: var(--bs-info-lighter, var(--info-300));
  --nav-tab-background: var(--bs-gray-100);
  --nav-tab-text-color: var(--bs-gray-900);
  --nav-link-active-cat-color: var(--bs-secondary);
  --nav-link-active-section-color: var(--bs-primary);
  --nav-link-active-section-border: var(--bs-primary);
  
  /* Button Specific Overrides */
  --btn-info: var(--bs-info);
  --btn-info-hover: var(--bs-info-darker);
  --btn-info-text: white;


 /* Typography */
 --font-family-base: 'Poppins', sans-serif;
 --font-size-base: 1rem;
 --font-weight-base: 400;

}

/* Button Color Overrides */
.btn-primary {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
}

.btn-primary:hover {
  background-color: var(--bs-primary-darker);
  border-color: var(--bs-primary-darker);
}

.btn-secondary {
  background-color: var(--bs-secondary);
  border-color: var(--bs-secondary);
}

.btn-secondary:hover {
  background-color: var(--bs-secondary-darker);
  border-color: var(--bs-secondary-darker);
}

/* Alert Colors with semantic color variables */
.alert-primary {
  background-color: color-mix(in srgb, var(--bs-primary) 15%, white);
  border-color: var(--bs-primary);
  color: var(--bs-primary);
}

.alert-secondary {
  background-color: color-mix(in srgb, var(--bs-secondary) 15%, white);
  border-color: var(--bs-secondary);
  color: var(--bs-secondary);
}

/* Focus States */
.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);
}

/* Info Button Overrides */
.btn-info {
  background-color: var(--btn-info);
  border-color: var(--btn-info);
  color: var(--btn-info-text);
}

.btn-info:hover,
.btn-info:active,
.btn-info:focus {
  background-color: var(--btn-info-hover);
  border-color: var(--btn-info-hover);
  color: var(--btn-info-text);
}

.btn-info:disabled {
  background-color: var(--btn-info-lighter);
  border-color: var(--btn-info-hover);
}

.btn-outline-info {
  color: var(--btn-info);
  border-color: var(--btn-info);
}

.btn-outline-info:hover,
.btn-outline-info:active,
.btn-outline-info:focus {
  background-color: var(--btn-info);
  color: var(--btn-info-text);
}
  

  /* Base Typography */
  body {
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-base);
  }
  
 
  /* Form Controls */
  .form-control {
    font-size: var(--label-size);
    border-radius: var(--input-border-radius);
    border-color: var(--input-border-color);
    padding: var(--input-padding);
    background-color: var(--input-background);
  }
  
  
  .form-label {
    font-size: calc(var(--label-size) * 1.2);
    font-weight: var(--label-weight);
    color: var(--bs-gray-700);
    margin-bottom: 0.25;
  }
  
  /* Readonly state */
    .form-control:read-only,
    .form-control[readonly] {
    background-color: var(--input-bg);
    border-color: transparent;
    }

    .form-select {
        font-size: var(--label-size);
        border-radius: var(--input-border-radius);
        border-color: var(--input-border-color);
        padding: var(--input-padding);
        background-color: var(--input-background);
      }

      .form-select:focus {
        border-color: var(--bs-primary);
        box-shadow: 0 0 0 0.25rem rgba(0, 102, 153, 0.25);
      }
    
      /* Readonly state */
    .form-select:read-only,
    .form-select[readonly] {
    background-color: var(--input-bg);
    border-color: transparent;
    }

      /* Form styling updates
      .form-label {
    font-weight: 500;
    color: var(--bs-gray-700);
    }
      
    .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);
    } */

  /* Alert Colors */
  .alert-primary {
    background-color: color-mix(in srgb, var(--bs-primary) 15%, white);
    border-color: var(--bs-primary);
    color: var(--bs-primary);
  }
  
  .alert-secondary {
    background-color: color-mix(in srgb, var(--bs-secondary) 15%, white);
    border-color: var(--bs-secondary);
    color: var(--bs-secondary);
  }
  
  /* Badge Colors */
  .badge.bg-primary {
    background-color: var(--bs-primary) !important;
  }
  
  .badge.bg-secondary {
    background-color: var(--bs-secondary) !important;
  }
  
  /* Top Navigation */
  .navbar-primary {
    background-color: var(--bs-primary);
    border-radius: var(--input-border-radius);
    color: white;
  }
  
  .nav-link {
    color: white;
    font-size: large;
  }

  .nav-link.dropdown {
    color: var(--bs-secondary);
  }
  
  .nav-link:hover {
    color: color-mix(in srgb, var(--bs-gray-700) 75%, black);
    border-radius: 0.375rem;
    border-color: transparent;
  }
  
  /* Tabs menu */
  .context-tabs .nav-tabs {
    background: var(--nav-tab-background);
    color: var(--nav-tab-text-color);
    z-index: 1020;
  }
  /* Section level navigation */
    /* .section-level-tabs {
        border-top: 1px solid var(--input-border-color);
        background: var(--nav-tab-background);
    } */

    /* .section-level-tabs {
      height: 44px;
    } */
    .section-level-tabs.expanded {
        display: block;
    }


    .section-level-tabs .nav-link {
        white-space: nowrap;
        padding: 0.5rem 0.75rem;

   }

  .section-level-tabs .nav-link.active {
    color: var(--nav-link-active-section-color);
    border-color: var(--nav-link-active-section-border);
  }

  .category-tabs .nav-link.active {
    color: var(--nav-link-active-cat-color);
    background: var(--nav-link-active-cat-background);
    border-color: var(--nav-link-active-cat-border);
  }

  .nav-tabs .nav-link {
    color: var(--nav-tab-text-color);
}
  .category-tabs .nav-link {
    display: flex;
    white-space: nowrap;
    font-size: 0.9rem;
    color: var(--nav-tab-text-color);
}

.section-level-tabs .nav {
  display: flex;
}

@media (max-width: 1200px) {
  .section-level-tabs .nav {
    display: flex;
    overflow-x: auto;
  }
}

  /* Mobile styles (devices smaller than 768px) */
@media (max-width: 767.98px) {

    .form-label {
      font-size: calc(var(--label-size) * 0.9); /* Slightly smaller on mobile */
      margin-bottom: 0.25rem; /* Tighter spacing */
  }

    .form-control {
      font-size: calc(var(--label-size) * 0.9); /* Slightly smaller input text */
      padding: calc(var(--input-padding) * 0.75); /* Reduced padding */
    }
    
    /* Adjust vertical spacing between form groups */
    .form-group,
    .mb-3 {
      margin-bottom: 0.75rem !important;
  }

    /* Make sure inputs are tall enough for touch */
    .form-control {
      min-height: 42px;
    }
    .section-level-tabs .nav {
      display: flex;
      overflow-x: auto;
    }

}
    
    /* Base container padding adjustments */
    @media (max-width: 767.98px) {
    .container-fluid {
      padding-left: 0.5rem;
      padding-right: 0.5rem;
  }

    /* Section content adjustments */
    /* .section-content {
      padding-left: 0.5rem;
      padding-right: 0.5rem;
      padding-bottom: 100px;

  } */

    /* Card spacing adjustments */
    .card {
      margin-left: -0.25rem;
      margin-right: -0.25rem;
      border-radius: 0.375rem;
  }

    .card-body {
      padding: 0.75rem;
  }

    /* Adjust section data container padding */
    .section-data-container {
      padding-left: 0.25rem !important;
      padding-right: 0.25rem !important;
  }

    /* Form group spacing in cards */
    .card .form-group,
    .card .mb-3 {
      margin-bottom: 0.75rem;
    }
  }

  /* Extra small devices (phones smaller than 576px)
  @media (max-width: 575.98px) {
    .container-fluid {
      padding-left: 0.25rem;
      padding-right: 0.25rem;
  }
  
    .section-content {
      padding-left: 0;
      padding-right: 0;
    }
  
    .card {
      margin-left: -0.25rem;
      margin-right: -0.25rem;
      border-radius: 0.25rem;
    }
  
    .card-body {
      padding: 0.5rem;
    }
   */
    /* Minimal padding for section containers */
    /* .section-data-container {
      padding-left: 0 !important;
      padding-right: 0 !important;
    }
  
    /* Further reduce form group spacing */
    /* .card .form-group,
    .card .mb-3 {
      margin-bottom: 0.5rem;
    }
  } */


  .navbar-brand {
    background-color: transparent;
    color: var(--input-bg);
  }
  
  .navbar-nav {
    color: white;
  }

  .navbar-footer {
    border-color: var(--bs-primary);
  }

  /* Add these styles to ensure the story modal appears on top */
  #addStoryModal {
    z-index: 1060 !important; /* Higher than Bootstrap's default 1050 */
  }

  #onboardingModal.story-in-progress {
    opacity: 0.5;
  }

/* Shared modal styling for both story and onboarding modals */
#addStoryModal .modal-content,
#onboardingModal .modal-content {
  border-radius: 12px;
  box-shadow: 0 15px 35px rgba(0,0,0,0.1);
}

#addStoryModal .modal-header,
#onboardingModal .modal-header {
  border-bottom: none;
  padding-bottom: 0;
}

#addStoryModal .modal-body,
#onboardingModal .modal-body {
  padding: 1.5rem 2rem;
}

#addStoryModal .progress,
#onboardingModal .progress {
  height: 8px;
  border-radius: 4px;
  background-color: #f0f0f0;
}

#addStoryModal .progress-bar,
#onboardingModal .progress-bar {
  background-color: var(--bs-info);
  transition: width 0.3s ease;
}

#addStoryModal .step-page,
#onboardingModal .onboarding-step {
  transition: opacity 0.3s ease;
}

#addStoryModal textarea,
#onboardingModal textarea {
  border-radius: 8px;
  border: 1px solid var(--bs-secondary);
  padding: 12px;
  font-size: 16px;
  transition: all 0.2s ease;
}

#addStoryModal textarea:focus,
#onboardingModal textarea:focus {
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.15);
}

#addStoryModal .modal-footer,
#onboardingModal .modal-footer {
  border-top: none;
  padding-top: 0;
}

#addStoryModal .btn,
#onboardingModal .btn {
  padding: 0.5rem 1.5rem;
  border-radius: 6px;
  font-weight: 500;
}

#storyProgress,
#onboardingProgress {
  transition: width 0.5s ease-in-out;
}

#storyCategory,
.badge {
  font-size: 0.85rem;
  padding: 0.4rem 0.8rem;
}

#storyQuestion,
#onboardingModal .card-title {
  font-size: 1rem;
  color: var(--bs-gray-700);
  font-weight: 100;
}

#addStoryModal .accordion-button:not(.collapsed),
#onboardingModal .accordion-button:not(.collapsed) {
  background-color: rgba(13, 110, 253, 0.1);
  color: var(--bs-secondary);
}

.story-entry.active-analysis {
  outline: 2px solid var(--bs-info);
}
.button-toolbar {
  z-index: 1020;
}
