/* assets/style.css */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap');

* {
  font-family: 'Roboto', sans-serif !important;
}

#navbar .navbar-brand {
    color: #F59410;  /* primary */
    font-size: 100%;
  }


#navbar {
  background: black !important;

}

#nav {
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
}

#nav .nav-link {
  color: #ffffff !important;
  margin: 0 0.75rem;
  font-size: 1.2rem;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  transition: all 0.3s ease;
}

#nav .nav-link:hover {
  background-color: rgba(134, 98, 179, 0.1);  /* secondary with low opacity */
  color: #CEA6FF !important;  /* tertiary */
}

#nav .nav-link.active {
  font-weight: 600;
  color: #ffffff !important;
  background-color: rgba(134, 98, 179, 0.25);  /* secondary with 25% opacity */
  border: 1px solid rgba(206, 166, 255, 0.4);  /* tertiary with 40% opacity */
}

.loader-background {
  background-color: rgba(134, 98, 179, 0.15);  /* secondary with low opacity */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 2rem 3rem;
  border-radius: 12px;
  border: 1px solid rgba(206, 166, 255, 0.3);  /* tertiary border */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 32px rgba(134, 98, 179, 0.2);
}

/* Table of contents ––––––––––––––––––––––––––––––––––––––––––––––––––
Taken from https://codepen.io/chriddyp/pen/bWLwgP.css
- Grid
- Base Styles
 - Typography
 - Links
 - Buttons
 - Forms
 - Lists
 - Code
 - Tables
 - Spacing
 - Utilities
 - Clearing
 - Media Queries
 - Custom App CSS */


/* Grid –––––––––––––––––––––––––––––––––––––––––––––––––– */
.container {
  position: relative;
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}
.column, .columns {
  width: 100%;
  float: left;
  box-sizing: border-box;
}
/* For devices larger than 400px */
@media (min-width: 400px) {
  .container {
      width: 85%;
      padding: 0;
 }
}
/* For devices larger than 550px */
@media (min-width: 550px) {
  .container {
      width: 80%;
 }
  .column, .columns {
      margin-left: 4%;
 }
  .column:first-child, .columns:first-child {
      margin-left: 0;
 }
  .one.column, .one.columns {
      width: 4.66666666667%;
 }
  .two.columns {
      width: 13.3333333333%;
 }
  .three.columns {
      width: 22%;
 }
  .four.columns {
      width: 30.6666666667%;
 }
  .five.columns {
      width: 39.3333333333%;
 }
  .six.columns {
      width: 48%;
 }
  .seven.columns {
      width: 56.6666666667%;
 }
  .eight.columns {
      width: 65.3333333333%;
 }
  .nine.columns {
      width: 74.0%;
 }
  .ten.columns {
      width: 82.6666666667%;
 }
  .eleven.columns {
      width: 91.3333333333%;
 }
  .twelve.columns {
      width: 100%;
      margin-left: 0;
 }
  .one-third.column {
      width: 30.6666666667%;
 }
  .two-thirds.column {
      width: 65.3333333333%;
 }
  .one-half.column {
      width: 48%;
 }
 /* Offsets */
  .offset-by-one.column, .offset-by-one.columns {
      margin-left: 8.66666666667%;
 }
  .offset-by-two.column, .offset-by-two.columns {
      margin-left: 17.3333333333%;
 }
  .offset-by-three.column, .offset-by-three.columns {
      margin-left: 26%;
 }
  .offset-by-four.column, .offset-by-four.columns {
      margin-left: 34.6666666667%;
 }
  .offset-by-five.column, .offset-by-five.columns {
      margin-left: 43.3333333333%;
 }
  .offset-by-six.column, .offset-by-six.columns {
      margin-left: 52%;
 }
  .offset-by-seven.column, .offset-by-seven.columns {
      margin-left: 60.6666666667%;
 }
  .offset-by-eight.column, .offset-by-eight.columns {
      margin-left: 69.3333333333%;
 }
  .offset-by-nine.column, .offset-by-nine.columns {
      margin-left: 78.0%;
 }
  .offset-by-ten.column, .offset-by-ten.columns {
      margin-left: 86.6666666667%;
 }
  .offset-by-eleven.column, .offset-by-eleven.columns {
      margin-left: 95.3333333333%;
 }
  .offset-by-one-third.column, .offset-by-one-third.columns {
      margin-left: 34.6666666667%;
 }
  .offset-by-two-thirds.column, .offset-by-two-thirds.columns {
      margin-left: 69.3333333333%;
 }
  .offset-by-one-half.column, .offset-by-one-half.columns {
      margin-left: 52%;
 }
}
/* Base Styles –––––––––––––––––––––––––––––––––––––––––––––––––– */
/* NOTE html is set to 62.5% so that all the REM measurements throughout Skeleton are based on 10px sizing. So basically 1.5rem = 15px :) */
html {
  font-size: 82.5%;
}
body {
  font-size: 1.5em;
 /* currently ems cause chrome bug misinterpreting rems on body element */
  line-height: 1.6;
  font-weight: 400;
  font-family: 'Roboto', sans-serif;
  color: rgb(50, 50, 50);
}

/* Typography –––––––––––––––––––––––––––––––––––––––––––––––––– */
h1, h2, h3, h4, h5, h6 {
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 300;
}
h1 {
  font-size: 4.5rem;
  line-height: 1.2;
  letter-spacing: -.1rem;
  margin-bottom: 2rem;
}
h2 {
  font-size: 3.6rem;
  line-height: 1.25;
  letter-spacing: -.1rem;
  margin-bottom: 1.8rem;
  margin-top: 1.8rem;
}
h3 {
  font-size: 3.0rem;
  line-height: 1.3;
  letter-spacing: -.1rem;
  margin-bottom: 1.5rem;
  margin-top: 1.5rem;
}
h4 {
  font-size: 2.6rem;
  line-height: 1.35;
  letter-spacing: -.08rem;
  margin-bottom: 1.2rem;
  margin-top: 1.2rem;
}
h5 {
  font-size: 2.2rem;
  line-height: 1.5;
  letter-spacing: -.05rem;
  margin-bottom: 0.6rem;
  margin-top: 0.6rem;
}
h6 {
  font-size: 2.0rem;
  line-height: 1.6;
  letter-spacing: 0;
  margin-bottom: 0.75rem;
  margin-top: 0.75rem;
}
p {
  margin-top: 0;
}
/* Blockquotes –––––––––––––––––––––––––––––––––––––––––––––––––– */
blockquote {
  border-left: 4px lightgrey solid;
  padding-left: 1rem;
  margin-top: 2rem;
  margin-bottom: 2rem;
  margin-left: 0rem;
}
/* Links –––––––––––––––––––––––––––––––––––––––––––––––––– */
a {
  color: #1EAEDB;
  text-decoration: underline;
  cursor: pointer;
}
a:hover {
  color: #0FA0CE;
}
/* Buttons –––––––––––––––––––––––––––––––––––––––––––––––––– */
.rc-slider-track{
  background-color: #F59410  /* primary */
}

.rc-slider-rail{
  background-color: #3A3A3C  /* quinary */
}


.main-svg{
  font-family: 'Roboto', sans-serif
}

.gtitle{
  font-family: 'Roboto', sans-serif !important
}

.g-title{
  font-family: 'Roboto', sans-serif
}


.button, button, input[type="submit"], input[type="reset"], input[type="button"] {
  display: inline-block;
  height: 38px;
  padding: 0 30px;
  color: #555;
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  line-height: 38px;
  letter-spacing: .1rem;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  background-color: transparent;
  border-radius: 4px;
  border: 1px solid #bbb;
  cursor: pointer;
  box-sizing: border-box;
}
.button:hover, button:hover, input[type="submit"]:hover, input[type="reset"]:hover, input[type="button"]:hover, .button:focus, button:focus, input[type="submit"]:focus, input[type="reset"]:focus, input[type="button"]:focus {
  color: #333;
  border-color: #888;
  outline: 0;
}
.button.button-primary, button.button-primary, input[type="submit"].button-primary, input[type="reset"].button-primary, input[type="button"].button-primary {
  color: #FFF;
  background-color: #33C3F0;
  border-color: #33C3F0;
}
.button.button-primary:hover, button.button-primary:hover, input[type="submit"].button-primary:hover, input[type="reset"].button-primary:hover, input[type="button"].button-primary:hover, .button.button-primary:focus, button.button-primary:focus, input[type="submit"].button-primary:focus, input[type="reset"].button-primary:focus, input[type="button"].button-primary:focus {
  color: #FFF;
  background-color: #1EAEDB;
  border-color: #1EAEDB;
}
/* Forms –––––––––––––––––––––––––––––––––––––––––––––––––– */
input[type="email"], input[type="number"], input[type="search"], input[type="text"], input[type="tel"], input[type="url"], input[type="password"], textarea, select {
height: 38px;
  padding: 6px 10px;
 /* The 6px vertically centers text on FF, ignored by Webkit */
  background-color: #1f2733 !important;
  color: #f2f5fa !important;
  border: 1px solid #2d3748 !important;
  border-radius: 4px;
  box-shadow: none;
  box-sizing: border-box;
  font-family: inherit;
  font-size: inherit;
 /*https://stackoverflow.com/questions/6080413/why-doesnt-input-inherit-the-font-from-body*/
}
/* Removes awkward default styles on some inputs for iOS */
input[type="email"], input[type="number"], input[type="search"], input[type="text"], input[type="tel"], input[type="url"], input[type="password"], textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
textarea {
  min-height: 65px;
  padding-top: 6px;
  padding-bottom: 6px;
  background-color: #1f2733 !important;
  color: #f2f5fa !important;
  border: 1px solid #2d3748 !important;
}
input[type="email"]:focus, input[type="number"]:focus, input[type="search"]:focus, input[type="text"]:focus, input[type="tel"]:focus, input[type="url"]:focus, input[type="password"]:focus, textarea:focus, select:focus {
  border: 1px solid #F59410 !important;
  outline: 0;
  background-color: #1f2733 !important;
  color: #f2f5fa !important;
}

/* Placeholder text styling */
input::placeholder, textarea::placeholder {
  color: #99a0af !important;
  opacity: 1;
}

/* Dash Bootstrap Components Input styling */
.form-control, .form-control:focus {
  background-color: #1f2733 !important;
  color: #f2f5fa !important;
  border: 1px solid #2d3748 !important;
}

.form-control:focus {
  border-color: #F59410 !important;
  box-shadow: 0 0 0 0.2rem rgba(245, 148, 16, 0.25) !important;
}

.form-control::placeholder {
  color: #99a0af !important;
  opacity: 1;
}
label, legend {
  display: block;
  margin-bottom: 0px;
}
fieldset {
  padding: 0;
  border-width: 0;
}
input[type="checkbox"], input[type="radio"] {
  display: inline;
}
label > .label-body {
  display: inline-block;
  margin-left: .5rem;
  font-weight: normal;
}
/* Lists –––––––––––––––––––––––––––––––––––––––––––––––––– */
ul {
  list-style: circle inside;
}
ol {
  list-style: decimal inside;
}
ol, ul {
  padding-left: 0;
  margin-top: 0;
}
ul ul, ul ol, ol ol, ol ul {
  margin: 1.5rem 0 1.5rem 3rem;
  font-size: 90%;
}
li {
  margin-bottom: 1rem;
}
/* Tables –––––––––––––––––––––––––––––––––––––––––––––––––– */
table {
  border-collapse: collapse;
}
th, td {
  padding: 12px 15px;
  text-align: left;
  border-bottom: 1px solid #E1E1E1;
}
th:first-child, td:first-child {
  padding-left: 0;
}
th:last-child, td:last-child {
  padding-right: 0;
}
/* Spacing –––––––––––––––––––––––––––––––––––––––––––––––––– */
button, .button {
  margin-bottom: 0rem;
}
input, textarea, select, fieldset {
  margin-bottom: 0rem;
}
pre, dl, figure, table, form {
  margin-bottom: 0rem;
}
p, ul, ol {
  margin-bottom: 0.75rem;
}
/* Utilities –––––––––––––––––––––––––––––––––––––––––––––––––– */
.u-full-width {
  width: 100%;
  box-sizing: border-box;
}
.u-max-full-width {
  max-width: 100%;
  box-sizing: border-box;
}
.u-pull-right {
  float: right;
}
.u-pull-left {
  float: left;
}
/* Misc –––––––––––––––––––––––––––––––––––––––––––––––––– */
hr {
  margin-top: 3rem;
  margin-bottom: 3.5rem;
  border-width: 0;
  border-top: 1px solid #E1E1E1;
}
/* Clearing –––––––––––––––––––––––––––––––––––––––––––––––––– */
/* Self Clearing Goodness */
.container:after, .row:after, .u-cf {
  content: "";
  display: table;
  clear: both;
}
/* Media Queries –––––––––––––––––––––––––––––––––––––––––––––––––– */
/* Note: The best way to structure the use of media queries is to create the queries near the relevant code. For example, if you wanted to change the styles for buttons on small devices, paste the mobile query code up in the buttons section and style it there. */
/* Larger than mobile */
@media (min-width: 400px) {
}
/* Larger than phablet (also point when grid becomes active) */
@media (min-width: 550px) {
}
/* Larger than tablet */
@media (min-width: 750px) {
}
/* Larger than desktop */
@media (min-width: 1000px) {
}
/* Larger than Desktop HD */
@media (min-width: 1200px) {
}
/* Custom App CSS Below --------------------------------- */
/* Main Layout ––––––––––––––––––––––––––––––––––––––––––––––––––*/
html, body{
  height: 100%;
}

body {
  background-color: black;
  color: #d8d8d8;
  height: 100%;
  margin: 0;
  padding: 0;
}

.react-entry-point{
  height: 100%;
}

h1, h2, h3, h4, h5 {
  font-family: 'Roboto', sans-serif;
  letter-spacing: 1px;
  font-size: 21px;
  padding-left: 12px;
  font-weight: 500;
}
p {
  font-family: 'Roboto', sans-serif;
  font-weight: 400;
  font-size: 14px;
  padding-left: 12px;
}
a {
  text-decoration: none;
}
.bg-grey{
  background-color: #31302F;
}
.text-padding{
  padding: 5px;
}
/* Graph Layout ––––––––––––––––––––––––––––––––––––––––––––––––––*/
.div-for-charts{
  display: flex;
  flex-direction: column;
  height: 100vh;
  width: 100%;
}
#histogram {
  flex-grow: 1
}
#map-graph {
  flex-grow: 2
}
.mapboxgl-canvas, .mapboxgl-map {
  min-width: 100%;
}
/* Graph Control Objects ––––––––––––––––––––––––––––––––––––––––––––––––––*/
.div-user-controls {
  padding-left: 55px;
  padding-top: 64px;
}
.div-for-dropdown {
  padding-top: 12px;
  padding-bottom: 12px;
}
.div-for-slider {
  width: 97%;
  text-align: center;
}
.logo {
  height: 40px;
  padding-bottom: 12px;
}
/* Dash Dropdown Styles */
.Select-control, .Select-menu-outer, .Select-multi-value-wrapper, .select-up, .is-open .Select-control {
  background-color: #1f2733 !important;
  color: #f2f5fa !important;
}

#modelselector .Select-control{
  max-height: 82px;
  overflow-y: auto;
  margin: 0px 0px -3px 0px;
  border: 0.5px solid #dbdbdb44;
}

.Select-control{
  border: 0.5px solid #dbdbdb44 !important;
  background-color: #1f2733 !important;
}

/* Dropdown input text */
.Select-input > input {
  color: #f2f5fa !important;
}

/* Dropdown placeholder text */
.Select-placeholder, .Select--single > .Select-control .Select-value .Select-value-label {
  color: #cbd5e0 !important;
}

/* Selected value in dropdown */
.has-value.Select--single>.Select-control .Select-value .Select-value-label, 
.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value .Select-value-label {
  color: #f2f5fa !important;
  background: #1f2733 !important;
  background-color: #1f2733 !important;
}

/* Dropdown menu container */
.Select-menu-outer {
  background-color: #1f2733 !important;
  border: 0.5px solid #dbdbdb44 !important;
}

/* Dropdown menu options */
.Select-option {
  background-color: #1f2733 !important;
  color: #f2f5fa !important;
}

.Select-option:hover, .Select-option:focus {
  background-color: #2d3748 !important;
  color: #f2f5fa !important;
}

.Select-option.is-selected {
  background-color: #4a5568 !important;
  color: #f2f5fa !important;
}

.Select-option.is-focused {
  background-color: #2d3748 !important;
  color: #f2f5fa !important;
}

._dash-app-content {
  overflow-x: hidden;
  overflow-y: hidden;
  position: relative;
}
.has-value.Select--single>.Select-control .Select-value .Select-value-label, .has-value.is-pseudo-focused.Select--single>.Select-control .Select-value .Select-value-labeln {
  color: #f2f5fa !important;
  font-weight: 400;
  font-size: 14px;
}

.Input.DateInput_1 {
  background-color: #1e1e1e;
}

#date {
  background-color: #1e1e1e;
  font-family: 'Roboto', sans-serif;
  font-weight: 400;
  color: #dbdbdb;
  border: 0.5px solid #dbdbdb44;
}

#date-picker{
  width: 100%;
}

._dash-undo-redo {
  display: none;
}

/* Removed: .DateInput.DateInput_1{ width: 100%; } - was breaking DateRangePicker layout */

.SingleDatePickerInput__withBorder{
  border:none;
}

.DateInput.DateInput_1 {
  background-color: #1e1e1e;
}

.SingleDatePickerInput__withBorder {
  border-radius: 3px;
  color: #dbdbdb;
  background: #1e1e1e;
  background-color: #1e1e1e;
}

.SingleDatePickerInput.SingleDatePickerInput_1.SingleDatePickerInput__withBorder.SingleDatePickerInput__withBorder_2 {
  border: 0.0px solid #dbdbdb;
  display: block;
}

.SingleDatePicker_1 {
  border: 0.0px solid #dbdbdb;
  display: block;
}

.SingleDatePicker_picker, .SingleDatePicker_picker_1, .SingleDatePicker_picker__directionLeft,
.SingleDatePicker_picker__directionLeft_2{
  filter:invert(100%);
}

/* -------------------------------------------------------------------------- */
/* Modern DateRangePicker (Dash dcc.DatePickerRange / react-dates)             */
/* -------------------------------------------------------------------------- */

/* Wrapper used in layouts (see inscripciones/campanas) */
.filter-bar{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
  padding: 3px 6px;
  margin: 0 0 10px 0;
  background: rgba(31, 39, 51, 0.50);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 6px;
}

.filter-bar__label{
  color: rgba(242, 245, 250, 0.75);
  font-size: 11px;
  font-weight: 500;
  margin-right: 2px;
  white-space: nowrap;
}

/* Flexing dropdown inside filter bars (e.g., "Filtrar por curso") */
.filter-bar .filter-dropdown{
  flex: 1 1 360px;
  min-width: 240px;
  max-width: 100%;
  min-height: 0;
}

.filter-bar .filter-dropdown .Select{
  width: 100%;
}

.filter-bar .filter-dropdown .Select-control{
  min-width: 0;
}

/* DateRangePicker - force single row layout */
.date-range,
.date-range > div,
.DateRangePicker,
.DateRangePicker_1{
  display: inline-block !important;
}

.date-range .DateRangePickerInput,
.date-range .DateRangePickerInput_1,
.DateRangePickerInput,
.DateRangePickerInput_1{
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  background: transparent !important;
}

.date-range .DateRangePickerInput > *,
.DateRangePickerInput > *{
  display: inline-block !important;
  vertical-align: middle !important;
}

.date-range .DateRangePickerInput__withBorder,
.DateRangePickerInput__withBorder{
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  background: rgba(18, 22, 33, 0.8) !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  border-radius: 6px !important;
  padding: 0 4px !important;
  box-shadow: 0 0 0 0 rgba(245,148,16,0);
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.date-range .DateRangePickerInput__withBorder:hover,
.DateRangePickerInput__withBorder:hover{
  border-color: rgba(255, 255, 255, 0.16) !important;
  background: rgba(18, 22, 33, 0.92) !important;
}

.date-range .DateInput,
.date-range .DateInput_1,
.DateInput,
.DateInput_1{
  display: inline-block !important;
  background: transparent !important;
  width: auto !important;
  vertical-align: middle !important;
}

.date-range .DateInput_input,
.DateInput_input{
  background: transparent !important;
  color: rgba(242, 245, 250, 0.96) !important;
  font-family: 'Roboto', sans-serif;
  font-size: 12px !important;
  font-weight: 500 !important;
  padding: 4px 6px !important;
  border-radius: 4px !important;
  border: 0 !important;
  width: 90px !important;
  line-height: 16px !important;
}

.date-range .DateInput_input::placeholder,
.DateInput_input::placeholder{
  color: rgba(242, 245, 250, 0.50) !important;
  font-weight: 500 !important;
}

.date-range .DateInput_input__focused,
.DateInput_input__focused{
  outline: none !important;
  background: rgba(255, 255, 255, 0.04) !important;
}

.date-range .DateRangePickerInput__focused,
.date-range .DateRangePickerInput__withBorder.DateRangePickerInput__focused,
.DateRangePickerInput__focused{
  border-color: rgba(245, 148, 16, 0.55) !important;
  box-shadow: 0 0 0 3px rgba(245, 148, 16, 0.18) !important;
}

/* Separator + icons */
.date-range .DateRangePickerInput_arrow,
.DateRangePickerInput_arrow{
  padding: 0 4px !important;
  display: inline-flex !important;
  align-items: center !important;
}
.date-range .DateRangePickerInput_arrow_svg,
.DateRangePickerInput_arrow_svg{
  fill: rgba(242, 245, 250, 0.45) !important;
  height: 12px !important;
  width: 12px !important;
}

.date-range .DateRangePickerInput_clearDates,
.DateRangePickerInput_clearDates{
  margin: 0 !important;
  padding: 0 4px 0 2px !important;
  display: inline-flex !important;
  align-items: center !important;
}
.date-range .DateRangePickerInput_clearDates_svg,
.DateRangePickerInput_clearDates_svg{
  fill: rgba(242, 245, 250, 0.45) !important;
  height: 10px !important;
  width: 10px !important;
}
.date-range .DateRangePickerInput_clearDates:hover .DateRangePickerInput_clearDates_svg,
.DateRangePickerInput_clearDates:hover .DateRangePickerInput_clearDates_svg{
  fill: rgba(242, 245, 250, 0.85) !important;
}

/* Calendar popover (dark theme) */
.date-range .DateRangePicker_picker,
.DateRangePicker_picker{
  background: #151a25 !important;
  border-radius: 14px !important;
  box-shadow: 0 18px 60px rgba(0,0,0,0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  z-index: 9999 !important;
}

.date-range .DayPicker,
.DayPicker{
  background: #151a25 !important;
}
.date-range .DayPicker__withBorder,
.DayPicker__withBorder{
  box-shadow: none !important;
}
.date-range .CalendarMonth,
.CalendarMonth{
  background: #151a25 !important;
}
.date-range .CalendarMonth_caption,
.CalendarMonth_caption{
  color: rgba(242, 245, 250, 0.92) !important;
  font-weight: 700 !important;
}
.date-range .DayPicker_weekHeader_li,
.DayPicker_weekHeader_li{
  color: rgba(242, 245, 250, 0.55) !important;
}

.date-range .CalendarDay,
.CalendarDay{
  background: transparent !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  color: rgba(242, 245, 250, 0.90) !important;
}
.date-range .CalendarDay__outside,
.CalendarDay__outside{
  color: rgba(242, 245, 250, 0.25) !important;
}
.date-range .CalendarDay__blocked_out_of_range,
.CalendarDay__blocked_out_of_range{
  color: rgba(242, 245, 250, 0.22) !important;
  background: rgba(255, 255, 255, 0.02) !important;
}
.date-range .CalendarDay__default:hover,
.CalendarDay__default:hover{
  background: rgba(242, 245, 250, 0.06) !important;
  border-color: rgba(242, 245, 250, 0.16) !important;
}
.date-range .CalendarDay__selected,
.CalendarDay__selected{
  background: rgba(245, 148, 16, 0.85) !important;
  border-color: rgba(245, 148, 16, 0.95) !important;
  color: #0b0f18 !important;
}
.date-range .CalendarDay__selected_span,
.CalendarDay__selected_span{
  background: rgba(245, 148, 16, 0.20) !important;
  border-color: rgba(245, 148, 16, 0.35) !important;
  color: rgba(242, 245, 250, 0.92) !important;
}
.date-range .CalendarDay__hovered_span,
.CalendarDay__hovered_span{
  background: rgba(245, 148, 16, 0.14) !important;
  border-color: rgba(245, 148, 16, 0.25) !important;
  color: rgba(242, 245, 250, 0.92) !important;
}

.date-range .DayPickerNavigation_button,
.DayPickerNavigation_button{
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  border-radius: 10px !important;
}
.date-range .DayPickerNavigation_button:hover,
.DayPickerNavigation_button:hover{
  background: rgba(255, 255, 255, 0.08) !important;
}
.date-range .DayPickerNavigation_svg__horizontal,
.DayPickerNavigation_svg__horizontal{
  fill: rgba(242, 245, 250, 0.80) !important;
}

.date-range .DateInput_fangStroke,
.DateInput_fangStroke{
  stroke: rgba(255, 255, 255, 0.10) !important;
}
.date-range .DateInput_fangShape,
.DateInput_fangShape{
  fill: #151a25 !important;
}

@media (max-width: 768px){
  /* Keep single-row; allow horizontal scroll if screen is extremely narrow */
  .filter-bar{
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* For Mobile Phones and small screens ––––––––––––––––––––––––––––––––––––––––––––––––––*/
@media only screen and (max-width: 768px) {
  .four, .eight {
      min-width: 100%;
 }
  h1, h2, h3, p {
      text-align: center;
 }
  body {
      display: block;
      margin: 0px;
      overflow-y: scroll;
  }
  .div-for-charts {
      padding: 0px;
      width: 100%;
      text-align: center;
 }

 .div-user-controls {
    padding: 32px;
 }

 .side-by-side{
    display: inline-block;
    width: 48%;
  }


 .side-by-side-right{
    display: inline-block;
    width: 48%;
    float:right;
  }
  .div-for-charts{
    margin: 0px;
  }
}

/* width */
::-webkit-scrollbar {
  width: 10px !important;
  display: block !important;
}

/* Track */
::-webkit-scrollbar-track {
  background: #1e1e1e !important;
  border-radius: 10px !important;
  display: block !important;
}

/* Handle */
::-webkit-scrollbar-thumb {
  background: transparent;
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
  background: #d8d8d870 !important;
}

/* .DateRangePicker {
  padding: 1rem 5rem;
}

.DateRangePicker div {
  display: inline-flex;
  align-items: center;
  justify-content: center;
} */

.card {
  background-color: #3A3A3C;  /* quinary */
  color: white;
  margin: 1rem;
}

.card-header {
  background-color: rgba(58, 58, 60, 0.8);  /* quinary darker */
}

.card-title {
  font-weight: bold;
  font-size: 36px;
  margin-top: 0;
  margin-bottom: 7.5px;
}

/* Loading spinner styles */
.spinner-border {
  width: 3rem;
  height: 3rem;
  position: relative;
  display: inline-block;
}

.spinner-border::before,
.spinner-border::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 3px solid transparent;
  box-sizing: border-box;
}

.spinner-border::before {
  border-top-color: #F59410;  /* primary */
  border-right-color: #F59410;
  animation: spinner-rotate 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
}

.spinner-border::after {
  border-bottom-color: #CEA6FF;  /* tertiary */
  border-left-color: #8662B3;  /* secondary */
  animation: spinner-rotate 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
  animation-delay: 0.3s;
}

@keyframes spinner-rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.text-primary {
  color: #F59410 !important;  /* primary */
}

/* Dash loading spinner customization */
._dash-loading {
  margin: auto;
  color: transparent;
  width: 0;
  height: 0;
  text-align: center;
}

._dash-loading::after {
  content: '';
  display: inline-block;
  width: 2rem;
  height: 2rem;
  color: #F59410;  /* primary */
  vertical-align: text-bottom;
  border: .25em solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  -webkit-animation: spinner-border .75s linear infinite;
  animation: spinner-border .75s linear infinite;
}

/* Override Dash default loading colors */
.dash-loading {
  color: #F59410 !important;  /* primary */
}

/* Center loading indicators */
.dash-spinner {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 200px;
}

/* Loading overlay - only show when actually loading */
#loading-page {
  pointer-events: none;  /* Allow clicks through */
}

#loading-page.dash-loading-container--is-loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  background-color: rgba(58, 58, 60, 0.7);  /* quinary with opacity */
  pointer-events: auto;  /* Block clicks only when loading */
}

#loading-page > div {
  text-align: center;
}

/* Hide default Dash loading spinner */
#loading-page._dash-loading-callback {
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Custom loader */
.loader {
  --b: 25%;
  height: 40px;
  aspect-ratio: 1/cos(30deg);
  position: relative;
  clip-path: polygon(50% 0,100% 100%,0 100%,50% 0,50% var(--b),calc(var(--b)*cos(30deg)) calc(100% - var(--b)/2),calc(100% - var(--b)*cos(30deg)) calc(100% - var(--b)/2),50% var(--b));
  filter: blur(12px);
}
.loader:before {
  content: "";
  position: absolute;
  inset: -8% 0;
  background: conic-gradient(#0000 35%,#F59410,#0000 65%);
  animation: l5 2s linear infinite;
}
@keyframes l5 {
  to {rotate: 1turn}
}

/* Timeseries period toggle */
.graph-card-with-controls {
  width: 100%;
}

.graph-control-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  gap: 12px;
  flex-wrap: wrap;
}

.graph-control-label {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #99a0af;
}

.period-toggle {
  display: inline-flex;
  padding: 4px;
  border-radius: 999px;
  background-color: #1d2330;
  border: 1px solid #2f394d;
  gap: 0;
}

.period-toggle .form-check {
  margin: 0;
  position: relative;
}

.period-toggle-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.period-toggle-label {
  font-size: 12px;
  font-weight: 500;
  color: #a8b0c3;
  padding: 6px 14px;
  border-radius: 999px;
  transition: all 0.15s ease-in-out;
  cursor: pointer;
  user-select: none;
  display: block;
}
.period-toggle .form-check:not(:last-of-type) .period-toggle-label {
  margin-right: 2px;
}

.period-toggle-label:hover {
  color: #ffffff;
}

.period-toggle-label-checked {
  background: linear-gradient(120deg, #F59410, #ffbf5f);
  color: #11141d;
  box-shadow: 0 2px 8px rgba(245, 148, 16, 0.35);
}

/* Google Login Button Hover Effects */
.google-login-btn:hover {
  background-color: #f8f9fa !important;
  box-shadow: 0 1px 3px rgba(60, 64, 67, 0.302), 0 1px 2px rgba(60, 64, 67, 0.298) !important;
  border-color: #dadce0 !important;
}
.google-login-btn:active {
  background-color: #f1f3f4 !important;
  box-shadow: 0 1px 2px rgba(60, 64, 67, 0.3) !important;
  background-color: #ecf0f1 !important;
}
