:root {
  --header-height: 3rem;
  --footer-height: 4rem;
  --clr-bg: rgb(43, 43, 43);
  --clr-dark: var(--clr-bg);
  --clr-light: rgb(230, 230, 230);
  --clr-primary: #56b4eb;
  --clr-accent: #250feb;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  font-size: 18px;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  background-color: var(--clr-bg);
  color: var(--clr-light);
  -ms-overflow-style: none;
  scrollbar-width: none;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar {
  display: none;
}

header {
  height: var(--header-height);
  background-color: var(--clr-light);
  color: var(--clr-dark);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-inline: 2rem;
}
header #logo {
  display: flex;
  align-items: center;
  font-weight: 700;
}
header #logo .logo {
  height: 2.5rem;
}
header a,
header a:visited,
header a:active,
header a:focus {
  padding: 0.5rem 1rem;
  color: var(--clr-dark);
  background-color: transparent;
  border: 1px solid currentColor;
  text-decoration: none;
  transition: all 500ms ease-in-out;
}
header a:hover,
header a:visited:hover,
header a:active:hover,
header a:focus:hover {
  color: var(--clr-primary);
}

main {
  min-height: calc(100lvh - (var(--header-height) + var(--footer-height)));
  padding: 0rem;
  max-width: 100dvw;
  display: grid;
  gap: 1rem;
}
main section {
  margin: 2rem 0 0;
}
main section > h3, main section > p, main section > ol {
  padding: 0 3rem;
  line-height: 1.7rem;
}
main section ol {
  margin: -1.5rem 0 0 1rem;
}
main section.invert {
  background-color: white;
  color: black;
  padding-bottom: 2rem;
  box-shadow: inset 0 0 1rem 0.25rem black;
  display: grid;
  grid-template-columns: 1fr;
  width: 100%;
}
main section.invert .rules {
  width: 100%;
  max-width: 1800px;
  margin: 0 auto;
}
main section.invert .rules h3 {
  padding: 1rem 3rem;
}
main section.invert .logo {
  width: 100%;
  max-width: 1800px;
  margin: 0 auto;
}
main section.invert .logo img {
  max-height: 20rem;
  max-width: 99vw;
}
main section.invert a {
  color: var(--clr-primary);
}
main section.invert a:hover {
  color: var(--clr-accent);
}
main a,
main a:visited {
  color: var(--clr-accent);
  font-weight: 700;
  transition: all 500ms ease-in-out;
}
main a:hover, main a:active,
main a:visited:hover,
main a:visited:active {
  color: var(--clr-primary);
}
main a.btn,
main a:visited.btn {
  padding: 0.5rem 2rem;
  font-size: 1.5rem;
  border: 2px solid var(--clr-accent);
  background-color: var(--clr-primary);
  border-radius: 0.25rem;
  text-decoration: none;
}
main a.btn:hover, main a.btn:active,
main a:visited.btn:hover,
main a:visited.btn:active {
  background-color: var(--clr-light);
  border-color: var(--clr-primary);
  color: var(--clr-primary);
}
main .flyer-container {
  margin: 0 auto;
  width: 100dvw;
  position: relative;
  display: grid;
  padding-bottom: 1rem;
}
main .flyer-container::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("./assets/images/flyer/Winter Workshop Background.png");
  background-position: center top;
  background-size: cover;
  transition: opacity 500ms ease-in-out;
}
main .flyer-container-background {
  -o-object-fit: cover;
     object-fit: cover;
  max-width: calc(100dvw - 2rem);
  width: 100%;
  position: absolute;
  z-index: 1;
}
main .flyer-container-title {
  max-width: calc(80dvw - 2rem);
  width: 80%;
  position: relative;
  z-index: 1;
  margin: 3rem 0;
  align-self: center;
  justify-self: center;
}
main .info {
  position: relative;
  z-index: 2;
  max-width: calc(100dvw - 4rem);
  margin-left: 2rem;
  font-weight: 700;
  color: var(--clr-bg);
  text-shadow: 0 0 0.5rem var(--clr-light);
}
main .info p,
main .info a {
  background-color: hsla(0, 0%, 100%, 0.5);
  border-radius: 1rem;
  padding: 0.5rem;
  display: inline-flex;
}
main .info p.fade-bg,
main .info a.fade-bg {
  background-image: linear-gradient(to right, hsla(0, 0%, 100%, 0.5), hsla(0, 0%, 100%, 0));
  background-color: transparent;
}
main .info p.no-bg,
main .info a.no-bg {
  padding: 0;
  border-radius: 0;
  background-color: transparent;
  display: initial;
  margin-bottom: 1rem;
}
main .info-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: auto 1fr;
}
main .info .qr {
  height: 10rem;
}
main .more {
  display: grid;
  padding: 0;
  max-width: 100dvw;
  grid-template-columns: repeat(auto-fit, minmax(min(35rem, 100%), 1fr));
  margin: 3rem 0 1.5rem;
  row-gap: 1rem;
  justify-content: center;
}
main .more .card {
  box-shadow: 0 1rem 1rem 0.5rem black;
  display: grid;
  grid-template-rows: auto 1fr auto;
  max-width: 30rem;
  justify-self: center;
  margin: 1rem 0;
}
main .more .card-header {
  background-color: var(--clr-primary);
  color: var(--clr-dark);
  font-size: 1.5rem;
  border-radius: 5px 5px 0 0;
  padding-inline: 0.5rem;
}
main .more .card-body {
  border-left: 2px solid var(--clr-primary);
  border-right: 2px solid var(--clr-accent);
  padding: 0.5rem;
  text-align: center;
  min-height: calc(390px + 1rem);
}
main .more .card-body img {
  width: 260px;
  height: 390px;
  margin-left: 1rem;
  -o-object-fit: cover;
     object-fit: cover;
  margin-right: 0;
}
main .more .card-body p {
  text-align: left;
}
main .more .card-footer {
  background-color: var(--clr-accent);
  color: var(--clr-light);
  font-size: 1.5rem;
  border-radius: 0 0 5px 5px;
  padding-inline: 0.5rem;
}

.call-to-action {
  min-height: 6rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

footer {
  height: var(--footer-height);
  background-color: var(--clr-primary);
  color: var(--clr-dark);
  display: flex;
  align-items: center;
  padding-inline: 2rem;
}

.emphasis {
  font-style: italic;
  font-weight: 700;
}

@media screen and (width < 1350px) {
  main .flyer-container::after {
    opacity: 0.5;
  }
}
@media screen and (width < 1000px) {
  main {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
  }
}
@media screen and (width < 500px) {
  main .info-grid {
    white-space: wrap;
  }
}
@media screen and (width < 438px) {
  header #logo span {
    display: none;
  }
}
@media screen and (width < 375px) {
  main .info-grid {
    grid-template-columns: 1fr;
  }
}
@media screen and (width > 1100px) {
  main section.invert {
    width: 100%;
    grid-template-columns: repeat(2, 1fr);
  }
}/*# sourceMappingURL=styles.css.map */