@use "sass:color";
@use "sass:list";
@use "sass:map";
@use "sass:string";
@use "functions";

// Variables
//
// Variables should follow the `$component-state-property-size` formula for
// consistent naming. Ex: $nav-link-disabled-color and $modal-content-box-shadow-xs.

// ----------------------
// NEW VIZ ID COLORS 2024
// ----------------------

// Primary
$blue-50: #ddedff !default;
$blue-100: #c8dfff !default;
$blue-200: #a7c9ff !default;
$blue-300: #85b2ff !default;
$blue-400: #688aea !default;
$blue-500: #4a62d4 !default;
$blue-600: #2e46b9 !default;
$blue-700: #1d3297 !default;
$blue-800: #162676 !default;
$blue-900: #1b1763 !default;

$blues: () !default;
$blues: map.merge(
  (
    "blue-50": $blue-50,
    "blue-100": $blue-100,
    "blue-200": $blue-200,
    "blue-300": $blue-300,
    "blue-400": $blue-400,
    "blue-500": $blue-500,
    "blue-600": $blue-600,
    "blue-700": $blue-700,
    "blue-800": $blue-800,
    "blue-900": $blue-900,
  ),
  $blues
);

// Secondary
$orange-50:  #fff3df !default;
$orange-100: #ffe7ca !default;
$orange-200: #ffdbb5 !default;
$orange-300: #ffcea0 !default;
$orange-400: #ffc28b !default;
$orange-500: #ffb67b !default;
$orange-600: #ffaa66 !default;
$orange-700: #ff9d51 !default;
$orange-800: #ff9133 !default;
$orange-900: #ed7c2b !default;

$oranges: () !default;
$oranges: map.merge(
  (
    "orange-50": $orange-50,
    "orange-100": $orange-100,
    "orange-200": $orange-200,
    "orange-300": $orange-300,
    "orange-400": $orange-400,
    "orange-500": $orange-500,
    "orange-600": $orange-600,
    "orange-700": $orange-700,
    "orange-800": $orange-800,
    "orange-900": $orange-900,
  ),
  $oranges
);

// Neutrals
$gray-50:  #f1f3fb !default;
$gray-100: #eaecf4 !default;
$gray-200: #dfe1eb !default;
$gray-300: #cfd1df !default;
$gray-400: #a7aaba !default;
$gray-500: #878999 !default;
$gray-600: #646776 !default;
$gray-700: #515362 !default;
$gray-800: #323543 !default;
$gray-900: #222633 !default;

$neutrals: () !default;
$neutrals: map.merge(
  (
    "gray-50": $gray-50,
    "gray-100": $gray-100,
    "gray-200": $gray-200,
    "gray-300": $gray-300,
    "gray-400": $gray-400,
    "gray-500": $gray-500,
    "gray-600": $gray-600,
    "gray-700": $gray-700,
    "gray-800": $gray-800,
    "gray-900": $gray-900,
  ),
  $neutrals
);

// Success
$success-50:  #ccedd8 !default;
$success-500: #80ce97 !default;
$success-900: #00a759 !default;

$success-colors: () !default;
$success-colors: map.merge(
  (
    "success-50": $success-50,
    "success-500": $success-500,
    "success-900": $success-900,
  ),
  $success-colors
);

// Warning
$warning-50:  #f8efca !default;
$warning-500: #f4df83 !default;
$warning-900: #f4ca11 !default;

$warning-colors: () !default;
$warning-colors: map.merge(
  (
    "warning-50": $warning-50,
    "warning-500": $warning-500,
    "warning-900": $warning-900,
  ),
  $warning-colors
);

// Error
$error-50:  #f7d7db !default;
$error-500: #efa6af !default;
$error-900: #de3c50 !default;

$error-colors: () !default;
$error-colors: map.merge(
  (
    "error-50": $error-50,
    "error-500": $error-500,
    "error-900": $error-900,
  ),
  $error-colors
);

// Core Colors
$white:       #fff !default;
$soft-blue:   $blue-100 !default;
$medium-blue: $blue-300 !default;
$dark-blue:   $blue-900 !default;
$warm-orange: $orange-800 !default;

$core-colors: () !default;
$core-colors: map.merge(
  (
    "white":       $white,
    "soft-blue":   $soft-blue,
    "medium-blue": $medium-blue,
    "dark-blue":   $dark-blue,
    "warm-orange": $warm-orange,
  ),
  $core-colors
);

// ------------------------------------------------------
// OLD PRE-VIZ-ID COLORS - 2023 AND EARLIER
// all old variable names kept for backward compatibility
// ------------------------------------------------------

// Gray Scale (mapped to closest new gray using https://codepen.io/romainblatrix/pen/YXgBoO)
$gray-150:  $gray-100 !default; // exception to closest, keeping light-to-dark gradient
$gray-1000: $gray-900 !default;
$gray-1100: $gray-900 !default;
$gray-1200: $gray-900 !default;
$black:     #000 !default;

$grays: () !default;
$grays: map.merge(
  (
    "gray-100": $gray-100,
    "gray-150": $gray-150,
    "gray-200": $gray-200,
    "gray-300": $gray-300,
    "gray-400": $gray-400,
    "gray-500": $gray-500,
    "gray-600": $gray-600,
    "gray-700": $gray-700,
    "gray-800": $gray-800,
    "gray-900": $gray-900,
    "gray-1000": $gray-1000,
    "gray-1100": $gray-1100,
    "gray-1200": $gray-1200,
    "black": $black,
  ),
  $grays
);

// teal scale (mapped to closest blue using https://codepen.io/romainblatrix/pen/YXgBoO)
$teal-100: $blue-50 !default;
$teal-200: $blue-200 !default;
$teal-300: $blue-300 !default;
$teal-400: $blue-400 !default;
$teal-500: $blue-400 !default;
$teal-600: $blue-600 !default;
$teal-700: $blue-800 !default;
$teal-800: $blue-900 !default;

$teals: () !default;
$teals: map.merge(
  (
    "teal-100": $teal-100,
    "teal-200": $teal-200,
    "teal-300": $teal-300,
    "teal-400": $teal-400,
    "teal-500": $teal-500,
    "teal-600": $teal-600,
    "teal-700": $teal-700,
    "teal-800": $teal-800,
  ),
  $teals
);

// cyan scale (mapped to closest blue using https://codepen.io/romainblatrix/pen/YXgBoO)
$cyan-100: $blue-50 !default;
$cyan-200: $blue-100 !default;
$cyan-300: $blue-200 !default;
$cyan-400: $blue-500 !default;
$cyan-500: $blue-600 !default;
$cyan-600: $blue-700 !default;
$cyan-700: $blue-800 !default;
$cyan-800: $blue-900 !default;

$cyans: () !default;
$cyans: map.merge(
  (
    "cyan-100": $cyan-100,
    "cyan-200": $cyan-200,
    "cyan-300": $cyan-300,
    "cyan-400": $cyan-400,
    "cyan-500": $cyan-500,
    "cyan-600": $cyan-600,
    "cyan-700": $cyan-700,
    "cyan-800": $cyan-800,
  ),
  $cyans
);

// pink scale (mapped to closest orange using https://codepen.io/romainblatrix/pen/YXgBoO)
$pink-100: $orange-50 !default;
$pink-200: $orange-200 !default;
$pink-300: $orange-400 !default;
$pink-400: $orange-500 !default;
$pink-500: $orange-900 !default;
$pink-600: $orange-900 !default;
$pink-700: $orange-900 !default;
$pink-800: $orange-900 !default;

$pinks: () !default;
$pinks: map.merge(
  (
    "pink-100": $pink-100,
    "pink-200": $pink-200,
    "pink-300": $pink-300,
    "pink-400": $pink-400,
    "pink-500": $pink-500,
    "pink-600": $pink-600,
    "pink-700": $pink-700,
    "pink-800": $pink-800,
  ),
  $pinks
);

// yellow scale (mapped to closest orange using https://codepen.io/romainblatrix/pen/YXgBoO)
$yellow-100: $orange-50 !default;
$yellow-200: $orange-200 !default;
$yellow-300: $orange-400 !default;
$yellow-400: $orange-600 !default;
$yellow-500: $orange-700 !default;
$yellow-600: $orange-900 !default;
$yellow-700: $orange-900 !default;
$yellow-800: $orange-900 !default;

$yellows: () !default;
$yellows: map.merge(
  (
    "yellow-100": $yellow-100,
    "yellow-200": $yellow-200,
    "yellow-300": $yellow-300,
    "yellow-400": $yellow-400,
    "yellow-500": $yellow-500,
    "yellow-600": $yellow-600,
    "yellow-700": $yellow-700,
    "yellow-800": $yellow-800,
  ),
  $yellows
);

// Base Colors (mapped to closest appropriate color using https://codepen.io/romainblatrix/pen/YXgBoO)
$blue:      $blue-600 !default;
$lightblue: $blue-200 !default;
$grayblue:  $blue-100 !default;
$indigo:    $blue-700 !default;
$purple:    $blue-600 !default;
$red:       $error-900 !default;
$orange:    $orange-800 !default;
$green:     $success-900 !default;
$pink:      $orange-800 !default;
$yellow:    $orange-800 !default;
$cyan:      $blue-900 !default;
$teal:      $blue-300 !default;
$gray:      $gray-900 !default;

$brand-colors: () !default;
$brand-colors: map.merge(
  (
    "cyan":      $cyan,
    "gray":      $gray,
    "pink":      $pink,
    "teal":      $teal,
    "yellow":    $yellow,
    "orange":    $orange
  ),
  $brand-colors
);

$colors: () !default;
$colors: map.merge(
  (
    "blue":       $blue,
    "light-blue": $lightblue,
    "gray-blue":  $grayblue,
    "indigo":     $indigo,
    "purple":     $purple,
    "pink":       $pink,
    "red":        $red,
    "orange":     $orange,
    "yellow":     $yellow,
    "green":      $green,
    "teal":       $teal,
    "cyan":       $cyan,
    "white":      $white,
    "gray":       $gray,
    "gray-dark":  $gray-800,
  ),
  $colors
);

$primary:       $cyan !default;
$secondary:     $gray !default;
$success:       $green !default;
$info:          $blue-300 !default;
$warning:       $warning-900 !default;
$danger:        $red !default;
$light:         $gray-200 !default;
$dark:          $gray-900 !default;
$mid:           $gray-300 !default;
$mid-dark:      $gray-600 !default;
$highlight:     $indigo;
$highlight-dark: $blue;

$theme-colors: () !default;
$theme-colors: map.merge(
  (
    "primary":    $primary,
    "secondary":  $secondary,
    "success":    $success,
    "info":       $info,
    "warning":    $warning,
    "danger":     $danger,
    "light":      $light,
    "dark":       $dark,
    "mid":        $mid,
    "mid-dark":   $mid-dark,
    "highlight":  $highlight,
    "highlight-dark": $highlight-dark,
  ),
  $theme-colors
);

// Set a specific jump point for requesting color jumps
$theme-color-interval:      8% !default;

// Options
//
// Quickly modify global styling by enabling or disabling optional features.

$enable-caret:                                true !default;
$enable-rounded:                              true !default;
$enable-shadows:                              false !default;
$enable-gradients:                            false !default;
$enable-transitions:                          true !default;
$enable-prefers-reduced-motion-media-query:   true !default;
$enable-hover-media-query:                    false !default; // Deprecated, no longer affects any compiled CSS
$enable-grid-classes:                         true !default;
$enable-pointer-cursor-for-buttons:           true !default;
$enable-print-styles:                         true !default;
$enable-responsive-font-sizes:                false !default;
$enable-validation-icons:                     true !default;
$enable-deprecation-messages:                 false !default;


// Spacing
//
// Control the default styling of most Bootstrap elements by modifying these
// variables. Mostly focused on spacing.
// You can add more entries to the $spacers map, should you need more variation.

$spacer: 1rem !default;

$spacers: () !default;
$spacers: map.merge(
  (
    0:    0,
    // deprecated
    1:   ($spacer * .25), // 4
    2:   ($spacer * .5),  // 8
    3:    $spacer,        // 16
    4:   ($spacer * 2),   // 32
    5:   ($spacer * 4.5), // 72
    6:   ($spacer * 8),   // 128
    450: ($spacer * 4.5), // 72
    // standard
    25:  ($spacer * .25), // 4
    50:  ($spacer * .5),  // 8
    100:  $spacer,        // 16
    150: ($spacer * 1.5), // 24
    200: ($spacer * 2),   // 32
    300: ($spacer * 3),   // 48
    400: ($spacer * 4),   // 64
    500: ($spacer * 5),   // 80
    600: ($spacer * 6),   // 96
    800: ($spacer * 8)    // 128
  ),
  $spacers
);

// This variable affects the `.h-*` and `.w-*` classes.
$sizes: () !default;
$sizes: map.merge(
  (
    25: 25%,
    50: 50%,
    75: 75%,
    100: 100%,
    auto: auto
  ),
  $sizes
);

// Typography base
//
// Foundational variables relating to typography.

// stylelint-disable value-keyword-case
$font-family-sans-serif:      "Plus Jakarta Sans", "Helvetica Neue", Roboto, "Segoe UI", -apple-system, BlinkMacSystemFont, Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" !default;
$font-family-monospace:       SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace !default;
$font-family-base:            $font-family-sans-serif !default;
// stylelint-enable value-keyword-case

$font-size-base:              1rem !default; // Assumes the browser default, typically `16px`

$font-size-50:                $font-size-base * 0.75 !default;   // 12px
$font-size-75:                $font-size-base * 0.875 !default;  // 14px
$font-size-100:               $font-size-base !default;          // 16px
$font-size-200:               $font-size-base * 1.125 !default;  // 18px
$font-size-300:               $font-size-base * 1.25 !default;   // 20px
$font-size-400:               $font-size-base * 1.5 !default;    // 24px
$font-size-500:               $font-size-base * 1.875 !default;  // 30px
$font-size-600:               $font-size-base * 2.375 !default;  // 38px
$font-size-700:               $font-size-base * 3 !default;      // 48px
$font-size-800:               $font-size-base * 3.375 !default;  // 54px
$font-size-900:               $font-size-base * 3.875 !default;  // 62px

$line-height-50:              $font-size-base * 1.125 !default;  // 18px
$line-height-75:              $font-size-base * 1.25 !default;   // 20px
$line-height-100:             $font-size-base * 1.5 !default;    // 24px
$line-height-200:             $font-size-base * 1.5 !default;    // 24px
$line-height-300:             $font-size-base * 1.75 !default;   // 28px
$line-height-400:             $font-size-base * 1.75 !default;   // 28px
$line-height-500:             $font-size-base * 2.25 !default;   // 36px
$line-height-600:             $font-size-base * 3 !default;      // 48px
$line-height-700:             $font-size-base * 3.5 !default;    // 56px
$line-height-800:             $font-size-base * 4 !default;      // 64px
$line-height-900:             $font-size-base * 4.375 !default;  // 70px

$font-size-xs:                $font-size-50 !default;            // 12px
$font-size-sm:                $font-size-75 !default;            // 14px
$font-size-lg:                $font-size-300 !default;           // 20px

// deprecated
$font-size-xl:                $font-size-400 !default;           // 24px
$font-size-xxl:               $font-size-500 !default;           // 30px

// used in font-size-* utility classes
$font-sizes: (
  "50":   $font-size-50,
  "75":   $font-size-75,
  "100":  $font-size-100,
  "200":  $font-size-200,
  "300":  $font-size-300,
  "400":  $font-size-400,
  "500":  $font-size-500,
  "600":  $font-size-600,
  "700":  $font-size-700,
  "800":  $font-size-800,
  "900":  $font-size-900,
  // body sizes
  "xs":   $font-size-xs,
  "sm":   $font-size-sm,
  "base": $font-size-base,
  "lg":   $font-size-lg,
  // deprecated
  "xl":   $font-size-xl,
  "xxl":  $font-size-xxl,
);

$line-heights: (
  "50":   $line-height-50,
  "75":   $line-height-75,
  "100":  $line-height-100,
  "200":  $line-height-200,
  "300":  $line-height-300,
  "400":  $line-height-400,
  "500":  $line-height-500,
  "600":  $line-height-600,
  "700":  $line-height-700,
  "800":  $line-height-800,
  "900":  $line-height-900,
  // body sizes
  "xs":   $line-height-50,
  "sm":   $line-height-75,
  "base": $line-height-100,
  "lg":   $line-height-300,
  // deprecated
  "xl":   $line-height-400,
  "xxl":  $line-height-500,
);

// fusv-disable
$font-weight-lightest:        lighter;
// fusv-enable
$font-weight-lighter:         200 !default;
$font-weight-light:           300 !default;
$font-weight-normal:          400 !default;
$font-weight-semibold:        500 !default;
$font-weight-bold:            600 !default;
$font-weight-bolder:          700 !default;
$font-weight-boldest:         800 !default;

$font-weight-base:            $font-weight-normal !default;
$line-height-base:            1.5 !default;

// Body
//
// Settings for the `<body>` element.

$body-bg:                   $white !default;
$body-color:                $gray-900 !default;


// Links
//
// Style anchor elements.

$link-color:                              $blue-600 !default;
$link-decoration:                         none !default;
$link-hover-color:                        $blue-600 !default;
$link-hover-decoration:                   underline !default;
$link-visited-color:                      $blue-800 !default;
$link-weight:                             $font-weight-semibold !default;
// Darken percentage for links with `.text-*` class (e.g. `.text-success`)
$emphasized-link-hover-darken-percentage: 15% !default;

// Paragraphs
//
// Style p element.

$paragraph-margin-bottom:   1rem !default;


// Grid breakpoints
//
// Define the minimum dimensions at which your layout will change,
// adapting to different screen sizes, for use in media queries.

$grid-breakpoints: (
  xs: 0,
  sm: 576px,
  md: 768px,
  lg: 992px,
  xl: 1200px,
  xxl: 1900px
) !default;

@include functions.assert-ascending($grid-breakpoints, "$grid-breakpoints");
@include functions.assert-starts-at-zero($grid-breakpoints, "$grid-breakpoints");


// Grid containers
//
// Define the maximum width of `.container` for different screen sizes.

$container-max-widths: (
  sm: 540px,
  md: 720px,
  lg: 960px,
  xl: 1140px,
  xxl: 1440px
) !default;

@include functions.assert-ascending($container-max-widths, "$container-max-widths");


// Grid columns
//
// Set the number of columns and specify the width of the gutters.

$grid-columns:                12 !default;
$grid-gutter-width:           30px !default;
$grid-row-columns:            6 !default;


// Components
//
// Define common padding and border radius sizes and more.

$line-height-lg:              1.5 !default;
$line-height-sm:              1.5 !default;

$border-width:                1px !default;
$border-color:                $gray-300 !default;

$border-radius-xs:            .25rem !default;
$border-radius-sm:            .5rem !default;
$border-radius:               .75rem !default;
$border-radius-lg:            1rem !default;

$rounded-pill:                50rem !default;

$box-shadow: 0 4px 12px $gray-300 !default;
$box-shadow-sm: $box-shadow !default;
$box-shadow-lg: $box-shadow !default;

$component-active-color:      $white !default;
$component-active-bg:         $dark-blue !default;

$caret-width:                 .4em !default;
$caret-vertical-align:        $caret-width * .85 !default;
$caret-spacing:               $caret-width * .85 !default;

$transition-base:             all .2s ease-in-out !default;
$transition-fade:             opacity .15s linear !default;
$transition-collapse:         height .35s ease !default;

$embed-responsive-aspect-ratios: () !default;
$embed-responsive-aspect-ratios: list.join(
  (
    (21 9),
    (16 9),
    (4 3),
    (1 1),
  ),
  $embed-responsive-aspect-ratios
);

// Typography elements
//
// Font, line-height, and color for body text, headings, and more.

$h1-font-size:                $font-size-400 !default;
$h2-font-size:                $font-size-300 !default;
$h3-font-size:                $font-size-200 !default;
$h4-font-size:                $font-size-100 !default;
$h5-font-size:                $font-size-75 !default;
// deprecated
$h6-font-size:                $font-size-75 !default;

$h1-line-height:              $line-height-400 !default;
$h2-line-height:              $line-height-300 !default;
$h3-line-height:              $line-height-200 !default;
$h4-line-height:              $line-height-100 !default;
$h5-line-height:              $line-height-75 !default;
// deprecated
$h6-line-height:              $line-height-75 !default;

$h1-font-size-desktop:        $font-size-600 !default;
$h2-font-size-desktop:        $font-size-500 !default;
$h3-font-size-desktop:        $font-size-400 !default;
$h4-font-size-desktop:        $font-size-300 !default;
$h5-font-size-desktop:        $font-size-100 !default;
// deprecated
$h6-font-size-desktop:        $font-size-100 !default;

$h1-line-height-desktop:      $line-height-600 !default;
$h2-line-height-desktop:      $line-height-500 !default;
$h3-line-height-desktop:      $line-height-400 !default;
$h4-line-height-desktop:      $line-height-300 !default;
$h5-line-height-desktop:      $line-height-100 !default;
// deprecated
$h6-line-height-desktop:      $line-height-100 !default;

$headings-margin-bottom:      1rem !default;
$headings-font-family:        $font-family-sans-serif !default;
$headings-font-weight:        $font-weight-bold !default;
$headings-line-height:        1.2 !default; // no longer used, in favor of specific per font size
$headings-color:              $gray-900 !default;
// fusv-disable
$headings-font-family-higher: null;
// fusv-enable

// poster type sizing
$post1-font-size:             $font-size-700 !default;
$post2-font-size:             $font-size-600 !default;
$post3-font-size:             $font-size-500 !default;

$post1-line-height:           $line-height-700 !default;
$post2-line-height:           $line-height-600 !default;
$post3-line-height:           $line-height-500 !default;

$post1-font-size-desktop:     $font-size-900 !default;
$post2-font-size-desktop:     $font-size-800 !default;
$post3-font-size-desktop:     $font-size-700 !default;

$post1-line-height-desktop:   $line-height-900 !default;
$post2-line-height-desktop:   $line-height-800 !default;
$post3-line-height-desktop:   $line-height-700 !default;

$post-font-weight:            $font-weight-bolder !default;

// eyebrow
$eyebrow-font-color:          $blue-900 !default;
$eyebrow-font-size:           $font-size-100 !default;
$eyebrow-line-height:         $line-height-100 !default;
$eyebrow-margin-bottom:       0.5rem !default;
$eyebrow-font-weight:         $font-weight-bold !default;
$eyebrow-letter-spacing:      0.08rem !default;

// deprecated "display" type sizing
$display1-size:               5rem !default;
$display2-size:               4.5rem !default;
$display3-size:               4rem !default;
$display4-size:               3.5rem !default;

$display1-weight:             300 !default;
$display2-weight:             300 !default;
$display3-weight:             300 !default;
$display4-weight:             300 !default;
$display-line-height:         $headings-line-height !default;

$lead-font-size:              $font-size-base * 1.25 !default;
$lead-font-weight:            300 !default;

$small-font-size:             .875em !default;

$text-muted:                  $gray-600 !default;

$blockquote-small-color:      $gray-600 !default;
$blockquote-small-font-size:  $small-font-size !default;
$blockquote-font-size:        $font-size-base * 1.25 !default;

$hr-border-color:             rgba($black, .1) !default;
$hr-border-width:             $border-width !default;

$mark-padding:                .2em !default;

$dt-font-weight:              $font-weight-bold !default;

$kbd-box-shadow:              inset 0 -.1rem 0 rgba($black, .25) !default;
$nested-kbd-font-weight:      $font-weight-bold !default;

$list-inline-padding:         .5rem !default;

$mark-bg:                     #fcf8e3 !default;

$hr-margin-y:                 $spacer !default;


// Tables
//
// Customizes the `.table` component with basic values, each used across all table variations.

$table-cell-padding:          1rem !default;
$table-cell-padding-sm:       .3rem !default;

$table-color:                 $body-color !default;
$table-bg:                    null !default;
$table-accent-bg:             rgba($black, .05) !default;
$table-hover-color:           $table-color !default;
$table-hover-bg:              rgba($black, .075) !default;
$table-active-bg:             $table-hover-bg !default;

$table-border-width:          $border-width !default;
$table-border-color:          $border-color !default;
$table-border-radius:         $border-radius !default;

$table-head-bg:               $gray-200 !default;
$table-head-color:            $gray-700 !default;
$table-th-font-weight:        null !default;

$table-dark-color:            $white !default;
$table-dark-bg:               $gray-800 !default;
$table-dark-accent-bg:        rgba($white, .05) !default;
$table-dark-hover-color:      $table-dark-color !default;
$table-dark-hover-bg:         rgba($white, .075) !default;
$table-dark-border-color:     color.adjust($table-dark-bg, $lightness: 7.5%) !default;

$table-striped-order:         odd !default;

$table-caption-color:         $text-muted !default;

$table-bg-level:              -9 !default;
$table-border-level:          -6 !default;


// Buttons + Forms
//
// Shared variables that are reassigned to `$input-` and `$btn-` specific variables.

$input-btn-padding-y:         1rem !default;
$input-btn-padding-x:         1rem !default;
$input-btn-font-family:       $font-family-sans-serif !default;
$input-btn-font-size:         $font-size-base !default;
$input-btn-line-height:       1.2 !default;
$input-btn-height:            $font-size-base * 3.5 !default;

$input-btn-focus-width:       0 !default;
$input-btn-focus-color:       rgba($component-active-bg, .25) !default;
$input-btn-focus-box-shadow:  0 0 0 $input-btn-focus-width $input-btn-focus-color !default;

$input-btn-padding-y-sm:      .15rem !default;
$input-btn-padding-x-sm:      1rem !default;
$input-btn-font-size-sm:      $font-size-base * 0.875 !default;
$input-btn-line-height-sm:    1.2 !default;
$input-btn-height-sm:         $font-size-base * 2.25 !default;

$input-btn-padding-y-lg:      .5rem !default;
$input-btn-padding-x-lg:      1.5rem !default;
$input-btn-font-size-lg:      $font-size-base !default;
$input-btn-line-height-lg:    $line-height-lg !default;

$input-btn-border-width:      1px !default;


// Buttons
//
// For each of Bootstrap's buttons, define text, background, and border color.

$button-colors: () !default;
$button-colors: map.merge(
  (
    "primary":           $blue-600,
    "secondary":         $blue-600,
    "dark":              $blue-600,
    "dark-bg":           $orange-700,
  ),
  $button-colors
);

$button-outline-bg-colors: () !default;
$button-outline-bg-colors: map.merge(
  (
    "outline-primary":   $white,
    "outline-secondary": $white,
    "outline-dark":      $white,
    "outline-dark-bg":   transparent,
  ),
  $button-outline-bg-colors
);

$button-outline-border-colors: () !default;
$button-outline-border-colors: map.merge(
  (
    "outline-primary":   $blue-600,
    "outline-secondary": $blue-600,
    "outline-dark":      $blue-600,
    "outline-dark-bg":   $white,
  ),
  $button-outline-border-colors
);

$button-text-colors: () !default;
$button-text-colors: map.merge(
  (
    "primary":           $white,
    "secondary":         $white,
    "dark":              $white,
    "outline-primary":   $blue-600,
    "outline-secondary": $blue-600,
    "outline-dark":      $blue-600,
    "dark-bg":           $blue-900,
    "outline-dark-bg":   $white,
  ),
  $button-text-colors
);

$button-hover-colors: () !default;
$button-hover-colors: map.merge(
  (
    "primary":           $blue-700,
    "secondary":         $blue-700,
    "dark":              $blue-700,
    "outline-primary":   $blue-50,
    "outline-secondary": $blue-50,
    "outline-dark":      $blue-50,
    "dark-bg":           $orange-800,
    "outline-dark-bg":   transparent,
  ),
  $button-hover-colors
);

$button-outline-hover-border-colors: () !default;
$button-outline-hover-border-colors: map.merge(
  (
    "outline-primary":   $blue-600,
    "outline-secondary": $blue-600,
    "outline-dark":      $blue-600,
    "outline-dark-bg":   $blue-50,
  ),
  $button-outline-hover-border-colors
);

$button-active-colors: () !default;
$button-active-colors: map.merge(
  (
    "primary":           $blue-800,
    "secondary":         $blue-800,
    "dark":              $blue-800,
    "outline-primary":   $blue-200,
    "outline-secondary": $blue-200,
    "outline-dark":      $blue-200,
    "dark-bg":           $orange-900,
    "outline-dark-bg":   transparent,
  ),
  $button-active-colors
);

$button-outline-active-border-colors: () !default;
$button-outline-active-border-colors: map.merge(
  (
    "outline-primary":   $blue-600,
    "outline-secondary": $blue-600,
    "outline-dark":      $blue-600,
    "outline-dark-bg":   $blue-200,
  ),
  $button-outline-active-border-colors
);

$button-focus-border-colors: () !default;
$button-focus-border-colors: map.merge(
  (
    "primary":           $blue-100,
    "secondary":         $blue-100,
    "dark":              $blue-100,
    "outline-primary":   $blue-600,
    "outline-secondary": $blue-600,
    "outline-dark":      $blue-600,
    "dark-bg":           $blue-100,
    "outline-dark-bg":   $blue-50,
  ),
  $button-focus-border-colors
);

$button-disabled-colors: () !default;
$button-disabled-colors: map.merge(
  (
    "primary":           $gray-200,
    "secondary":         $gray-200,
    "dark":              $gray-200,
    "outline-primary":   $white,
    "outline-secondary": $white,
    "outline-dark":      $white,
    "dark-bg":           $orange-100,
    "outline-dark-bg":   $gray-400,
  ),
  $button-disabled-colors
);

$button-disabled-font-colors: () !default;
$button-disabled-font-colors: map.merge(
  (
    "primary":           $gray-500,
    "secondary":         $gray-500,
    "dark":              $gray-500,
    "outline-primary":   $gray-500,
    "outline-secondary": $gray-500,
    "outline-dark":      $gray-500,
    "dark-bg":           $orange-400,
    "outline-dark-bg":   $gray-400,
  ),
  $button-disabled-font-colors
);

$btn-primary-box-shadow: 0 5px 10px 0 $blue-100 !default;
$btn-primary-active-box-shadow: 0 4px 10px 0 $blue-100 !default;
$btn-dark-bg-box-shadow: 0 5px 10px 0 rgba(255, 145, 51, 0.25);
$btn-dark-bg-active-box-shadow: 0 4px 10px 0 rgba(255, 145, 51, 0.25);

$button-box-shadows: () !default;
$button-box-shadows: map.merge(
  (
    "primary":           $btn-primary-box-shadow,
    "secondary":         $btn-primary-box-shadow,
    "dark":              $btn-primary-box-shadow,
    "outline-primary":   $btn-primary-box-shadow,
    "outline-secondary": $btn-primary-box-shadow,
    "outline-dark":      $btn-primary-box-shadow,
    "dark-bg":           $btn-dark-bg-box-shadow,
    "outline-dark-bg":   none,
  ),
  $button-box-shadows
);

$button-active-box-shadows: () !default;
$button-active-box-shadows: map.merge(
  (
    "primary":           $btn-primary-active-box-shadow,
    "secondary":         $btn-primary-active-box-shadow,
    "dark":              $btn-primary-active-box-shadow,
    "outline-primary":   $btn-primary-active-box-shadow,
    "outline-secondary": $btn-primary-active-box-shadow,
    "outline-dark":      $btn-primary-active-box-shadow,
    "dark-bg":           $btn-dark-bg-active-box-shadow,
    "outline-dark-bg":   none,
  ),
  $button-active-box-shadows
);

$btn-padding-y:               $input-btn-padding-y !default;
$btn-padding-x:               1.5rem !default; // default button x padding is different from inputs
$btn-font-family:             $input-btn-font-family !default;
$btn-font-size:               $input-btn-font-size !default;
$btn-line-height:             $input-btn-line-height !default;
$btn-white-space:             null !default; // Set to `nowrap` to prevent text wrapping

$btn-padding-y-sm:            $input-btn-padding-y-sm !default;
$btn-padding-x-sm:            $input-btn-padding-x-sm !default;
$btn-font-size-sm:            $input-btn-font-size-sm !default;
$btn-line-height-sm:          $input-btn-line-height-sm !default;

// fusv-disable
$btn-padding-y-lg:            $input-btn-padding-y-lg !default;
// fusv-enable
$btn-padding-x-lg:            $input-btn-padding-x-lg !default;
// fusv-disable
$btn-font-size-lg:            $input-btn-font-size-lg !default;
$btn-line-height-lg:          $input-btn-line-height-lg !default;
// fusv-enable

$btn-border-width:            2px !default;

$btn-font-weight:             $font-weight-bolder !default;
$btn-box-shadow:              0 5px 10px 0 $blue-100 !default;
$btn-focus-width:             $input-btn-focus-width !default;
$btn-focus-box-shadow:        0 !default;
$btn-disabled-opacity:        1 !default;
$btn-active-box-shadow:       0 !default;
$btn-active-transform:        translateY(1px) !default;

$btn-disabled-bg-color:       $gray-200 !default;
$btn-disabled-border-color:   $gray-400 !default;
$btn-disabled-font-color:     $gray-500 !default;
$btn-link-disabled-color:     $gray-500 !default;

$btn-block-spacing-y:         .5rem !default;

// Allows for customizing button radius independently from global border radius
$btn-border-radius:           $border-radius !default;
// fusv-disable
$btn-border-radius-lg:        $border-radius !default; // not currently used
$btn-border-radius-sm:        $border-radius !default; // not currently used
// fusv-enable

$btn-transition:              color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out !default;


// Forms

$label-margin-bottom:                   .5rem !default;

$input-padding-y:                       $input-btn-padding-y !default;
$input-padding-x:                       $input-btn-padding-x !default;
$input-font-family:                     $input-btn-font-family !default;
$input-font-size:                       $input-btn-font-size !default;
$input-font-weight:                     $font-weight-base !default;
$input-line-height:                     $input-btn-line-height !default;

$input-padding-y-sm:                    $input-btn-padding-y-sm !default;
$input-padding-x-sm:                    $input-btn-padding-x-sm !default;
$input-font-size-sm:                    $input-btn-font-size-sm !default;
$input-line-height-sm:                  $input-btn-line-height-sm !default;

$input-padding-y-lg:                    $input-btn-padding-y-lg !default;
$input-padding-x-lg:                    $input-btn-padding-x-lg !default;
$input-font-size-lg:                    $input-btn-font-size-lg !default;
$input-line-height-lg:                  $input-btn-line-height-lg !default;

$input-bg:                              $white !default;
$input-disabled-bg:                     $gray-100 !default;
$input-disabled-color:                  $gray-500 !default;

$input-color:                           $gray-900 !default;
// fusv-disable
$input-color-placeholder:               $gray-700 !default;
// fusv-enable
$input-border-color:                    $gray-900 !default;
$input-border-width:                    $input-btn-border-width !default;
$input-box-shadow:                      inset 0 1px 1px rgba($black, .075) !default;

$input-border-radius:                   $border-radius-xs !default;
$input-border-radius-lg:                $border-radius-lg !default;
$input-border-radius-sm:                $border-radius-sm !default;

$input-focus-bg:                        $input-bg !default;
$input-focus-border-color:              $medium-blue !default;
$input-focus-color:                     $input-color !default;
$input-focus-width:                     $input-btn-focus-width !default;
$input-focus-box-shadow:                $input-btn-focus-box-shadow !default;

$input-placeholder-color:               $gray-600 !default;
$input-plaintext-color:                 $body-color !default;

$input-height-border:                   $input-border-width * 2 !default;

$input-height-inner:                    functions.add($input-line-height * 1em, $input-padding-y * 2) !default;
$input-height-inner-half:               functions.add($input-line-height * .5em, $input-padding-y) !default;
$input-height-inner-quarter:            functions.add($input-line-height * .25em, $input-padding-y * .5) !default;

$input-height:                          $input-btn-height !default;
$input-height-sm:                       functions.add($input-line-height-sm * 1em, functions.add($input-padding-y-sm * 2, $input-height-border, false)) !default;
$input-height-lg:                       functions.add($input-line-height-lg * 1em, functions.add($input-padding-y-lg * 2, $input-height-border, false)) !default;

$input-transition:                      border-color .15s ease-in-out, box-shadow .15s ease-in-out !default;

$form-text-margin-top:                  .25rem !default;

$form-check-input-gutter:               1.25rem !default;
$form-check-input-margin-y:             .3rem !default;
$form-check-input-margin-x:             .25rem !default;

$form-check-inline-margin-x:            .75rem !default;
$form-check-inline-input-margin-x:      .3125rem !default;

$form-grid-gutter-width:                10px !default;
$form-group-margin-bottom:              1rem !default;

$input-group-addon-color:               $input-color !default;
$input-group-addon-bg:                  $gray-200 !default;
$input-group-addon-border-color:        $input-border-color !default;

$custom-forms-transition:               background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out !default;

$custom-control-gutter:                 1rem !default;
$custom-control-spacer-x:               2rem !default;
$custom-control-cursor:                 null !default;

$custom-control-indicator-size:         1rem !default;
$custom-control-indicator-bg:           $input-bg !default;

$custom-control-indicator-bg-size:      50% 50% !default;
$custom-control-indicator-box-shadow:   $input-box-shadow !default;
$custom-control-indicator-border-color: $gray-800 !default;
$custom-control-indicator-border-width: 2px !default;

$custom-control-label-color:            null !default;

$custom-control-indicator-disabled-bg:          $white !default;
$custom-control-label-disabled-color:           $gray-500 !default;

$custom-control-indicator-checked-color:        $component-active-color !default;
$custom-control-indicator-checked-bg:           $component-active-bg !default;
$custom-control-indicator-checked-disabled-bg:  $white !default;

$custom-control-indicator-checked-box-shadow:   null !default;
$custom-control-indicator-checked-border-color: $custom-control-indicator-checked-bg !default;

$custom-control-indicator-hover-box-shadow:     0 0 0 10px $blue-50 !default;

$custom-control-indicator-focus-box-shadow:     0 0 0 10px $blue-300 !default;
$custom-control-indicator-focus-border-color:   $input-focus-border-color !default;

$custom-control-indicator-active-color:         $component-active-color !default;
$custom-control-indicator-active-bg:            $white !default;

$custom-control-indicator-active-box-shadow:    0 0 0 10px $blue-50 !default;
$custom-control-indicator-active-border-color:  $custom-control-indicator-border-color !default;

$custom-checkbox-indicator-border-radius:         0.125rem !default;
$custom-checkbox-indicator-icon-checked:          url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='7 8 10 8'><path fill-rule='evenodd' clip-rule='evenodd' d='M16.723 8.237a.94.94 0 0 1 .053 1.277l-5.366 6.193a.834.834 0 0 1-.611.293.83.83 0 0 1-.622-.264L7.25 12.639a.94.94 0 0 1 0-1.278.821.821 0 0 1 1.207 0l2.297 2.43 4.763-5.498a.821.821 0 0 1 1.206-.056Z' fill='#{$custom-control-indicator-checked-color}'/></svg>") !default;
$custom-checkbox-indicator-icon-checked-disabled: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='7 8 10 8'><path fill-rule='evenodd' clip-rule='evenodd' d='M16.723 8.237a.94.94 0 0 1 .053 1.277l-5.366 6.193a.834.834 0 0 1-.611.293.83.83 0 0 1-.622-.264L7.25 12.639a.94.94 0 0 1 0-1.278.821.821 0 0 1 1.207 0l2.297 2.43 4.763-5.498a.821.821 0 0 1 1.206-.056Z' fill='#{$custom-control-label-disabled-color}'/></svg>") !default;

$custom-checkbox-indicator-indeterminate-bg:           $component-active-bg !default;
$custom-checkbox-indicator-indeterminate-color:        $custom-control-indicator-checked-color !default;
$custom-checkbox-indicator-icon-indeterminate:         url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='4' height='4' viewBox='0 0 4 4'><path stroke='#{$custom-checkbox-indicator-indeterminate-color}' d='M0 2h4'/></svg>") !default;
$custom-checkbox-indicator-indeterminate-box-shadow:   null !default;
$custom-checkbox-indicator-indeterminate-border-color: $custom-checkbox-indicator-indeterminate-bg !default;

$custom-radio-indicator-border-radius:          50% !default;
$custom-radio-indicator-icon-checked:           url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='7 7 10 10'><circle cx='12' cy='12' r='5' fill='#{$custom-control-indicator-checked-bg}'/></svg>") !default;
$custom-radio-indicator-icon-checked-disabled:  url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='7 7 10 10'><circle cx='12' cy='12' r='5' fill='#{$custom-control-label-disabled-color}'/></svg>") !default;

$custom-switch-width:                           $custom-control-indicator-size * 1.75 !default;
$custom-switch-indicator-border-radius:         $custom-control-indicator-size * .5 !default;
$custom-switch-indicator-size:                  functions.subtract($custom-control-indicator-size, $custom-control-indicator-border-width * 4) !default;

$custom-select-padding-y:           $input-padding-y !default;
$custom-select-padding-x:           $input-padding-x !default;
$custom-select-font-family:         $input-font-family !default;
$custom-select-font-size:           $input-font-size !default;
$custom-select-height:              $input-height !default;
$custom-select-indicator-padding:   1rem !default; // Extra padding to account for the presence of the background-image based indicator
$custom-select-font-weight:         $input-font-weight !default;
$custom-select-line-height:         $input-line-height !default;
$custom-select-color:               $input-color !default;
$custom-select-disabled-color:      $gray-600 !default;
$custom-select-bg:                  $input-bg !default;
$custom-select-disabled-bg:         $gray-200 !default;
$custom-select-bg-size:             8px 10px !default; // In pixels because image dimensions
$custom-select-indicator-color:     $gray-800 !default;
$custom-select-indicator:           url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'><path fill='#{$custom-select-indicator-color}' d='M2 0L0 2h4zm0 5L0 3h4z'/></svg>") !default;
$custom-select-background:          escape-svg($custom-select-indicator) right $custom-select-padding-x center / $custom-select-bg-size no-repeat !default; // Used so we can have multiple background elements (e.g., arrow and feedback icon)

$custom-select-feedback-icon-padding-right: functions.add(1em * .75, (2 * $custom-select-padding-y * .75) + $custom-select-padding-x + $custom-select-indicator-padding) !default;
$custom-select-feedback-icon-position:      center right ($custom-select-padding-x + $custom-select-indicator-padding) !default;
$custom-select-feedback-icon-size:          $input-height-inner-half $input-height-inner-half !default;

$custom-select-border-width:        $input-border-width !default;
$custom-select-border-color:        $input-border-color !default;
$custom-select-border-radius:       $border-radius !default;
$custom-select-box-shadow:          inset 0 1px 2px rgba($black, .075) !default;

$custom-select-focus-border-color:  $input-focus-border-color !default;
$custom-select-focus-width:         $input-focus-width !default;
$custom-select-focus-box-shadow:    0 0 0 $custom-select-focus-width $input-btn-focus-color !default;

$custom-select-padding-y-sm:        $input-padding-y-sm !default;
$custom-select-padding-x-sm:        $input-padding-x-sm !default;
$custom-select-font-size-sm:        $input-font-size-sm !default;
$custom-select-height-sm:           $input-height-sm !default;

$custom-select-padding-y-lg:        $input-padding-y-lg !default;
$custom-select-padding-x-lg:        $input-padding-x-lg !default;
$custom-select-font-size-lg:        $input-font-size-lg !default;
$custom-select-height-lg:           $input-height-lg !default;

$custom-range-track-width:          100% !default;
$custom-range-track-height:         .5rem !default;
$custom-range-track-cursor:         pointer !default;
$custom-range-track-bg:             $gray-300 !default;
$custom-range-track-border-radius:  1rem !default;
$custom-range-track-box-shadow:     inset 0 .25rem .25rem rgba($black, .1) !default;

$custom-range-thumb-width:                   1rem !default;
$custom-range-thumb-height:                  $custom-range-thumb-width !default;
$custom-range-thumb-bg:                      $component-active-bg !default;
$custom-range-thumb-border:                  0 !default;
$custom-range-thumb-border-radius:           1rem !default;
$custom-range-thumb-box-shadow:              0 .1rem .25rem rgba($black, .1) !default;
$custom-range-thumb-focus-box-shadow:        0 0 0 1px $body-bg, $input-focus-box-shadow !default;
$custom-range-thumb-focus-box-shadow-width:  $input-focus-width !default; // For focus box shadow issue in IE/Edge
$custom-range-thumb-active-bg:               color.adjust($component-active-bg, $lightness: 35%) !default;
$custom-range-thumb-disabled-bg:             $gray-500 !default;

$custom-file-height:                $input-height !default;
$custom-file-height-inner:          $input-height-inner !default;
$custom-file-focus-border-color:    $input-focus-border-color !default;
$custom-file-focus-box-shadow:      $input-focus-box-shadow !default;
$custom-file-disabled-bg:           $input-disabled-bg !default;

$custom-file-padding-y:             $input-padding-y !default;
$custom-file-padding-x:             $input-padding-x !default;
$custom-file-line-height:           $input-line-height !default;
$custom-file-font-family:           $input-font-family !default;
$custom-file-font-weight:           $input-font-weight !default;
$custom-file-color:                 $input-color !default;
$custom-file-bg:                    $input-bg !default;
$custom-file-border-width:          $input-border-width !default;
$custom-file-border-color:          $input-border-color !default;
$custom-file-border-radius:         $input-border-radius !default;
$custom-file-box-shadow:            $input-box-shadow !default;
$custom-file-button-color:          $custom-file-color !default;
$custom-file-button-bg:             $input-group-addon-bg !default;
$custom-file-text: (
  en: "Browse"
) !default;


// Form validation

$form-feedback-margin-top:          $form-text-margin-top !default;
$form-feedback-font-size:           $small-font-size !default;
$form-feedback-valid-color:         map.get($theme-colors, "success") !default;
$form-feedback-invalid-color:       map.get($theme-colors, "danger") !default;

$form-feedback-icon-valid-color:    $form-feedback-valid-color !default;
$form-feedback-icon-valid:          url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'> <path fill='transparent' d='M23 12c0 6.075-4.925 11-11 11S1 18.075 1 12 5.925 1 12 1s11 4.925 11 11Z'></path> <path fill='#{$form-feedback-icon-valid-color}' d='M16.64 8.732a1 1 0 0 1 .128 1.408l-5 6a1 1 0 0 1-1.475.067l-3-3a1 1 0 1 1 1.414-1.414l2.226 2.226 4.299-5.16a1 1 0 0 1 1.408-.127Z'></path> <path fill='#{$form-feedback-icon-valid-color}' d='M12 3a9 9 0 1 0 0 18 9 9 0 0 0 0-18ZM1 12C1 5.925 5.925 1 12 1s11 4.925 11 11-4.925 11-11 11S1 18.075 1 12Z'></path></svg>") !default;
$form-feedback-icon-invalid-color:  $form-feedback-invalid-color !default;
$form-feedback-icon-invalid:        url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'> <path fill='transparent' d='M23 12c0 6.075-4.925 11-11 11S1 18.075 1 12 5.925 1 12 1s11 4.925 11 11Z'></path> <path fill='#{$form-feedback-icon-invalid-color}' d='M12 3a9 9 0 1 0 0 18 9 9 0 0 0 0-18ZM1 12C1 5.925 5.925 1 12 1s11 4.925 11 11-4.925 11-11 11S1 18.075 1 12Z'> </path> <path fill='#{$form-feedback-icon-invalid-color}' d='M12 6a1 1 0 0 1 1 1v6a1 1 0 1 1-2 0V7a1 1 0 0 1 1-1Zm0 9.5a1 1 0 0 1 1 1v.5a1 1 0 1 1-2 0v-.5a1 1 0 0 1 1-1Z'></path></svg>") !default;

$form-validation-states: () !default;
$form-validation-states: map.merge(
  (
    "valid": (
      "color": $form-feedback-valid-color,
      "icon": ""
    ),
    "invalid": (
      "color": $form-feedback-invalid-color,
      "icon": $form-feedback-icon-invalid
    ),
  ),
  $form-validation-states
);

// Z-index master list
//
// Warning: Avoid customizing these values. They're used for a bird's eye view
// of components dependent on the z-axis and are designed to all work together.

$zindex-dropdown:                   1000 !default;
$zindex-sticky:                     1020 !default;
$zindex-fixed:                      1030 !default;
$zindex-modal-backdrop:             1040 !default;
$zindex-modal:                      1050 !default;
$zindex-popover:                    1060 !default;
$zindex-tooltip:                    1070 !default;

// Verification code

$verification-code-dimension-xs:       3.5rem !default;
$verification-code-dimension-lg:       5rem !default;
$verification-code-border:             2px solid $gray-200;
$verification-code-border-radius:      $border-radius-sm !default;
$verification-code-shadow:             0px 4px 12px 0px $gray-50;
$verification-code-focus-border-color: $blue-200;

// Accordions

$accordion-border-radius:           $border-radius-lg;


// Navs

$nav-link-padding-y:                .5rem !default;
$nav-link-padding-x:                1rem !default;
$nav-link-disabled-color:           $gray-600 !default;

$nav-tabs-border-color:             $gray-300 !default;
$nav-tabs-border-width:             $border-width !default;
$nav-tabs-border-radius:            $border-radius !default;
$nav-tabs-link-hover-border-color:  $gray-200 $gray-200 $nav-tabs-border-color !default;
$nav-tabs-link-active-color:        $gray-700 !default;
$nav-tabs-link-active-bg:           $body-bg !default;
$nav-tabs-link-active-border-color: $gray-300 $gray-300 $nav-tabs-link-active-bg !default;

$nav-pills-border-radius:           $border-radius !default;
$nav-pills-link-active-color:       $component-active-color !default;
$nav-pills-link-active-bg:          $component-active-bg !default;

$nav-divider-color:                 $gray-200 !default;
$nav-divider-margin-y:              $spacer * .5 !default;


// Navbar

$navbar-padding-y:                  $spacer * .5 !default;
$navbar-padding-x:                  $spacer !default;

$navbar-nav-link-padding-x:         1rem !default;

$navbar-brand-font-size:            $font-size-lg !default;
// Compute the navbar-brand padding-y so the navbar-brand will have the same height as navbar-text and nav-link
$nav-link-height:                   $font-size-base * $line-height-base + $nav-link-padding-y * 2 !default;
$navbar-brand-height:               $navbar-brand-font-size * $line-height-base !default;
$navbar-brand-padding-y:            ($nav-link-height - $navbar-brand-height) * .5 !default;

$navbar-toggler-padding-y:          .25rem !default;
$navbar-toggler-padding-x:          .75rem !default;
$navbar-toggler-font-size:          $font-size-lg !default;
$navbar-toggler-border-radius:      $btn-border-radius !default;

$navbar-nav-scroll-max-height:      75vh !default;

$navbar-dark-color:                 $white !default;
$navbar-dark-hover-color:           rgba($white, .75) !default;
$navbar-dark-active-color:          $white !default;
$navbar-dark-disabled-color:        rgba($white, .25) !default;
$navbar-dark-toggler-icon-bg:       url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'><path stroke='#{$navbar-dark-color}' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/></svg>") !default;
$navbar-dark-toggler-border-color:  rgba($white, .1) !default;

$navbar-light-color:                $gray !default;
$navbar-light-hover-color:          $gray !default;
$navbar-light-active-color:         $gray !default;
$navbar-light-disabled-color:       rgba($black, .3) !default;
$navbar-light-toggler-icon-bg:      url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'><path stroke='#{$navbar-light-color}' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/></svg>") !default;
$navbar-light-toggler-border-color: rgba($black, .1) !default;

$navbar-light-brand-color:                $navbar-light-active-color !default;
$navbar-light-brand-hover-color:          $navbar-light-active-color !default;
$navbar-dark-brand-color:                 $navbar-dark-active-color !default;
$navbar-dark-brand-hover-color:           $navbar-dark-active-color !default;


// Dropdowns
//
// Dropdown menu container and contents.

$dropdown-min-width:                10rem !default;
$dropdown-padding-x:                0 !default;
$dropdown-padding-y:                .5rem !default;
$dropdown-spacer:                   .125rem !default;
$dropdown-font-size:                $font-size-base !default;
$dropdown-color:                    $body-color !default;
$dropdown-bg:                       $white !default;
$dropdown-border-color:             rgba($black, .15) !default;
$dropdown-border-radius:            0 !default;
$dropdown-border-width:             $border-width !default;
$dropdown-inner-border-radius:      functions.subtract($dropdown-border-radius, $dropdown-border-width) !default;
$dropdown-divider-bg:               $gray-200 !default;
$dropdown-divider-margin-y:         $nav-divider-margin-y !default;
$dropdown-box-shadow:               0 .5rem 1rem rgba($black, .175) !default;

$dropdown-link-color:               $gray-900 !default;
$dropdown-link-hover-color:         $white !default;
$dropdown-link-hover-bg:            $primary !default;

$dropdown-link-active-color:        $component-active-color !default;
$dropdown-link-active-bg:           $component-active-bg !default;

$dropdown-link-disabled-color:      $gray-500 !default;

$dropdown-item-padding-y:           .25rem !default;
$dropdown-item-padding-x:           1.5rem !default;

$dropdown-header-color:             $gray-600 !default;
$dropdown-header-padding:           $dropdown-padding-y $dropdown-item-padding-x !default;


// Pagination

$pagination-padding-y:              .5rem !default;
$pagination-padding-x:              .75rem !default;
$pagination-padding-y-sm:           .25rem !default;
$pagination-padding-x-sm:           .5rem !default;
$pagination-padding-y-lg:           .75rem !default;
$pagination-padding-x-lg:           1.5rem !default;
$pagination-line-height:            1.25 !default;

$pagination-color:                  $link-color !default;
$pagination-bg:                     transparent !default;
$pagination-border-width:           $border-width !default;
$pagination-border-color:           $gray-300 !default;

$pagination-focus-box-shadow:       $input-btn-focus-box-shadow !default;
$pagination-focus-outline:          0 !default;

$pagination-hover-color:            $link-hover-color !default;
$pagination-hover-bg:               $gray-200 !default;
$pagination-hover-border-color:     $gray-300 !default;

$pagination-active-color:           $gray-900 !default;
$pagination-active-bg:              $orange-50 !default;
$pagination-active-border-color:    $pagination-border-color !default;

$pagination-disabled-color:         $gray-500 !default;
$pagination-disabled-bg:            transparent !default;
$pagination-disabled-border-color:  $gray-300 !default;

$pagination-border-radius:          $border-radius-xs !default;
$pagination-border-radius-sm:       $border-radius-sm !default;
$pagination-border-radius-lg:       $border-radius-lg !default;


// Jumbotron

$jumbotron-padding:                 2rem !default;
$jumbotron-color:                   null !default;
$jumbotron-bg:                      $gray-200 !default;


// Cards

$card-spacer-y:                     .75rem !default;
$card-spacer-x:                     1.25rem !default;
$card-border-width:                 2px !default;
$card-border-radius:                $border-radius !default;
$card-border-color:                 $gray-100 !default;
$card-inner-border-radius:          functions.subtract($card-border-radius, $card-border-width) !default;
$card-cap-bg:                       $white !default;
$card-cap-color:                    null !default;
$card-height:                       null !default;
$card-color:                        null !default;
$card-bg:                           $white !default;

$card-img-overlay-padding:          1.25rem !default;

$card-group-margin:                 $grid-gutter-width * .5 !default;
$card-deck-margin:                  $card-group-margin !default;

$card-columns-count:                3 !default;
$card-columns-gap:                  1.25rem !default;
$card-columns-margin:               $card-spacer-y !default;

$card-interactive-border-color:           $gray-200 !default;
$card-interactive-shadow:                 0px 4px 12px 0px $gray-50 !default;

$card-interactive-hover-border-color:     $orange-300 !default;

$card-interactive-focus-border-color:     $orange-600 !default;
$card-interactive-focus-shadow:           0px 0px 8px 0px rgba(255, 145, 51, 0.40) !default;

$card-interactive-active-border-color:    $orange-900 !default;
$card-interactive-active-shadow:          0px 3px 10px 0px $gray-50 !default;

$card-interactive-selected-shadow:        0px 0px 8px 0px rgba(255, 145, 51, 0.40) !default;
$card-interactive-selected-active-shadow: 0px 0px 7px 0px rgba(255, 145, 51, 0.40) !default;

// Tooltips

$tooltip-font-size:                 $font-size-sm !default;
$tooltip-max-width:                 200px !default;
$tooltip-color:                     $white !default;
$tooltip-bg:                        $gray-900 !default;
$tooltip-border-radius:             $border-radius !default;
$tooltip-opacity:                   1 !default;
$tooltip-padding-y:                 .25rem !default;
$tooltip-padding-x:                 .5rem !default;
$tooltip-margin:                    0 !default;

$tooltip-arrow-width:               .8rem !default;
$tooltip-arrow-height:              .4rem !default;
$tooltip-arrow-color:               $tooltip-bg !default;

// Form tooltips must come after regular tooltips
$form-feedback-tooltip-padding-y:     $tooltip-padding-y !default;
$form-feedback-tooltip-padding-x:     $tooltip-padding-x !default;
$form-feedback-tooltip-font-size:     $tooltip-font-size !default;
$form-feedback-tooltip-line-height:   $line-height-base !default;
$form-feedback-tooltip-opacity:       $tooltip-opacity !default;
$form-feedback-tooltip-border-radius: $tooltip-border-radius !default;


// Popovers

$popover-font-size:                 $font-size-100 !default;
$popover-bg:                        $black !default;
$popover-max-width:                 276px !default;
$popover-border-width:              0 !default;
$popover-border-color:              rgba($black, .2) !default;
$popover-border-radius:             $border-radius-sm !default;
$popover-inner-border-radius:       functions.subtract($popover-border-radius, $popover-border-width) !default;
$popover-box-shadow:                0 1px 6px 0 rgba(34, 38, 51, 0.25) !default;

$popover-header-bg:                 $popover-bg !default;
$popover-header-color:              $white !default;
$popover-header-font-weight:        $font-weight-bold !default;
$popover-header-padding-y:          1rem !default;
$popover-header-padding-x:          1rem !default;

$popover-body-color:                $white !default;
$popover-body-padding-y:            $popover-header-padding-y !default;
$popover-body-padding-x:            1rem !default;

$popover-arrow-width:               2rem !default;
$popover-arrow-height:              1.25rem !default;
$popover-arrow-color:               $black !default;

// asdf
$popover-arrow-outer-color:         fade-in($popover-border-color, .05) !default;


// Toasts

$toast-max-width:                   350px !default;
$toast-padding-x:                   .75rem !default;
$toast-padding-y:                   .25rem !default;
$toast-font-size:                   .875rem !default;
$toast-color:                       null !default;
$toast-background-color:            rgba($white, .85) !default;
$toast-border-width:                1px !default;
$toast-border-color:                rgba(0, 0, 0, .1) !default;
$toast-border-radius:               .25rem !default;
$toast-box-shadow:                  0 .25rem .75rem rgba($black, .1) !default;

$toast-header-color:                $gray-600 !default;
$toast-header-background-color:     rgba($white, .85) !default;
$toast-header-border-color:         rgba(0, 0, 0, .05) !default;


// Badges

$badge-font-size:                   $font-size-sm !default;
$badge-font-weight:                 $font-weight-bold !default;
$badge-padding-y:                   0.25rem !default;
$badge-padding-x:                   1rem !default;
$badge-border-radius:               $border-radius !default;

$badge-transition:                  $btn-transition !default;
$badge-focus-width:                 $input-btn-focus-width !default;

$badge-pill-padding-x:              .6em !default;
// Use a higher than normal value to ensure completely rounded edges when
// customizing padding or font-size on labels.
$badge-pill-border-radius:          10rem !default;

$badge-bg-colors: () !default;
$badge-bg-colors: map.merge(
  (
    "danger":    $error-50,
    "dark":      $dark-blue,
    "info":      $orange-500,
    "primary":   $soft-blue,
    "success":   $success-50,
    "warning":   $warning-50,

    // deprecated
    "secondary":      $soft-blue,
    "light":          $light,
    "mid":            $mid,
    "mid-dark":       $mid-dark,
    "highlight":      $highlight,
    "highlight-dark": $highlight-dark,
  ),
  $badge-bg-colors
);

$badge-text-colors: () !default;
$badge-text-colors: map.merge(
  (
    "danger":    $gray-900,
    "dark":      $white,
    "info":      $gray-900,
    "primary":   $dark-blue,
    "success":   $gray-900,
    "warning":   $gray-900,

    // deprecated
    "secondary":      $gray-900,
    "light":          $gray-900,
    "mid":            $gray-900,
    "mid-dark":       $gray-900,
    "highlight":      $gray-900,
    "highlight-dark": $gray-900,
  ),
  $badge-text-colors
);

// Modals

// Padding applied to the modal body
$modal-inner-padding:               0 2rem 2rem 2rem !default;

$modal-footer-padding-x:            2rem !default;
$modal-footer-padding-bottom:       2rem !default;
$modal-footer-padding-top:          4rem !default; // border appears halfway down this

// Margin between elements in footer, must be lower than or equal to 2 * $modal-inner-padding
$modal-footer-margin-between:       .5rem !default;

$modal-dialog-margin:               .5rem !default;
$modal-dialog-margin-y-sm-up:       1.75rem !default;

$modal-title-line-height:           1.2 !default;

$modal-content-color:               null !default;
$modal-content-bg:                  $white !default;
$modal-content-border-color:        null !default;
$modal-content-border-width:        0 !default;
$modal-content-border-radius:       $border-radius-xs !default;
$modal-content-inner-border-radius: functions.subtract($modal-content-border-radius, $modal-content-border-width) !default;
$modal-content-box-shadow-xs:       0 !default;
$modal-content-box-shadow-sm-up:    0px 4px 12px 0px $gray-300 !default;

$modal-backdrop-bg:                 rgba($gray-900, 0.45) !default;
$modal-backdrop-opacity:            .2 !default;
$modal-header-border-color:         null !default;
$modal-footer-border-color:         $gray-500 !default;
$modal-header-border-width:         0 !default;
$modal-footer-border-width:         1px !default;
$modal-header-padding-y:            2rem !default;
$modal-header-padding-x:            2rem !default;
$modal-header-padding:              $modal-header-padding-y $modal-header-padding-x !default; // Keep this for backwards compatibility

$modal-xl:                          1140px !default;
$modal-lg:                          800px !default;
$modal-md:                          500px !default;
$modal-sm:                          300px !default;

$modal-fade-transform:              translate(0, -50px) !default;
$modal-show-transform:              none !default;
$modal-transition:                  transform .3s ease-out !default;
$modal-scale-transform:             scale(1.02) !default;


// Alerts
//
// Define alert colors, border radius, and padding.

$alert-padding-y:                   1rem !default;
$alert-padding-x:                   1rem !default;
$alert-margin-bottom:               1rem !default;
$alert-border-radius:               $border-radius-sm !default;
$alert-link-font-weight:            $font-weight-bold !default;
$alert-border-width:                $border-width !default;

$alert-bg-level:                    -10 !default;
$alert-border-level:                -9 !default;
$alert-color-level:                 6 !default;


// Progress bars

$progress-height:                   1rem !default;
$progress-font-size:                $font-size-base * .75 !default;
$progress-bg:                       $gray-200 !default;
$progress-border-radius:            $border-radius !default;
$progress-box-shadow:               inset 0 .1rem .1rem rgba($black, .1) !default;
$progress-bar-color:                $white !default;
$progress-bar-bg:                   $orange !default;
$progress-bar-animation-timing:     1s linear infinite !default;
$progress-bar-transition:           width .6s ease !default;


// List group

$list-group-color:                  null !default;
$list-group-bg:                     $white !default;
$list-group-border-color:           rgba($black, .125) !default;
$list-group-border-width:           $border-width !default;
$list-group-border-radius:          $border-radius !default;

$list-group-item-padding-y:         .75rem !default;
$list-group-item-padding-x:         1.25rem !default;

$list-group-hover-bg:               $gray-100 !default;
$list-group-active-color:           $component-active-color !default;
$list-group-active-bg:              $component-active-bg !default;
$list-group-active-border-color:    $list-group-active-bg !default;

$list-group-disabled-color:         $gray-600 !default;
$list-group-disabled-bg:            $list-group-bg !default;

$list-group-action-color:           $gray-700 !default;
$list-group-action-hover-color:     $list-group-action-color !default;

$list-group-action-active-color:    $body-color !default;
$list-group-action-active-bg:       $gray-200 !default;


// Image thumbnails

$thumbnail-padding:                 .25rem !default;
$thumbnail-bg:                      $body-bg !default;
$thumbnail-border-width:            $border-width !default;
$thumbnail-border-color:            $gray-300 !default;
$thumbnail-border-radius:           $border-radius !default;
$thumbnail-box-shadow:              0 1px 2px rgba($black, .075) !default;


// Figures

$figure-caption-font-size:          90% !default;
$figure-caption-color:              $gray-600 !default;


// Breadcrumbs

$breadcrumb-font-size:              $font-size-sm !default;

$breadcrumb-padding-y:              0 !default;
$breadcrumb-padding-x:              0 !default;
$breadcrumb-item-padding:           0.5rem !default;

$breadcrumb-margin-bottom:          1rem !default;

$breadcrumb-bg:                     transparent !default;
$breadcrumb-divider-color:          $gray-900 !default;
$breadcrumb-active-color:           $gray-900 !default;
$breadcrumb-divider:                string.quote("/") !default;

$breadcrumb-border-radius:          $border-radius !default;


// Carousel

$carousel-control-color:             $white !default;
$carousel-control-width:             15% !default;
$carousel-control-opacity:           .5 !default;
$carousel-control-hover-opacity:     .9 !default;
$carousel-control-transition:        opacity .15s ease !default;

$carousel-indicator-width:           30px !default;
$carousel-indicator-height:          3px !default;
$carousel-indicator-hit-area-height: 10px !default;
$carousel-indicator-spacer:          3px !default;
$carousel-indicator-active-bg:       $white !default;
$carousel-indicator-transition:      opacity .6s ease !default;

$carousel-caption-width:             70% !default;
$carousel-caption-color:             $white !default;

$carousel-control-icon-width:        20px !default;

$carousel-control-prev-icon-bg:      url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' fill='#{$carousel-control-color}' width='8' height='8' viewBox='0 0 8 8'><path d='M5.25 0l-4 4 4 4 1.5-1.5L4.25 4l2.5-2.5L5.25 0z'/></svg>") !default;
$carousel-control-next-icon-bg:      url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' fill='#{$carousel-control-color}' width='8' height='8' viewBox='0 0 8 8'><path d='M2.75 0l-1.5 1.5L3.75 4l-2.5 2.5L2.75 8l4-4-4-4z'/></svg>") !default;

$carousel-transition-duration:       .6s !default;
$carousel-transition:                transform $carousel-transition-duration ease-in-out !default; // Define transform transition first if using multiple transitions (e.g., `transform 2s ease, opacity .5s ease-out`)


// Spinners

$spinner-width:           1.25rem !default;
$spinner-height:          $spinner-width !default;
$spinner-vertical-align:  -.125em !default;
$spinner-border-width:    .15em !default;

$spinner-width-sm:        1.25rem !default;
$spinner-height-sm:       $spinner-width-sm !default;
$spinner-border-width-sm: .15em !default;


// Close

$close-font-size:                   $font-size-base * 1.5 !default;
$close-font-weight:                 $font-weight-bold !default;
$close-color:                       $black !default;
$close-text-shadow:                 0 1px 0 $white !default;


// Code

$code-font-size:                    87.5% !default;
$code-color:                        $orange-900 !default;

$kbd-padding-y:                     .2rem !default;
$kbd-padding-x:                     .4rem !default;
$kbd-font-size:                     $code-font-size !default;
$kbd-color:                         $white !default;
$kbd-bg:                            $gray-900 !default;

$pre-color:                         $gray-900 !default;
$pre-scrollable-max-height:         340px !default;


// Utilities

$displays: none, inline, inline-block, block, table, table-row, table-cell, flex, inline-flex !default;
$overflows: auto, hidden !default;
$positions: static, relative, absolute, fixed, sticky !default;
$user-selects: all, auto, none !default;


// Printing

$print-page-size:                   a3 !default;
$print-body-min-width:              map.get($grid-breakpoints, "lg") !default;


// Further ES Atoms

// fusv-disable
$b-table-stacked-gap: 2rem;
$b-table-sort-icon-bg-not-sorted: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='101' height='101' view-box='0 0 101 101' preserveAspectRatio='none'><path fill='black' opacity='.3' d='M51 1l25 23 24 22H1l25-22zM51 101l25-23 24-22H1l25 22z'/></svg>");
$b-table-sort-icon-bg-ascending: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='101' height='101' view-box='0 0 101 101' preserveAspectRatio='none'><path fill='black' d='M51 1l25 23 24 22H1l25-22z'/><path fill='black' opacity='.3' d='M51 101l25-23 24-22H1l25 22z'/></svg>");
$b-table-sort-icon-bg-descending: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='101' height='101' view-box='0 0 101 101' preserveAspectRatio='none'><path fill='black' opacity='.3' d='M51 1l25 23 24 22H1l25-22z'/><path fill='black' d='M51 101l25-23 24-22H1l25 22z'/></svg>");
// fusv-enable
