/* inter-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/inter-v20-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* inter-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/inter-v20-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
:root {
  --orange: #EA8118;
  --lightblue: #38B6FF;
  --red: #DB0D11;
  --green: #64AC13;
  --gradient-start: rgb(4, 45, 91);
  --gradient-end: rgb(11, 28, 53);
  --cassiopeia-color-primary: rgb(4, 45, 91);
  --cassiopeia-color-hover: rgb(11, 28, 53);
  --cassiopeia-font-family-headings: 'Inter';
  --cassiopeia-font-weight-headings: 600;
  --cassiopeia-font-family-body: 'Inter';
  --body-font-size: 1.1rem;
  --body-bg: #f3f3f3;
  --link-color: var(--cassiopeia-color-primary);
}
h1 {
  margin-block-end: 2rem;
}
h2 {
  margin-block-end: 1rem;
}
@media (width >= 1200px) {
  h3, .h3 {
    font-size: 1.5rem;
  }
}
p + h2 {
  margin-block-start: 2rem;
}
.btn {
  --btn-font-weight: 600;
  &:focus-visible {
    outline: 2px dotted currentColor;
  }
}
.card {
  --card-border-width: 0;
  --card-border-color: transparent;
  --card-box-shadow: var(--bs-box-shadow-sm);
  --card-bg: #fff;
  --card-cap-bg: #fff;
}
.card-header {
  padding-inline: 2rem;
  padding-block: 1.5rem .5rem;
}
.card-body {
  padding-inline: 2rem;
  padding-block: .5rem 1.5rem;
}
body:not(.home) {
  .container-header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-areas: "top below"
                         "logo logo"
                         "nav nav";
  }
  .container-header .container-topbar {
    padding: .5em;
  }
  .container-header .container-topbar {
    grid-area: top;
  }
  .container-header .container-below-top {
    grid-area: below;
    justify-content: flex-end;
  }
  .container-header .grid-child:has(.navbar-brand) {
    grid-area: logo;
  }
  .container-header .container-nav {
    grid-area: nav;
  }
  @media (width >= 991.98px) {
    .container-header {
        grid-template-columns:
            [full-start] minmax(0,1fr)
            [main-start] repeat(4,minmax(0,19.875rem))
            [main-end] minmax(0,1fr)[full-end];
        grid-template-areas: ". logo nav nav nav .";
        gap: 0 1rem;
    }
    .container-header:has(.container-below-top, .container-topbar) {
        grid-template-areas: ". top top below below ."
                             ". logo nav nav nav .";
    }
  }
}
.container-header .container-below-top {
  padding-block-end: 0;
}
.home .container-below-top {
  justify-content: flex-end;
}
.container-component > :first-child,
.container-sidebar-left > :first-child,
.container-sidebar-right > :first-child,
.container-component > * + *,
.container-sidebar-left > * + *,
.container-sidebar-right > * + * {
  margin-top: 3em;
}
.container-sidebar-right .sidebar-right:first-child {
  margin-top: 3em;
}
@media (width >= 768px) {
  .container-header .container-nav {
    justify-content: flex-end;
    min-height: 113px;
  }
}
@media (width < 992px) {
  .nav-brand {
    margin-inline: auto;
  }
}
.container-header nav {
  text-transform: uppercase;
}
.home .container-banner {
  background-color: var(--cassiopeia-color-primary);
}
.container-banner .banner-overlay {
  height: calc(100vh - 113px);
  .overlay {
    background-color: transparent;
    height: calc(100vh - 113px);
  }
}
.subline {
  color: var(--lightblue);
  text-transform: uppercase;
  font-size: 1.5rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  border-block-start: 1px solid rgba(255, 255, 255, .8);
  padding-block-start: 1rem;
}
@media (width < 692px) {
  .subline {
    flex-direction: column;
    text-align: center;
  }
}
.slogan {
  font-weight: 600;
  font-size: clamp(2rem, 1.412rem + 3.137vi, 4rem);
  text-transform: uppercase;
  padding-block-end: 2rem;
}
.buttons {
  display: flex;
  justify-content: center;
  gap: 1rem;
  text-transform: uppercase;
}
.btn-ticket {
  --btn-bg: var(--orange);
  &:hover, &:focus-visible {
    --btn-hover-bg: #ed953c;
    --btn-hover-color: var(--body-color);
  }
}
.btn-speaker {
  --btn-bg: var(--lightblue);
  &:hover, &:focus-visible {
    --btn-hover-bg: #5fc4ff;
    --btn-hover-color: var(--body-color);
  }
}
.container-banner:has(.headline) {
  background-color: var(--cassiopeia-color-primary);
  background-image: linear-gradient(135deg,var(--cassiopeia-color-primary)0%,var(--cassiopeia-color-hover)100%);
  .headline {
    max-width: 1320px;
    margin-inline: auto;
    .subline {
      font-size: 1rem;
      padding-inline: .5em;
    }
  }
}
.home .container-top-a {
  background-color: #fff;
}
.footer {
  margin-top: 0;
}
.footer .grid-child {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: auto;
  grid-template-areas: "menu menu" "language language" "newsletter newsletter";
  align-items: flex-start;
  gap: 2rem;
  .mod-menu {
    grid-area: menu;
  }
  .mod-languages {
    grid-area: language;
  }
  .newsletter {
    grid-area: newsletter;
  }
  @media (width >= 992px) {
    grid-template-areas: "menu newsletter" "language newsletter";
    grid-auto-rows: 1fr;
  }
}
footer .newsletter {
  label {
    display: flex;
    gap: .5rem;
    > span {
      width: 60px;
    }
  }
  .btn-primary {
    color: var(--cassiopeia-color-primary);
    background-color: #fff;
    border-bottom: #fff;
    &:hover, &:focus-visible {
      background-color: var(--red);
      color: #fff;
    }
  }
}
/* News */
.mod-articles-item {
  height: 100%;
  .item-image {
    order: -1;
    img {
      border-radius: var(--border-radius) var(--border-radius) 0 0;
      width: 100%;
    }
  }
  .mod-articles-item-content {
    padding: 2rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    .readmore {
      margin-block-start: auto;
    }
  }
}
.mod-articles-date,
.published,
.modified {
  font-size: .95rem;
}
.article-info {
  margin-block-start: 2rem;
}
.accordion-button {
  font-size: 1.2rem;
}
/* Speakers */
.speakers h2 {
  text-align: center;
}
.category-desc {
  margin-block-end: 3rem;
}
.com-contact-single {
  position: relative;
  background-color: #fff;
  height: 100%;
  a {
    text-decoration: none;
    color: var(--body-color);
  }
  .contact-thumbnail {
    aspect-ratio: 1/1;
    object-fit: cover;
  }
}
@media (width >= 1200px) {
  .com-contact-single h2 {
    font-size: 1.5rem;
  }
}
#jform_com_fields_language .radio,
#jform_com_fields_typ .radio {
  display: flex;
  gap: 1.5rem;
}
.form-check-input {
  border-color: #989898;
}
/* Testimonials */
.container-bottom-b {
  grid-column: full-start/full-end;
  padding: 4rem 1em;
  background-color: var(--lightblue);
  margin-block-start: 3rem;
   & .bottom-b {
    max-width: 1320px;
    margin-inline: auto;
  }
}
.testimonials {
  h2 {
    margin-block-end: 2rem;
  }
  li {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    @media (min-width: 600px) {
      grid-template-columns: 1fr 2fr;
    }
  }
  .mod-articles-items {
    display: flex;
    flex-direction: column;
    gap: 2rem;
  }
  .mod-articles-item-content {
    padding: 1.5rem;
  }
  .item-image {
    margin-bottom: 0;
    img {
      border-radius: var(--border-radius) 0 0 var(--border-radius);
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
  }
}
.testimonial-tagline {
  font-size: 1.3rem;
  font-weight: 600;
}
@media (min-width: 600px) {
  .testimonials-small li {
    grid-template-columns: 250px auto;
    align-items: flex-start;
  }
}
/* speaker training */
.speaker {
  background: linear-gradient(180deg, #0bb58a 0%, #099f7a 100%);
  color: #ffffff;
  padding: 40px 30px;
  position: relative;
  .mod-custom {
    padding: 1rem;
  }
  .logo {
    width: 70px;
    margin-bottom: 40px;
  }
  .headline {
    font-size: 64px;
    font-weight: 700;
    line-height: 1.05;
    margin-bottom: 30px;
  }
  .subtext {
    font-size: 34px;
    font-weight: 400;
    line-height: 1.2;
    margin-bottom: 50px;
  }
  .hashtag {
    font-size: 32px;
    font-weight: 700;
    color: #ffb020;
  }
  .signup a {
    font-size: 32px;
    font-weight: 700;
    color: #fff;
  }
}
/* AcyMailing */
.acym_module_form .onefield {
  margin: 1.5rem 0 !important;
}
/* Tickets */
.pretix-widget-wrapper {
  padding-block: 1rem 2rem;
}

/*Social icons */
.moduletable.social .mod-menu {
  flex-direction: row;
}