* {
  font-family: "Roboto", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

*:not(html, head, meta, title, link, script, button, input, label) {
  display: flex;
  flex-direction: column;
}

*::selection {
  background-color: #ff0000;
}

html {
  width: 100vw;
  height: 100vh;
  background-color: #fff;
  x-overflow: hidden;
  visibility: hidden;
  position: absolute;
}

body {
  width: 100vw;
  background-color: #fff;
  overflow-y: scroll;
}

p, h1, h2, h3, h4, h5, h6, address {
  color: #212121;
  width: 100%;
}

p.center, h1.center, h2.center, h3.center, h4.center, h5.center, h6.center, address.center {
  text-align: center;
}

p {
  line-height: 1.4em;
}

h1 {
  font-size: 2.5em;
}

span.pseudoLink, p.pseudoLink {
  cursor: pointer;
  color: #1b37e8;
  font-weight: 500 !important;
}

a {
  color: #f4f4f4;
  text-decoration: none;
  transition: all 0.3s;
}

a:hover {
  color: #ff0000;
  fill: #ff0000;
}

a.coloredLink {
  color: #ff0000;
}

a.coloredLink:hover {
  text-decoration: underline;
}

ul {
  list-style: none;
}

ul li[active] a {
  color: #ff0000 !important;
}

img, video {
  max-width: 100%;
}

fieldset {
  border: none;
}

label {
  margin-bottom: .2em;
}

input, button {
  border-radius: 4px;
  border: 2px solid #ff0000;
  max-width: 100%;
  font-size: 14px;
  line-height: 24px;
  color: #ff0000;
  background-color: #ffffff;
}

input label, input::placeholder, button label, button::placeholder {
  color: #ff0000;
}

input::focus-visible, button::focus-visible {
  border: 2px solid #ff0000;
}

input {
  padding: .25em .5em;
  font-weight: 400;
}

button {
  flex: auto;
  padding: 8px;
  font-weight: 500;
  margin: 0 8px 0 0;
  cursor: pointer;
  text-align: center;
  text-transform: uppercase;
  transition: all .8s;
}

button.more {
  margin-top: 3em;
  flex: none;
  border-radius: 50px;
  padding: 1em 4em;
  font-size: 1em;
  background: transparent;
  color: #f4f4f4;
  border: 3px solid #f4f4f4;
}

button.highlighted {
  background-color: transparent;
  color: #ff0000;
  border-color: #ff0000;
}

button.colored {
  background-color: #ff0000;
  color: #f4f4f4;
  border-color: #ff0000;
}

button.colored:hover {
  color: #ff0000;
  background-color: #ffffff;
}

button:hover {
  color: #f4f4f4;
  background-color: #ff0000;
  transition: all 0.3s;
}

form {
  gap: 1em;
}

tooltip {
  content: attr(data-tooltip);
  position: absolute;
  background: #4e4b66;
  color: #fff;
  left: calc( 100% 7pc);
}

.articleList {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  gap: 2em;
  width: 100%;
  height: 100%;
  padding: 1em;
}

#article {
  width: 70vw;
  margin: auto;
}

#article h1, #article h2 {
  margin: 0 auto;
  text-align: center;
  max-width: 75%;
  word-break: break-word;
  white-space: normal;
}

#article h1 {
  margin-bottom: .2em;
  max-width: 85%;
}

#article .articleDate {
  text-align: center;
}

#article img {
  margin: 1em auto;
  width: 110%;
  align-self: center;
  height: auto;
}

article {
  display: flex;
  flex-direction: column;
  gap: 1em;
  width: 48%;
  height: 100%;
  padding: 1.5em;
  background-color: rgba(21, 21, 21, 0.4);
  border-radius: 6px;
  box-shadow: 0 -1px 10px 0 #acabab4d;
  overflow: hidden;
  cursor: pointer;
}

article a {
  gap: 1em;
}

article p, article h1, article h2, article h3, article img {
  margin: 0 !important;
  padding: 0 !important;
}

article:first-of-type {
  align-items: center;
  text-align: center;
  width: 100%;
  min-height: 30vh;
  justify-content: center;
}

article:first-of-type a {
  gap: 0;
}

article:first-of-type img {
  width: 60vw;
  height: auto;
  align-self: center;
}

article:first-of-type h2 {
  width: fit-content;
  align-self: center;
  color: #f4f4f4;
  padding: .5em 1em !important;
  transform: translateY(-3em);
  background-color: rgba(21, 21, 21, 0.5);
}

article:first-of-type h3 {
  transform: translateY(-1em);
}

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

article p {
  word-break: break-word;
  white-space: normal;
}

article h2 {
  font-size: 1.8em;
}

article h3 {
  font-weight: 420;
}

article.colored {
  background-color: #151515;
}

article.shadow {
  box-shadow: 0 -1px 10px 0 #acabab4d;
}

header #topBar {
  justify-content: space-between;
  align-items: center;
  padding: 1em 2em;
  background-color: #fff;
  flex-direction: row;
}

header #topBar .socialIcons, header #topBar #logo, header #topBar #login_register {
  width: 33%;
}

header #topBar .socialIcons {
  flex-direction: row;
  justify-content: flex-start;
}

header #topBar .socialIcons a {
  margin: 0 5px;
  color: #212121;
}

header #topBar .socialIcons a i {
  font-size: 25px;
}

header #topBar #logo {
  justify-content: center;
  align-items: center;
}

header #topBar #logo img {
  max-width: 16em;
}

header #topBar #login_register {
  flex-direction: row;
  justify-content: flex-end;
}

header #topBar #login_register a {
  width: auto;
}

header nav {
  width: 100%;
  min-height: 5em;
  padding: 1em 2em;
  justify-content: space-between;
  align-items: center;
  background-color: #151515;
  flex-direction: row;
}

header nav div {
  width: 10%;
}

header nav ul {
  list-style: none;
  gap: 10px;
  flex-direction: row;
}

header nav ul li {
  margin: 0 10px;
}

header nav ul li a {
  font-weight: 400;
}

header nav .search {
  width: 10%;
  flex-direction: row;
  justify-content: flex-end;
}

header nav .search form {
  flex-direction: row;
  justify-content: center;
}

header nav .search form input {
  width: 235px;
  transition: all 1s;
}

header nav .search form button {
  display: inherit;
  flex-direction: row;
  justify-content: center;
  border: none;
}

header nav .search form button i {
  font-size: 2em;
}

main {
  gap: 2em;
  margin: 2vh 8vw;
  overflow: hidden;
}

main #hero {
  margin-top: 1px;
}

main section p, main section address, main section contact {
  margin-bottom: 1em;
}

main section h1, main section h2, main section h3, main section .sectionSubtitle {
  margin-bottom: 1.5em;
}

main section .sectionSubtitle {
  font-weight: 600;
}

section {
  width: 100%;
  height: 100%;
}

section.centered {
  justify-content: center;
  align-content: center;
  align-items: center;
}

section.colored {
  background-color: #f4f4f4;
}

box {
  z-index: 999;
  background-color: #ffffff;
  border-radius: 6px;
}

box.fixed {
  position: fixed;
}

box.absoluteCentered {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

box.colored {
  background-color: #151515;
}

box.shadow {
  border: 1px solid #ffffff;
  box-shadow: 0 -1px 10px 0 #acabab4d;
}

box p {
  font-size: 14px;
  font-weight: 400;
  margin: 0;
}

box p.boxTitle {
  line-height: 24px;
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 12px;
}

box .boxButtons {
  justify-content: flex-end;
  margin-top: 16px;
}

box .boxHeader, box .boxBody, box .boxFooter {
  padding: 22px 24px;
}

box .boxHeader {
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  border-bottom: 2px solid #f4f4f4;
}

box .boxHeader i {
  font-size: 1.5em;
  cursor: pointer;
}

box .boxBody {
  overflow: auto;
}

box .boxBody div {
  padding: .5em 0 1em 0;
  border-bottom: 2px solid #f4f4f4;
}

box .boxBody div div {
  padding: 0;
  border: none;
}

box .boxBody div div i {
  padding-top: 3px;
}

box .boxBody > div:first-child, box .boxBody div:last-child {
  border: none;
}

box .boxBody .according {
  flex-direction: row;
  gap: .5em;
  border-bottom: 2px solid #f4f4f4;
  margin-bottom: 1em;
  padding-bottom: 1em;
  height: autp;
  transition: all .5s;
  cursor: pointer;
}

box .boxBody .according.collapsed {
  height: 6em;
}

box .boxBody .according h3, box .boxBody .according p {
  margin-bottom: 1em;
}

box .boxBody .according div {
  width: 100%;
}

box .boxBody .according div div {
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}

box .boxBody .according div div p {
  color: green;
  font-weight: 600;
  align-items: flex-end;
}

box .boxBody #cookieText {
  display: inline;
}

box .boxFooter .footerShadow {
  display: block;
  width: 100%;
  height: 40px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #ffffff 100%);
}

box.innerBox {
  background-color: #f4f4f4;
  position: relative;
  padding: 1em .5em !important;
  align-items: center;
  opacity: 1;
  cursor: default;
}

box.innerBox.unshown {
  visibility: hidden;
  position: absolute;
}

box.innerBox p {
  color: #212121 !important;
  margin: 0 !important;
}

#cookieIcon {
  bottom: 20px;
  left: 20px;
  padding: 4px;
  background-color: #ff0000;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

#cookieIcon i {
  color: #f4f4f4;
  font-size: 2.5em;
}

#cookieNotice {
  bottom: 40px;
  left: 40px;
  width: 440px;
  background-color: #ffffff;
  padding: 20px 26px;
}

#cookieNotice .boxButtons {
  gap: 4px;
}

#cookieSettings {
  background-color: #ffffff;
  width: 845px;
  height: 79vh;
}

#cookieSettings h3, #cookieSettings p {
  text-align: start;
}

#cookieSettings #cookieTextToggle {
  display: inline;
}

#cookieSettings .boxFooter {
  flex-direction: row;
}

#backToTop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  padding: 8px;
  background-color: #ff0000;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  width: 42px;
  opacity: 1;
  transition: all .5s;
  border: 1px solid;
}

#backToTop:hover {
  background-color: #ffffff;
  border: 1px solid #ff0000;
}

#backToTop i {
  font-size: 1.5em;
}

footer {
  background-color: #151515;
  color: #f4f4f4;
  padding: 2em 0;
  gap: 1em;
}

footer div {
  flex-direction: row;
  justify-content: space-around;
  align-items: flex-start;
}

footer div div {
  flex-direction: column;
}

footer div div h2 {
  color: #f4f4f4;
  margin: 0 0 1em 0;
}

footer div div ul {
  gap: 1em;
}

footer div div ul li, footer div div ul li a {
  flex-direction: row;
  align-items: center;
  gap: .5em;
}

footer div div ul li a, footer div div ul li address, footer div div ul li p, footer div div ul li svg {
  color: #f4f4f4;
  fill: #f4f4f4;
}

footer div div ul li i {
  font-size: 1.5em !important;
}

footer div div ul li p {
  text-align: center;
  margin: 0;
  color: inherit;
}

footer div div ul li svg {
  width: 1.4em;
  height: 1.4em;
  fill: inherit;
}

footer .AHN {
  flex-direction: row;
  justify-content: center;
  align-items: center;
  text-align: center;
  line-height: 1.5em;
}

footer .AHN p {
  font-size: 1em;
  font-weight: 400;
  color: #f4f4f4;
}

footer .AHN a {
  color: #ff0000;
  font-weight: 800;
}

.allowedSelect {
  user-select: text;
}

.hidden {
  display: none !important;
}

.invisible {
  opacity: 0 !important;
}

.unshown {
  opacity: 0 !important;
  width: 0px !important;
}

.videoContainer {
  position: relative;
  width: 100%;
  height: 100%;
}

.videoContainer video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.videoContainer .backgroundOverlay {
  width: 100%;
  height: 100%;
  position: absolute;
  background: #000;
  opacity: .4;
  inset: 0;
  z-index: 2;
}

.videoContainer .videoText {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 3;
  text-align: center;
  justify-content: center;
  align-items: center;
  gap: 1em;
  inset: 0;
}

.videoContainer h1, .videoContainer p, .videoContainer button {
  margin: 0;
  font-weight: 300;
  color: #f4f4f4;
}

.videoContainer h1 {
  font-size: 6em;
}

.videoContainer p {
  font-size: 1.5em;
}

.videoContainer button {
  font-weight: 400;
}

#aboutMe {
  justify-content: space-between;
  align-items: center;
  text-align: center;
  gap: 2em;
}

#aboutMe h3 {
  width: 20vw;
  padding-bottom: .5em;
  margin: 0;
  border-bottom: 2px solid #ff0000;
}

#aboutMe img {
  width: 40vw;
}

#aboutMe p {
  width: 50vw;
  color: #54595F;
}

#phoneView {
  justify-content: center;
  flex-direction: row;
  text-align: center;
  gap: 4em;
}

#phoneView .phone {
  align-items: center;
  width: 30%;
}

#phoneView .phone img {
  width: 80%;
}

#phoneView .phone .socialCounter, #phoneView .phone .socialCounterHeading, #phoneView .phone .socialCounterText {
  font-weight: 600;
  margin: 0;
}

#phoneView .phone .socialCounter {
  color: #ff0000;
  font-size: 5.5vw;
}

#phoneView .phone .socialCounterHeading {
  color: #212121;
  font-size: 1.5em;
  margin: .5em 0;
}

#phoneView .phone .socialCounterText {
  color: #54595F;
}

#partners {
  justify-content: center;
  align-items: center;
}

#partners h2 {
  color: #ff0000;
  margin: 1em;
}

#partners .partnerContainer {
  flex-direction: row;
  flex-wrap: wrap;
  flex-grow: 4;
  justify-content: center;
  align-content: center;
  align-items: center;
}

#partners .partnerContainer .partner {
  max-width: 25%;
  height: 30em;
  justify-content: space-between;
  align-items: center;
  overflow: hidden;
  padding: .5em;
  gap: 1em;
  text-align: center;
}

#partners .partnerContainer .partner p {
  margin: 0;
}

#partners .partnerContainer .partner .partnerLogo {
  height: 8em;
  justify-content: center;
  align-items: center;
  gap: 1em;
  margin-top: 2em;
}

#partners .partnerContainer .partner .partnerLogo a:hover {
  color: #212121 !important;
  fill: #212121 !important;
}

#partners .partnerContainer .partner .partnerLogo a img, #partners .partnerContainer .partner .partnerLogo a svg {
  width: 10em;
  max-height: 5em;
  margin: auto;
}

#partners .partnerContainer .partner .partnerName {
  font-weight: 600;
  font-size: 20px;
}

#partners .partnerContainer .partner .partnerDescription {
  color: #54595F;
  height: 40%;
}

#partners .partnerContainer .partner button {
  width: 80%;
  margin: 0;
  padding: .75em .5em;
  margin-bottom: 1em;
}

.contactForm label {
  gap: 0;
}

Box#login,
Box#register {
  justify-content: center;
  align-items: center;
  transform: translate(-50%, -65%);
  gap: 1em;
}

Box#login a,
Box#register a {
  align-items: center;
  width: 75%;
}

Box#login box,
Box#register box {
  padding: 2em;
  width: 25vw;
}

Box#login box h1, Box#login box p, Box#login box label,
Box#register box h1,
Box#register box p,
Box#register box label {
  color: #f4f4f4 !important;
}

Box#login box form input, Box#login box form input::placeholder,
Box#register box form input,
Box#register box form input::placeholder {
  color: #212121;
}

Box#login box div,
Box#register box div {
  justify-content: center;
  text-align: center;
}

Box#login box div span,
Box#register box div span {
  font-size: .6em;
}

Box#login box div span p, Box#login box div span a,
Box#register box div span p,
Box#register box div span a {
  display: inline;
}
