@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@900&display=swap");
/*
===========================================================================
    The Html variables are set in $templatedir/php/helper/variables.php 
===========================================================================
*/
/* CSS HEX */
* {
  box-sizing: border-box;
}

:root {
  font-size: 16px;
}
@media (min-width: 1200px) {
  :root {
    font-size: 18px;
  }
}
@media (min-width: 1600px) {
  :root {
    font-size: 20px;
  }
}

html {
  height: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Roboto", sans-serif;
  min-height: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

h2 {
  font-size: 1.618rem;
  font-weight: 900;
  color: #ff8c00;
  margin: 0;
}
h2 span {
  font-size: 2.617924rem;
  font-weight: 900;
  color: #ff8c00;
  margin: 0;
}
@media (min-width: 480px) {
  h2 {
    font-size: 2.617924rem;
  }
}

h3 {
  font-size: 1.618rem;
  margin: 0;
}

p {
  padding: 0;
  margin: 0;
  line-height: 170%;
}

table {
  line-height: 170%;
}

img {
  max-width: 100%;
  height: auto;
}

.link,
a {
  background: none;
  border: none;
  text-decoration: none;
  cursor: pointer;
  padding: 0;
}
.link:hover,
a:hover {
  color: #ff8300;
}

.margin {
  min-height: 90px;
}

.bigTitle {
  font-size: clamp(50px, 1rem + 10vw, 180px);
  font-weight: 900;
  color: rgba(17, 71, 151, 0.2);
  line-height: 80%;
  padding: 0 0 3rem 0;
  margin: 0;
  text-align: center;
}
@media (min-width: 1200px) {
  .bigTitle {
    margin: 0 0 -35px -75px;
    padding: 0;
    text-align: left;
  }
}

body {
  display: flex;
  flex-direction: column;
}

.site-grid {
  margin-bottom: auto;
}

.site-grid {
  display: grid;
  grid-template-areas: "titelbild " "comp" "side-r" "cont" "side-l" "bot-b";
  grid-template-columns: 100%;
  grid-gap: 0 0rem;
}
.site-grid > [class^=container-],
.site-grid > [class*=" container-"] {
  width: 100%;
  max-width: none;
  column-gap: 0rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (min-width: 1200px) {
  .site-grid {
    justify-content: space-between;
    grid-template-areas: "titelbild titelbild titelbild titelbild" "top-a     top-a     top-a     top-a    " "top-b     top-b     top-b     top-b    " "side-l    comp      comp      side-r   " "side-l    cont      cont      side-r   " "bot-a     bot-a     bot-a     bot-a    " "bot-b     bot-b     bot-b     bot-b    ";
    grid-template-columns: minmax(0, auto) [main-start] repeat(2, minmax(0, 100%)) [main-end] minmax(0, auto);
  }
}

@media (min-width: 1200px) {
  .container-sidebar-left div {
    margin-left: clamp(1rem, 0.5rem + 5vw, 4rem);
  }

  .container-sidebar-right div {
    margin-right: clamp(1rem, 0.5rem + 5vw, 4rem);
  }
}
.container-titelbild {
  grid-area: titelbild;
}

.container-component {
  grid-area: comp;
}

.container-content {
  grid-area: cont;
}

.container-sidebar-left {
  grid-area: side-l;
}

.container-sidebar-right {
  grid-area: side-r;
}

.container-bottom-b {
  grid-area: bot-b;
}

.grid-child {
  padding: 0;
}

.com-content-article .pagenavigation {
  display: none;
}
.com-content-article .icons {
  display: none;
}

main,
.item-page {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  max-width: var(--maxWidth);
}
main .item-image,
.item-page .item-image {
  margin: clamp(1rem, 0.5rem + 5vw, 4rem) 0;
  width: 100%;
}
main .item-image img,
.item-page .item-image img {
  width: 100%;
  max-height: 500px;
  object-fit: cover;
}
main p,
.item-page p {
  display: inline-block;
}

.container-content > *,
.container-component > * {
  padding: 0 clamp(1rem, 0.5rem + 5vw, 4rem);
}

#ID_4 > .site-grid > .container-content {
  padding: 0;
}

.mod-custom {
  max-width: var(--maxWidth);
  width: 100%;
}

.shadow {
  box-shadow: 0px 0px 50px rgba(0, 0, 0, 0.15);
}

.cover-image-wrapper {
  width: 100%;
  height: var(--titelbildheight);
}

.cover-image-wrapper-fullscreen {
  width: 100%;
  height: 90vh;
}
.cover-image-wrapper-fullscreen .cover-image {
  background-position: center bottom;
}

.cover-image {
  background-image: var(--titelbild);
  background-position: center;
  background-size: cover;
  height: 100%;
  position: relative;
}

.cover-image-headline {
  margin: 0;
  text-align: center;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2rem, 1rem + 5vw, 4.235801032rem);
  color: white;
  padding: 10vh clamp(1rem, 10vw, 5rem) 0 clamp(1rem, 10vw, 5rem);
}

.cover-image-fullscreen-divider {
  position: absolute;
  bottom: 0;
  left: 0;
  fill: white;
  height: 0px;
  width: 100%;
}
@media (min-width: 1200px) {
  .cover-image-fullscreen-divider {
    height: 100px;
  }
}
@media (min-width: 1600px) {
  .cover-image-fullscreen-divider {
    height: var(--dividerHeight);
  }
}

.texthighlight {
  border-radius: 10px;
  padding: 2rem;
  margin: 1rem 0;
  background-color: rgba(17, 71, 151, 0.2);
}
@media (min-width: 480px) {
  .texthighlight {
    padding: 3rem;
    margin-top: 3rem;
  }
}

.container-content .texthighlight {
  margin: 0;
  max-width: var(--maxWidth);
  padding-left: clamp(1rem, 0.5rem + 5vw, 4rem);
  padding-right: clamp(1rem, 0.5rem + 5vw, 4rem);
}
@media (min-width: 480px) {
  .container-content .texthighlight {
    margin: 0 clamp(1rem, 0.5rem + 5vw, 4rem);
  }
}

.texthighlight::after {
  content: "";
  clear: both;
  display: table;
}

.texthighlight table td {
  vertical-align: top;
  padding: 0.5rem 0;
}

.cardsmodule {
  width: 100%;
  max-width: 1920px;
  padding: 4rem clamp(1rem, 0.5rem + 5vw, 4rem);
}
@media (min-width: 800px) {
  .cardsmodule {
    padding: 4rem clamp(1rem, 0.5rem + 5vw, 4rem);
  }
}

.cardsmodule-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 3rem;
}
@media (min-width: 800px) {
  .cardsmodule-cards {
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  }
}
@media (min-width: 1200px) {
  .cardsmodule-cards {
    gap: 4rem;
  }
}

.cardsmodule-cards-card {
  width: 100%;
  height: 300px;
  perspective: 800px;
}
@media (min-width: 800px) {
  .cardsmodule-cards-card {
    height: 350px;
  }
}
.cardsmodule-cards-card:hover > .container {
  cursor: pointer;
  transform: rotateY(180deg);
}

.container {
  background-color: white;
  width: 100%;
  height: 100%;
  position: relative;
  transition: transform 500ms;
  transform-style: preserve-3d;
}
.container::before {
  content: "";
  background-color: #114797;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 20px;
  border-radius: 10px 10px 0 0;
}

.front {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.front,
.back {
  height: 100%;
  width: 100%;
  border-radius: 10px;
  position: absolute;
  backface-visibility: hidden;
}

.back {
  padding: 1.5rem;
  background-color: white;
  transform: rotateY(180deg);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5rem;
}
.back p {
  text-align: center;
}

.cardsmodule-cards-card-icon {
  height: 100px;
}

.cardsmodule-cards-card-label {
  color: #114797;
  margin-bottom: 0;
}

.sponsoren {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 8rem clamp(1rem, 0.5rem + 5vw, 4rem) 2rem clamp(1rem, 0.5rem + 5vw, 4rem);
  width: 100%;
  gap: 3rem;
}
.sponsoren .flex {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  gap: 1rem;
}
@media (min-width: 1600px) {
  .sponsoren .flex {
    flex-direction: row;
  }
}
.sponsoren .grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  max-width: var(--maxWidth);
  gap: 4rem;
}
.sponsoren .grid div {
  display: grid;
}
.sponsoren .grid div img {
  min-width: 100%;
  min-height: 100%;
  object-fit: contain;
}
@media (min-width: 800px) {
  .sponsoren .grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.sponsoren .grid > div::before {
  content: "";
  padding-bottom: 100%;
  display: block;
}
.sponsoren .grid > div::before,
.sponsoren .grid > div > img {
  grid-area: 1/1/2/2;
}

.sponsoren-headline {
  color: rgba(0, 0, 0, 0.5);
  text-align: center;
  font-weight: 700;
}

.sponsoren-pictures-sponsor {
  max-height: 90px;
  max-width: 100%;
}

.grey {
  opacity: 0.5;
  filter: grayscale(100%);
}

.textHighlight {
  color: #114797;
}

/* 
  REFACTORING LATER REQUIRED
  */
.news-frontpage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3rem;
  max-width: 1920px;
  padding: 4rem clamp(1rem, 0.5rem + 5vw, 4rem);
}
.news-frontpage a {
  display: block;
}
@media (min-width: 1200px) {
  .news-frontpage {
    display: grid;
    grid-template-areas: "header header header" "c1 c2 c3" ". button .";
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
    gap: 0 clamp(1rem, 0.5rem + 5vw, 4rem);
    align-items: stretch;
  }
}
@media (min-width: 1200px) {
  .news-frontpage .news-card-content {
    text-align: left;
  }
}
@media (min-width: 1200px) {
  .news-frontpage .news-card-content-button {
    margin: 0;
  }
}
.news-frontpage #card1 {
  grid-area: c1;
}
.news-frontpage #card2 {
  grid-area: c2;
}
.news-frontpage #card3 {
  grid-area: c3;
}

.news-other {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4rem;
  max-width: var(--maxWidth);
  padding: 4rem clamp(1rem, 0.5rem + 5vw, 4rem);
}
.news-other .news-header {
  margin: 0;
  padding-bottom: 4rem;
}
.news-other a {
  display: block;
}
.news-other .news-card-content {
  text-align: center;
}
.news-other .news-card-content .news-card-content-button {
  margin: 0 auto;
}

.news-header {
  padding: 0;
}

.news-card {
  background: white;
  border-radius: 10px;
  transition: all 100ms;
  color: inherit;
}
.news-card:hover {
  transform: scale(1.1);
  color: inherit;
}

.news-card-picture {
  border-radius: 10px 10px 0 0;
  height: 200px;
  background-size: cover;
  background-position: center;
}

.news-card-image {
  border-radius: 10px 10px 0 0;
  width: 100%;
  height: 100%;
  max-height: 200px;
  object-fit: cover;
}

.news-card-content {
  padding: 3rem 3rem 3.5rem 3rem;
  text-align: center;
}

.news-card-content-text {
  margin: 2rem 0 0 0;
  font-weight: 300;
}

.news-card-content-button {
  padding: 15px 20px;
  border-radius: 10px;
  background-color: #114797;
  color: white;
  width: fit-content;
  margin: 0 auto;
}

.news-allNewsButton {
  grid-area: button;
  text-align: center;
  margin-top: clamp(1rem, 0.5rem + 5vw, 4rem);
  font-weight: 500;
  color: white;
  background-color: #114797;
  padding: 15px;
  border-radius: 10px;
}

.background {
  max-width: 1920px;
  padding: 0 clamp(1rem, 0.5rem + 5vw, 4rem);
  width: 100%;
}

.events {
  background-color: rgba(17, 71, 151, 0.1);
  display: flex;
  justify-content: center;
  width: 100%;
  padding: 4rem 0;
  flex-direction: column;
  align-items: center;
}
.events a {
  display: block;
}

.events-header {
  max-width: 1920px;
  width: 100%;
}
@media (min-width: 1200px) {
  .events-header {
    margin: 0 0 -35px -130px;
    padding: 0 clamp(1rem, 0.5rem + 5vw, 4rem);
  }
}

.events-card {
  display: flex;
  justify-content: flex-end;
  flex-direction: column;
}
@media (min-width: 1200px) {
  .events-card {
    align-items: center;
    flex-direction: row;
  }
}

.events-card-mainEvent {
  transform: translateY(20%);
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (min-width: 1200px) {
  .events-card-mainEvent {
    transform: translateX(50%);
    width: 500px;
  }
}

.events-card-mainEvent-picture {
  width: 100%;
  height: 275px;
  object-fit: cover;
  object-position: center;
}

.events-card-mainEvent-text {
  background-color: white;
  font-weight: 900;
  width: 65%;
  margin-top: -3rem;
  padding: 1.5rem;
  border-radius: 10px;
}

.events-card-mainEvent-text-Highlight {
  color: orange;
  margin-bottom: 0.5rem;
}

.events-card-otherEvents {
  padding: 6rem 2rem 2rem 2rem;
  background: transparent linear-gradient(109deg, #114797 0%, #acbfdb 100%) 0% 0% no-repeat padding-box;
  height: max-content;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  border-radius: 10px;
}
@media (min-width: 480px) {
  .events-card-otherEvents {
    align-items: center;
    height: 450px;
    padding: 2rem;
  }
}
@media (min-width: 1200px) {
  .events-card-otherEvents {
    width: 70%;
  }
}

.events-card-otherEvents-content {
  color: white;
}

.events-card-otherEvents-content-headline {
  font-weight: 700;
  margin-bottom: 2rem;
}

.events-card-otherEvents-content-event {
  display: flex;
  gap: 1rem;
  margin: 0.75rem 0;
}
.events-card-otherEvents-content-event .name,
.events-card-otherEvents-content-event .date {
  font-size: 1rem;
  font-weight: 400;
}

.events-card-otherEvents-content-moreButton {
  margin-top: 2rem;
  display: block;
  color: white;
  border: solid 1px white;
  padding: 15px 20px;
  font-weight: 500;
}

.layouthelper {
  width: 25vw;
}

.media-scroller {
  width: 100%;
  display: grid;
  padding: 0;
  grid-auto-flow: column;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  background-color: #acbfdb;
}

.media-element {
  width: 100%;
  height: 300px;
  object-fit: cover;
  scroll-snap-align: start;
}

.fullVerticalSize {
  grid-auto-columns: max-content;
  gap: var(--horizontalGalleryGap);
  justify-content: space-between;
}
.fullVerticalSize .media-element {
  margin: 2.5rem 0;
  transition: all 100ms;
}
.fullVerticalSize .media-element:hover {
  transform: scale(1.1);
}

.adjustedVerticalSize {
  grid-auto-columns: 65%;
}
@media (min-width: 800px) {
  .adjustedVerticalSize {
    grid-auto-columns: 29%;
  }
}
@media (min-width: 1200px) {
  .adjustedVerticalSize {
    grid-auto-columns: 22%;
  }
}
@media (min-width: 1600px) {
  .adjustedVerticalSize {
    grid-auto-columns: 20%;
  }
}
.adjustedVerticalSize .media-element {
  padding: 2.5rem 0;
}

.actionbuttons {
  margin: 1rem 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 250px;
  gap: 1rem;
  align-self: flex-start;
  align-self: center;
}
@media (min-width: 1200px) {
  .actionbuttons {
    align-self: flex-start;
  }
}

.actionButton {
  text-align: center;
  padding: 15px 20px;
  border-radius: 10px;
  color: #114797;
}

.primaryButton {
  background-color: #ff8300;
}

.secondaryButton {
  background-color: #acbfdb;
}

.displaypersonal-wrapper {
  width: 100%;
}

.displaypersonal {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: var(--maxWidth);
  overflow-x: hidden;
  flex-direction: column;
}
@media (min-width: 1600px) {
  .displaypersonal {
    flex-direction: row;
  }
}

@media (min-width: 1600px) {
  .displaypersonal-right {
    flex-direction: row-reverse;
  }
}

.displaypersonal-personalbild {
  width: 300px;
  margin: 0;
}
@media (min-width: 1600px) {
  .displaypersonal-personalbild {
    width: 400px;
  }
}

.displaypersonal-background {
  width: 400px;
  z-index: -1;
  max-width: none;
}
@media (min-width: 1600px) {
  .displaypersonal-background {
    width: 550px;
  }
}

.displaypersonal-background-left {
  transform: scaleX(-1);
  margin: -70px 0 0 0;
}
@media (min-width: 1600px) {
  .displaypersonal-background-left {
    margin: 0 0 0 -200px;
  }
}

.displaypersonal-background-right {
  margin: -70px 0 0 0;
}
@media (min-width: 1600px) {
  .displaypersonal-background-right {
    margin: 0 -200px 0 0;
  }
}

.displaypersonal-textfield {
  display: flex;
  flex-direction: column;
  color: #114797;
  transform: translateY(-100px);
  margin-top: -125px;
}
@media (min-width: 1600px) {
  .displaypersonal-textfield {
    transform: translateY(0);
    margin-top: 0;
  }
}

@media (min-width: 1600px) {
  .displaypersonal-textfield-left {
    margin-left: -325px;
  }
}

@media (min-width: 1600px) {
  .displaypersonal-textfield-right {
    margin-right: -325px;
  }
}

.displaypersonal-textfield-name {
  font-weight: 900;
}

.displaypersonal-textfield-number {
  padding: 1rem 0;
}

.displaypersonal-textfield-sport {
  color: #ff8300;
  font-weight: 900;
}

.mod-menu {
  width: 100%;
  margin: 1rem 0;
  list-style-type: none;
  display: flex;
  flex-direction: column;
  padding: 0;
  text-align: center;
  gap: 1rem;
}
@media (min-width: 1200px) {
  .mod-menu {
    margin-top: 4rem;
    text-align: left;
  }
}
.mod-menu .nav-item {
  width: 100%;
  background-color: rgba(17, 71, 151, 0.2);
}
.mod-menu .nav-item a {
  color: #114797;
  padding: 2rem;
  display: block;
  width: 100%;
}
.mod-menu .nav-item:hover {
  background-color: #114797;
}
.mod-menu .nav-item:hover a {
  color: white;
}

.container-content .mod-menu {
  margin: 0;
  max-width: var(--maxWidth);
}
@media (min-width: 480px) {
  .container-content .mod-menu {
    margin: 0 clamp(1rem, 0.5rem + 5vw, 4rem);
  }
}

.horizontalshapes {
  display: grid;
  justify-content: center;
  grid-template-columns: 1fr 1fr;
}
@media (min-width: 1200px) {
  .horizontalshapes {
    grid-template-columns: repeat(4, 25%);
    gap: 3rem;
  }
}

.horizontalshapes-wrapper {
  display: grid;
  justify-items: center;
  align-items: center;
  grid-template-rows: 10rem;
}

.horizontalshapes-text {
  text-align: center;
  grid-column-start: 1;
  grid-row-start: 1;
  color: #114797;
  font-weight: 900;
}

.horizontalshapes-background {
  max-height: 100%;
  grid-column-start: 1;
  grid-row-start: 1;
  z-index: -1;
}
.link {
  display: block;
  text-align: left;
  padding: 1rem 1.5rem;
  font-size: 1rem;
}

/* 
REFACTORING LATER REQUIRED
*/
.name-and-logo {
  display: flex;
  align-items: center;
  height: 90px;
  padding-left: clamp(1rem, 0.5rem + 5vw, 4rem);
}

.logo {
  max-height: 60px;
}

.name {
  font-size: clamp(24px, 2.5vw, 50px);
  font-weight: 900;
  color: white;
  padding: 0;
  padding-left: 25px;
}

.arrow {
  width: 0.5em;
  height: 0.5em;
  display: inline-block;
  vertical-align: middle;
  border-left: 0.15em solid currentColor;
  border-bottom: 0.15em solid currentColor;
  transform: rotate(-45deg);
  margin-top: -0.25em;
  transition: transform 100ms ease-in-out;
  margin-left: 5px;
}

.dropdown-menu {
  position: absolute;
  left: 0;
  right: 0;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-10px);
  transition: opacity 150ms ease-in-out, transform 150ms ease-in-out;
  /* pointer-events: none; */
  display: flex;
  gap: 5rem;
  justify-content: center;
}

.dropdown-link {
  color: #114797;
  font-family: "Roboto", sans-serif;
  font-size: 16px;
  padding: 1rem 3rem;
}

.link:hover {
  color: #ff8300;
}

.dropdown-link:hover {
  background-color: #114797;
  color: white;
}

.dropdown.active > .link {
  font-weight: 900;
}

.dropdown.active > .dropdown-menu {
  opacity: 1;
  transform: translateY(13px);
  pointer-events: auto;
  outline: none;
}
.dropdown.active > .dropdown-menu .dropdown.active > .dropdown-menu {
  transform: translateY(0px);
}

header {
  position: fixed;
  z-index: 999;
  top: 0;
  left: 0;
  right: 0;
  height: 90px;
  background-color: #114797;
  max-width: 100%;
}

.header-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.header-nav-links {
  display: flex;
  justify-content: center;
  padding-right: clamp(1rem, 0.5rem + 5vw, 4rem);
  color: white;
}

.header-nav-links > :last-child {
  padding-right: 0;
}

.header-nav-links-dropdown-level2 {
  background-color: #acbfdb;
  gap: 0;
}

.level2-dropdown-level3 {
  background-color: #dce4f0;
  gap: 0;
}

.header-nav-MenuButtonContainer {
  position: relative;
  display: none;
  min-width: 80px;
  height: 61px;
  cursor: pointer;
  transition: all 250ms ease-in-out;
  /* border: 3px solid #fff; */
}

.header-nav-MenuButtonContainer-BurgerButton {
  width: 40px;
  height: 3px;
  background: white;
  border-radius: 5px;
  transition: all 0.5s ease-in-out;
}
.header-nav-MenuButtonContainer-BurgerButton::before, .header-nav-MenuButtonContainer-BurgerButton::after {
  content: "";
  position: absolute;
  width: 40px;
  height: 3px;
  background: white;
  border-radius: 5px;
  transition: all 0.5s ease-in-out;
}
.header-nav-MenuButtonContainer-BurgerButton::before {
  transform: translateY(-12px);
}
.header-nav-MenuButtonContainer-BurgerButton::after {
  transform: translateY(12px);
}

/* ANIMATION */
.header-nav-MenuButtonContainer.open .header-nav-MenuButtonContainer-BurgerButton {
  transform: translateX(-50px);
  background: transparent;
  box-shadow: none;
}

.header-nav-MenuButtonContainer.open .header-nav-MenuButtonContainer-BurgerButton::before {
  transform: rotate(45deg) translate(35px, -35px);
}

.header-nav-MenuButtonContainer.open .header-nav-MenuButtonContainer-BurgerButton::after {
  transform: rotate(-45deg) translate(35px, 35px);
}

.header-nav-links-dropdown-Level1Button {
  font-size: 20px;
  color: #fff;
}

@media (max-width: 1200px) {
  button {
    width: 100%;
  }

  /* 
  REFACTORING LATER REQUIRED
  */
  .name-and-logo {
    position: static;
    width: auto;
    padding-left: 20px;
  }

  .logo {
    display: none;
  }

  .name {
    position: static;
    font-size: 1.25rem;
  }

  .dropdown-menu {
    position: absolute;
    top: 0;
    left: 0;
    padding: 1.5rem 0;
    border-left: 2px dashed #114797;
    min-width: 16rem;
    transform-origin: top center;
    opacity: 0;
    transform: scaleY(0) translateY(0);
    transition: transform ease-in-out 100ms;
    border-radius: 0;
  }

  .dropdown-links {
    position: absolute;
    top: 0;
    left: 0;
    margin-left: 24px;
    border-left: 2px dashed #114797;
    min-width: 16rem;
    transform-origin: top center;
    opacity: 0;
    transform: scaleY(0) translateY(0);
    transition: transform ease-in-out 100ms;
  }
  .dropdown-links:active .dropdown-menu {
    position: relative;
    opacity: 1;
    transform: scaleY(1);
  }
  .dropdown-links:active .large-box:active .dropdown-links {
    position: relative;
    opacity: 1;
    transform: scaleY(1);
  }
  .dropdown-links:active .large-box:active .dropdown-links .arrow {
    transform: rotate(225deg);
  }

  .dropdown.active > .link + .dropdown-menu,
.large-box.active > .link + .dropdown-links {
    position: relative;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  .dropdown.active > .link,
.large-box.active > .link,
.link:hover {
    color: white;
    background-color: #114797;
  }
  .dropdown.active > .link .arrow,
.large-box.active > .link .arrow,
.link:hover .arrow {
    transform: rotate(225deg);
  }

  .open ~ .header-nav-links {
    transform: scaleY(1);
    opacity: 1;
  }

  .header-nav {
    flex-direction: row;
    justify-content: space-between;
  }

  .header-nav-links {
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    gap: 0;
    position: absolute;
    padding: 0;
    padding-bottom: 75px;
    top: 90px;
    width: auto;
    left: 0;
    right: 0;
    height: 90vh;
    transform: scaleY(0);
    opacity: 0;
    transform-origin: top center;
    transition: 200ms transform cubic-bezier(0.36, 0.4, 0.42, 1.48) 100ms, 100ms opacity ease-in-out;
    overflow-y: auto;
    overflow-x: hidden;
    background-color: white;
  }

  .header-nav-links-dropdown-level2,
.level2-dropdown-level3 {
    flex-direction: column;
  }

  .header-nav-links-dropdown-Level1Button {
    color: #114797;
  }

  .header-nav-MenuButtonContainer {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
body {
  position: relative;
}

.footer-name-and-logo {
  display: flex;
  align-items: center;
  gap: 1rem;
}

/* 
REFACTORING LATER REQUIRED
*/
.footer .name {
  font-size: 1.618rem;
  font-weight: 500;
  margin: 0;
  padding: 0;
  color: white;
  width: 100%;
  text-align: center;
}
@media (min-width: 800px) {
  .footer .name {
    text-align: left;
  }
}
.footer .logo {
  height: 45px;
}

.footer {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  min-height: 50px;
  background-color: #114797;
  padding: 2rem clamp(1rem, 0.5rem + 5vw, 4rem);
  display: grid;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-template-areas: "logo" "menu" "menu" "menu" "contactinfo" "rights";
  text-align: center;
}
@media (min-width: 800px) {
  .footer {
    grid-template-columns: 50% repeat(3, 1fr);
    grid-template-areas: "logo menu menu menu" "rights . . contactinfo";
    text-align: left;
  }
}
@media (min-width: 1200px) {
  .footer {
    grid-template-columns: 60% repeat(3, 1fr);
  }
}

.footer-menu {
  display: flex;
  flex-direction: column;
  align-items: center;
  grid-area: menu;
  width: 100%;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 1.5rem 0;
}
@media (min-width: 800px) {
  .footer-menu {
    flex-direction: row;
    padding: 0;
  }
}

.footer-menu-links {
  color: white;
  font-weight: 500;
  padding: 0;
}

.footer-contactinfo {
  grid-area: contactinfo;
  display: flex;
  flex-direction: column;
  color: rgba(255, 255, 255, 0.5);
}
.footer-contactinfo p {
  padding: 0;
  margin: 0;
}
.footer-contactinfo .footer-contactinfo-email {
  padding-top: 1rem;
}
@media (min-width: 800px) {
  .footer-contactinfo {
    justify-self: flex-end;
    text-align: right;
    font-size: 0.8rem;
  }
}

.footer-content {
  grid-area: rights;
  padding: 1rem 0;
  color: rgba(255, 255, 255, 0.5);
}
@media (min-width: 800px) {
  .footer-content {
    font-size: 0.8rem;
  }
}

/*# sourceMappingURL=template.css.map */
