/* Codestich Floating Navbar Styles */
:root {
  /* Default heights used for spacing below fixed nav */
  --nav-height-desktop: 6rem;   /* matches #cs-navigation height on desktop */
  --nav-offset-top: 2rem;       /* the top offset when not scrolled */
  --nav-height-mobile: 4.25rem; /* approximate closed height on mobile */
}

/* Use clean system font stack for header globally */
#cs-navigation,
#cs-navigation * {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif;
}

/* Spacer element that reserves space for the fixed navigation */
.nav-spacer {
  width: 100%;
  /* primary source of truth from JS measurement */
  height: var(--nav-spacer-height, calc(var(--nav-height-mobile) + var(--nav-offset-top)));
}

/* When wide screens, match desktop nav dimensions */
@media only screen and (min-width: 64rem) {
  .nav-spacer {
    height: calc(var(--nav-height-desktop) + var(--nav-offset-top));
  }
}

/* When body has .scroll, the nav snaps to top (no offset). Keep spacer equal to the nav height only */
body.scroll .nav-spacer {
  height: var(--nav-spacer-height, var(--nav-height-mobile));
}
@media only screen and (min-width: 64rem) {
  body.scroll .nav-spacer {
    height: var(--nav-spacer-height, var(--nav-height-desktop));
  }
}
/*-- -------------------------- -->
<---     Mobile Navigation      -->
<--- -------------------------- -*/
/* Mobile - 1023px */
@media only screen and (max-width: 63.9375rem) {
  body.cs-open {
    overflow: hidden;
  }
  body.scroll #cs-navigation {
    width: 100%;
    max-width: 100%;
    top: 0;
  }
  body.scroll #cs-navigation:before {
    border-radius: 0;
  }
  body.scroll #cs-navigation .cs-ul-wrapper {
    top: 100%;
  }
  #cs-navigation {
    width: 94%;
    max-width: 80rem;
    /* prevents padding from affecting height and width */
    box-sizing: border-box;
    /* 12px - 24px */
    padding: clamp(0.75rem, 2vw, 1.5rem);
    /* 12px - 24px */
    border-radius: clamp(0.75rem, 2vw, 1.5rem);
    position: fixed;
    top: 2rem;
    left: 50%;
    z-index: 10000;
    transform: translateX(-50%);
    transition: top 0.3s, border-radius 0.3s, width 0.3s, max-width 0.3s;
  }
  #cs-navigation:before {
    /* background color */
    content: "";
    width: 100%;
    height: 100%;
    background: #fff;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
    opacity: 1;
    /* 12px - 24px */
    border-radius: clamp(0.75rem, 2vw, 1.5rem);
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  transition: transform 0.2s, border-radius 0.3s ease-in-out;
  z-index: -1;
  }
  #cs-navigation.cs-active:before {
    transform: translateX(-50%) scale(1.03);
  }
  #cs-navigation.cs-active .cs-toggle {
    transform: rotate(180deg);
  }
  #cs-navigation.cs-active .cs-ul-wrapper {
    transform: scaleY(1);
    transition-delay: 0.15s;
  }
  #cs-navigation.cs-active .cs-li {
    opacity: 1;
    transform: translateY(0);
  }
  #cs-navigation .cs-container {
    width: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 1.5rem;
  }
  #cs-navigation .cs-logo {
  width: auto;
  max-width: 18rem;
  height: 100%;
  margin: 0 auto 0 0;
  /* prevents padding from affecting height and width */
  box-sizing: border-box;
  padding: 0;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.75rem; /* spacing between glyph and text */
  z-index: 10;
  }
  #cs-navigation .cs-logo img {
    width: 100%;
    height: 100%;
    /* ensures the image never overflows the container. It stays contained within it's width and height and expands to fill it then stops once it reaches an edge */
    object-fit: contain;
  }
  #cs-navigation .cs-logo-text {
  font-weight: 700;
  font-size: clamp(1.05rem, 2.4vw, 1.25rem);
    color: #222;
    white-space: nowrap;
  }
  #cs-navigation .cs-toggle {
    width: 20px;
    height: 20px;
    padding: 5px;
    margin: 0 0 0 auto;
    background-color: #1a1a1a;
    border: none;
    border-radius: 0.25rem;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    z-index: 10;
    transition: transform 0.6s;
  }
  #cs-navigation .cs-nav {
    /* sends it to the right in the 3rd position */
    order: 3;
  }
  #cs-navigation .cs-contact-group {
    display: none;
    position: relative;
    z-index: 10;
  }
  #cs-navigation .cs-phone {
    font-size: 1rem;
    line-height: 1.5em;
    text-decoration: none;
    margin: 0;
    color: var(--headerColor);
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0.5rem;
    transition: opacity 0.3s, color 0.3s;
  }
  #cs-navigation .cs-phone-icon {
    width: 1.5rem;
    height: auto;
    display: block;
  }
  #cs-navigation .cs-social {
    display: none;
  }
  #cs-navigation .cs-active .cs-line1 {
    top: 50%;
    transform: translate(-50%, -50%) rotate(225deg);
  }
  #cs-navigation .cs-active .cs-line2 {
    top: 50%;
    transform: translate(-50%, -50%) translateY(0) rotate(-225deg);
    transform-origin: center;
  }
  #cs-navigation .cs-active .cs-line3 {
    opacity: 0;
    bottom: 100%;
  }
  #cs-navigation .cs-box {
    /* 24px - 28px */
    width: clamp(1.5rem, 2vw, 1.75rem);
    height: 1rem;
    position: relative;
  }
  #cs-navigation .cs-line {
    width: auto;
    max-width: none;
    height: 2rem;
    border-radius: 2px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }
  #cs-navigation .cs-line1 {
    gap: 0.75rem;
    top: 0;
    transition: transform 0.5s, top 0.3s, left 0.3s;
    animation-duration: 0.7s;
    animation-timing-function: ease;
    animation-direction: normal;
    animation-fill-mode: forwards;
    transform-origin: center;
  }
  #cs-navigation .cs-logo-text {
    font-weight: 700;
    letter-spacing: 0.01em;
    font-size: clamp(1.125rem, 1.9vw, 1.5rem);
    color: var(--headerColor);
    white-space: nowrap;
  }
  #cs-navigation .cs-line2 {
    top: 50%;
    transform: translateX(-50%) translateY(-50%);
    transition: top 0.3s, left 0.3s, transform 0.5s;
    animation-duration: 0.7s;
    animation-timing-function: ease;
    animation-direction: normal;
    animation-fill-mode: forwards;
  }
  #cs-navigation .cs-line3 {
    bottom: 0;
    transition: bottom 0.3s, opacity 0.3s;
  }
  #cs-navigation .cs-ul-wrapper {
    width: 100%;
    height: auto;
    padding-bottom: 2.4em;
    background-color: #fff;
    border-radius: 0 0 1.5rem 1.5rem;
    position: absolute;
    top: 85%;
    left: 0;
    z-index: -1;
    overflow: hidden;
    transform: scaleY(0);
    transition: transform 0.4s;
    transform-origin: top;
  }
  #cs-navigation .cs-ul {
    width: 100%;
    height: auto;
    max-height: 65vh;
    margin: 0;
    padding: 4rem 0 0 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: 1.25rem;
    overflow: auto;
  }
  #cs-navigation .cs-li {
    text-align: center;
    list-style: none;
    width: 100%;
    margin-right: 0;
    opacity: 0;
    /* transition from these values */
    transform: translateY(-70/16rem);
    transition: transform 0.6s, opacity 0.9s;
  }
  #cs-navigation .cs-li:nth-of-type(1) { transition-delay: 0.05s; }
  #cs-navigation .cs-li:nth-of-type(2) { transition-delay: 0.1s; }
  #cs-navigation .cs-li:nth-of-type(3) { transition-delay: 0.15s; }
  #cs-navigation .cs-li:nth-of-type(4) { transition-delay: 0.2s; }
  #cs-navigation .cs-li:nth-of-type(5) { transition-delay: 0.25s; }
  #cs-navigation .cs-li:nth-of-type(6) { transition-delay: 0.3s; }
  #cs-navigation .cs-li:nth-of-type(7) { transition-delay: 0.35s; }
  #cs-navigation .cs-li:nth-of-type(8) { transition-delay: 0.4s; }
  #cs-navigation .cs-li:nth-of-type(9) { transition-delay: 0.45s; }
  #cs-navigation .cs-li:nth-of-type(10) { transition-delay: 0.5s; }
  #cs-navigation .cs-li:nth-of-type(11) { transition-delay: 0.55s; }
  #cs-navigation .cs-li:nth-of-type(12) { transition-delay: 0.6s; }
  #cs-navigation .cs-li:nth-of-type(13) { transition-delay: 0.65s; }
  #cs-navigation .cs-li-link {
    /* 16px - 24px */
    font-size: clamp(1rem, 2.5vw, 1.5rem);
    line-height: 1.2em;
    text-decoration: none;
    margin: 0;
    color: var(--headerColor);
    display: inline-block;
    position: relative;
  }
  #cs-navigation .cs-li-link.cs-active { color: var(--primary); }
  #cs-navigation .cs-li-link:hover { color: var(--primary); }
  #cs-navigation .cs-button-solid { display: none; }
}

/* Tablet - 768px */
@media only screen and (min-width: 48rem) {
  #cs-navigation .cs-contact-group { display: block; }
}

/*-- -------------------------- -->
<---     Navigation Dropdown    -->
<--- -------------------------- -*/
/* Mobile - 1023px */
@media only screen and (max-width: 63.9375rem) {
  #cs-navigation .cs-li { text-align: center; width: 100%; display: block; }
  #cs-navigation .cs-dropdown { color: var(--bodyTextColorWhite); position: relative; }
  #cs-navigation .cs-dropdown.cs-active .cs-drop-ul {
    height: auto; margin: 0.75rem 0 0 0; padding: 0.75rem 0; opacity: 1; visibility: visible;
  }
  #cs-navigation .cs-dropdown.cs-active .cs-drop-link { opacity: 1; }
  #cs-navigation .cs-dropdown .cs-li-link { position: relative; transition: opacity 0.3s; }
  #cs-navigation .cs-drop-icon { width: 0.9375rem; height: auto; position: absolute; top: 50%; right: -1.25rem; transform: translateY(-50%); }
  #cs-navigation .cs-drop-ul {
    width: 100%; height: 0; margin: 0; padding: 0; background-color: var(--primary); opacity: 0; display: flex; visibility: hidden;
    flex-direction: column; justify-content: flex-start; align-items: center; gap: 0.75rem; overflow: hidden; transition: padding 0.3s, margin 0.3s, height 0.3s, opacity 0.3s, visibility 0.3s;
  }
  #cs-navigation .cs-drop-li { list-style: none; }
  #cs-navigation .cs-li-link.cs-drop-link { font-size: clamp(0.875rem, 2vw, 1.25rem); color: #fff; }
}

/* Desktop - 1024px */
@media only screen and (min-width: 64rem) {
  #cs-navigation .cs-dropdown { position: relative; }
  #cs-navigation .cs-dropdown:hover { cursor: pointer; }
  #cs-navigation .cs-dropdown:hover .cs-drop-ul { opacity: 1; visibility: visible; transform: scaleY(1); }
  #cs-navigation .cs-dropdown:hover .cs-drop-li { opacity: 1; transform: translateY(0); }
  #cs-navigation .cs-drop-icon { width: 0.9375rem; height: auto; display: inline-block; }
  #cs-navigation .cs-drop-ul {
    min-width: 12.5rem; margin: 0; padding: 0; background-color: #fff; box-shadow: inset rgba(149, 157, 165, 0.1) 0px 8px 10px; opacity: 0;
    border-bottom: 5px solid var(--primary); border-radius: 0 0 1.5rem 1.5rem; visibility: hidden; position: absolute; top: 100%; z-index: 100001; overflow: hidden;
    transform: scaleY(0); transition: transform 0.3s, visibility 0.3s, opacity 0.3s; transform-origin: top;
  }
  /* Keep open when focused (keyboard) */
  #cs-navigation .cs-dropdown:focus-within .cs-drop-ul {
    opacity: 1; visibility: visible; transform: scaleY(1);
  }
  #cs-navigation .cs-drop-li {
    font-size: 1rem; text-decoration: none; list-style: none; width: 100%; height: auto; opacity: 0; display: block; transform: translateY(-0.625rem);
    transition: opacity 0.6s, transform 0.6s;
  }
  #cs-navigation .cs-drop-li:nth-of-type(1) { transition-delay: 0.05s; }
  #cs-navigation .cs-drop-li:nth-of-type(2) { transition-delay: 0.1s; }
  #cs-navigation .cs-drop-li:nth-of-type(3) { transition-delay: 0.15s; }
  #cs-navigation .cs-drop-li:nth-of-type(4) { transition-delay: 0.2s; }
  #cs-navigation .cs-drop-li:nth-of-type(5) { transition-delay: 0.25s; }
  #cs-navigation .cs-drop-li:nth-of-type(6) { transition-delay: 0.3s; }
  #cs-navigation .cs-drop-li:nth-of-type(7) { transition-delay: 0.35s; }
  #cs-navigation .cs-drop-li:nth-of-type(8) { transition-delay: 0.4s; }
  #cs-navigation .cs-drop-li:nth-of-type(9) { transition-delay: 0.45s; }
  #cs-navigation .cs-li-link.cs-drop-link {
    font-size: 1rem; line-height: 1.5em; text-transform: capitalize; text-decoration: none; white-space: nowrap; width: 100%; box-sizing: border-box;
    padding: 0.75rem; color: var(--headerColor); display: block; transition: color 0.3s, background-color 0.3s;
  }
  #cs-navigation .cs-li-link.cs-drop-link:hover { color: var(--bodyTextColorWhite); background-color: var(--primary); }
  #cs-navigation .cs-li-link.cs-drop-link:before { display: none; }
}

/*-- -------------------------- -->
<---     Desktop Navigation     -->
<--- -------------------------- -*/
/* Small Desktop - 1024px */
@media only screen and (min-width: 64rem) {
  body.scroll #cs-navigation { width: 100%; max-width: 100%; border-radius: 0; top: 0; }
  #cs-navigation {
    width: 94%; max-width: 90rem; height: 6rem; box-sizing: border-box; padding: clamp(0.75rem, 2vw, 1.5rem) 0; background-color: #fff;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px; border-radius: clamp(0.75rem, 2vw, 1.5rem); display: flex; align-items: center; position: fixed; top: 2rem; left: 50%; z-index: 10000; transform: translateX(-50%);
  transition: top 0.3s, border-radius 0.3s, width 0.3s, max-width 0.3s;
  z-index: 100000; /* ensure above content and footer */
  }
  #cs-navigation .cs-container { width: 100%; max-width: 90rem; margin: auto; box-sizing: border-box; padding: 0 1.5rem; display: grid; grid-template-columns: minmax(0,1fr) auto minmax(0,1fr); align-items: center; gap: 2rem; }
  #cs-navigation .cs-toggle { display: none; }
  #cs-navigation .cs-logo { grid-column: 1; justify-self: start; width: auto; max-width: none; height: 2rem; margin: 0 auto 0 0; padding: 0; display: flex; justify-content: flex-start; align-items: center; gap: 1rem; flex: 0 0 auto; z-index: 100; }
  #cs-navigation .cs-logo-text { white-space: nowrap; }
  #cs-navigation .cs-logo img { width: auto; height: 100%; object-fit: contain; }
  #cs-navigation .cs-contact-group { grid-column: 3; justify-self: end; display: flex; justify-content: flex-end; align-items: center; gap: 1.5rem; }
  #cs-navigation .cs-login-link { display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none; color: var(--headerColor); font-weight: 600; }
  #cs-navigation .cs-login-link:hover { color: var(--primary); }
  #cs-navigation .cs-login-icon { width: 1.125rem; height: 1.125rem; display: inline-block; }
  #cs-navigation .cs-phone { font-size: 1rem; line-height: 1.5em; text-decoration: none; margin: 0; color: var(--headerColor); display: flex; justify-content: flex-start; align-items: center; gap: 0.5rem; transition: opacity 0.3s, color 0.3s; }
  #cs-navigation .cs-phone-icon { width: 1.5rem; height: auto; display: block; }
  #cs-navigation .cs-social { height: 2rem; opacity: 1; display: none; visibility: visible; justify-content: center; align-items: center; gap: 0.5rem; transition: opacity 0.3s, visibility 0.3s, height 0.3s; }
  #cs-navigation .cs-social-link { text-decoration: none; width: 2rem; height: 2rem; background-color: #f7f7f7; border-radius: 50%; display: flex; justify-content: center; align-items: center; transition: background-color 0.3s; }
  #cs-navigation .cs-social-link:hover { background-color: var(--primary); }
  #cs-navigation .cs-social-link:hover .cs-social-icon { opacity: 1; filter: grayscale(1) brightness(10000%); }
  #cs-navigation .cs-social-icon { width: 0.75rem; height: auto; opacity: 0.6; display: block; transition: opacity 0.3s; }
  #cs-navigation .cs-nav { grid-column: 2; justify-self: center; position: static; }
  /* Center the nav list in the middle column without removing it from flow */
  #cs-navigation .cs-ul-wrapper { grid-column: 2; height: 100%; display: flex; align-items: center; justify-content: center; position: static; top: auto; left: auto; transform: none; }
  #cs-navigation .cs-ul { width: auto; height: 100%; margin: 0; padding: 0; display: flex; justify-content: center; align-items: center; gap: clamp(1.25rem, 2.6vw, 2.25rem); }
  #cs-navigation .cs-li { list-style: none; height: 100%; padding: 0; display: flex; align-items: center; flex: none; }
  #cs-navigation .cs-li-link { font-size: 1.5rem; line-height: 1.5em; text-decoration: none; margin: 0; color: var(--headerColor); display: block; position: relative; transition: color 0.3s; }
  #cs-navigation .cs-li-link:hover { color: var(--primary); }
  #cs-navigation .cs-li-link.cs-active { color: var(--primary); }
  #cs-navigation .cs-button-solid { font-size: 1rem; font-weight: 700; line-height: clamp(2.875em, 5.5vw, 3.5em); text-align: center; text-decoration: none; min-width: 9.375rem; margin: 0; box-sizing: border-box; padding: 0 2rem; color: #fff; background-color: var(--primary); display: inline-block; position: relative; z-index: 1; transition: color 0.3s; }
  #cs-navigation .cs-button-solid:before { content: ""; width: 0%; height: 100%; background: #fff; opacity: 1; position: absolute; top: 0; left: 0; z-index: -1; transition: width 0.3s; }
  #cs-navigation .cs-button-solid:hover { color: #1a1a1a; }
  #cs-navigation .cs-button-solid:hover:before { width: 100%; }
}

/* Large Desktop - 1300px */
@media only screen and (min-width: 81.25rem) {
  #cs-navigation .cs-social { display: flex; }
}
