/*! Handmade with love by https://esmes.fi */
/* RESET */
*,
::before,
::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
}

html {
  margin: 0;
  padding: 0;
  height: 100%;
}

body {
  margin: 0;
  padding: 0;
  height: 100%;
  -webkit-text-size-adjust: 100%;
}

/*input,
textarea {
  border: 0;
  border-radius: 0; // Fix awful iOS default
  font: inherit;
  -webkit-appearance: none;
}*/
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
}

/* HTML5 for old-ie */
article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section {
  display: block;
}

template {
  display: none;
}

address,
button,
input,
optgroup,
select,
textarea {
  font: inherit;
}

a img {
  border-style: none;
}

/* Responsive SVG */
img[src*=".svg"] {
  width: 100%;
  height: auto;
}

:root {
  font-size: 16px;
  --app-height: 100vh;
  --body-text-size: 1rem;
  --body-text-line-height: 140%;
  --header-height: 5.75rem;
  --logo-height: 9.375rem;
  --safety-padding: 4.375rem;
  --layout-width: 90rem;
  --main-bottom-padding: 6.25rem;
  --container-max-width: 90rem;
}

:root {
  font-size: 1.1111111111vw;
}

#audio-announcer {
  display: none;
}

html, body {
  height: 100%;
}

body {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  font-family: "Public Sans";
  font-weight: 300;
  color: #144B5B;
  overflow: hidden;
}

body.page-template-page-template-groups {
  overflow: initial;
}

header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
  font-size: 1rem;
}
header nav ul li a {
  color: #144B5B;
  position: relative;
}

nav {
  padding: 0.625rem;
}
nav ul {
  display: flex;
  gap: 0.9375rem;
  justify-content: center;
}
nav ul li {
  display: inline-block;
}
nav ul li a {
  position: relative;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
  display: block;
  padding: 0.5rem 1rem;
  /*&[target="_blank"]{
    text-transform: none;
    &::after {
      transform: translateY(p(-1));
      display: inline-block;
      width: p(10);
      height: p(14);
      vertical-align: middle;
      margin-left: p(8);
      content: '';
      mask: url('../svg/caret-right.svg') no-repeat 50% 50%;
      mask-size: contain;
      background-color: currentColor;
    }
  }*/
}
nav ul li a:hover {
  font-style: italic;
}
nav ul li a:not(.button):hover::before {
  content: "";
  position: absolute;
  bottom: 0.25rem;
  left: 1rem;
  right: 1rem;
  border-bottom: 0.125rem solid currentColor;
}
nav ul li a.groups::after {
  transform: translateY(-0.125rem);
  display: inline-block;
  width: 0.75rem;
  height: 0.875rem;
  vertical-align: middle;
  margin-left: 0.5rem;
  content: "";
  background: url("../svg/icon-groups.svg") no-repeat 50% 50%;
  background-size: contain;
}
nav ul li a.active::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 1rem;
  right: 1rem;
  background-color: currentColor;
  height: 0.125rem;
}

.controls {
  position: absolute;
  top: -1px;
  right: 0.625rem;
  display: flex;
  gap: 0.625rem;
  z-index: 990;
}
.controls button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: none;
  font-size: 0;
  color: transparent;
  position: relative;
  width: 2rem;
  height: 2rem;
  background-color: #000;
  transition: background-color 0.25s, border-color 0.25s;
  border: 0.125rem solid #000;
  border-top: 0;
  border-bottom-left-radius: 1rem;
  border-bottom-right-radius: 1rem;
}
.controls button::before, .controls button::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #fff;
  -webkit-mask-size: 100% auto;
          mask-size: 100% auto;
  -webkit-mask-position: 50% 50%;
          mask-position: 50% 50%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
}
.controls button:hover {
  background-color: #DC92F5;
  border-color: #DC92F5;
}
.controls button:hover::before, .controls button:hover::after {
  background-color: #000;
}
.controls button::after {
  opacity: 0;
}
.controls button[data-action=open-settings]::before {
  -webkit-mask-image: url("../svg/icon-settings.svg");
          mask-image: url("../svg/icon-settings.svg");
  -webkit-mask-size: 1.0625rem auto;
          mask-size: 1.0625rem auto;
}
.controls button[data-action=open-settings]::after {
  -webkit-mask-image: url("../svg/icon-settings-close.svg");
          mask-image: url("../svg/icon-settings-close.svg");
  -webkit-mask-size: 0.875rem auto;
          mask-size: 0.875rem auto;
}
.controls button[data-action=mute]::before {
  -webkit-mask-image: url("../svg/icon-mute.svg");
          mask-image: url("../svg/icon-mute.svg");
  -webkit-mask-size: 1.125rem auto;
          mask-size: 1.125rem auto;
}
.controls button[data-action=mute]::after {
  -webkit-mask-image: url("../svg/icon-muted.svg");
          mask-image: url("../svg/icon-muted.svg");
  -webkit-mask-size: 1.125rem auto;
          mask-size: 1.125rem auto;
}
.controls button[data-action=fullscreen]::before {
  -webkit-mask-image: url("../svg/icon-fullscreen.svg");
          mask-image: url("../svg/icon-fullscreen.svg");
  -webkit-mask-size: 0.875rem auto;
          mask-size: 0.875rem auto;
}
.controls button[data-action=fullscreen].--active {
  background-color: #fff;
  border-color: #000;
}
.controls button[data-action=fullscreen].--active::before {
  background-color: #000;
}
.controls button[data-action=fullscreen].--active:hover {
  background-color: #DC92F5;
}

body.--muted .controls button[data-action=mute] {
  background-color: #fff;
  border-color: #000;
}
body.--muted .controls button[data-action=mute]::before {
  opacity: 0;
}
body.--muted .controls button[data-action=mute]::after {
  background-color: #000;
  opacity: 1;
}
body.--muted .controls button[data-action=mute]:hover {
  background-color: #DC92F5;
}

.button {
  position: relative;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
  display: inline-block;
  padding: 0.5rem 1rem;
  background-color: rgba(20, 75, 91, 0.3019607843);
  color: #144B5B;
  transition: color 0.25s, background-color 0.25s;
}
.button:hover {
  background-color: #144B5B;
  color: #fff;
}
.button.--black {
  color: #fff;
  background-color: #000;
}
.button.--black:hover {
  color: #000;
  background-color: #DC92F5;
}
.button.--black:hover::after {
  background-color: #000;
}
.button.--back {
  padding-left: calc(2.125rem) !important;
}
.button.--back::after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0.75rem;
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 0.75rem;
  height: 1.25rem;
  background-color: #fff;
  -webkit-mask: url("../svg/caret-left-white.svg") no-repeat 50% 50%;
          mask: url("../svg/caret-left-white.svg") no-repeat 50% 50%;
  -webkit-mask-size: 100% auto;
          mask-size: 100% auto;
  transition: background-color 0.25s;
}

a.arrow {
  position: relative;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
  display: inline-block;
  color: inherit;
}
a.arrow:hover {
  font-style: italic;
}
a.arrow:hover::before {
  content: "";
  position: absolute;
  bottom: -0.25rem;
  left: 0;
  right: 0.75rem;
  border-bottom: 0.125rem solid currentColor;
}
a.arrow.--right {
  padding-right: 1.875rem;
}
a.arrow.--right::after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.75rem;
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 0.75rem;
  height: 1.25rem;
  background: url("../svg/caret-right-white.svg") no-repeat 50% 50%;
  background-size: 100% auto;
}

.small-logo {
  position: absolute;
  top: 2rem;
  left: 2rem;
  z-index: 400;
}
.small-logo a {
  text-decoration: none;
}
.small-logo a img {
  width: 6.25rem;
  height: auto;
}

.prop {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 0.875rem;
  left: -2.125rem;
}
.prop::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  transform: translateX(-50%);
  height: 3.125rem;
  background: url("../svg/prop-1.svg") no-repeat 50% 0;
  background-size: 100% auto;
}
.prop::after {
  content: "";
  position: absolute;
  transform: translateX(-50%);
  top: 3.375rem;
  left: 50%;
  bottom: 0;
  width: 0.125rem;
  background-color: #144B5B;
}

.mobile-content {
  display: none;
}

.popup-dialog {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background-color: transparent;
  height: 100vh;
  margin: auto;
  border: none;
  z-index: 80000;
  max-height: 0;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: none;
  transition: max-height 0s 0.3s, background-color 0.25s 0s;
}
.popup-dialog > .frame {
  background-color: rgba(255, 255, 255, 0.5019607843);
  color: #144B5B;
  padding: 0.9375rem;
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  border-radius: 0.375rem;
  transform: translateY(2.5rem);
  transition: opacity 0.25s, transform 0.25s;
  opacity: 0;
}
.popup-dialog > .frame > .container {
  font-size: 1.375rem;
  line-height: 1.6875rem;
  border-radius: 0.375rem;
  background: rgba(231, 237, 239, 0.8);
  padding: 2.5rem;
  padding-right: 0.625rem;
  position: relative;
  width: 48.125rem;
}
.popup-dialog > .frame > .container button.--close {
  color: transparent;
  font-size: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: transparent;
  position: absolute;
  top: 0;
  right: 0;
  width: 2.125rem;
  height: 2.125rem;
  background: url("../svg/icon-close.svg") no-repeat 50% 50%;
  background-size: 0.875rem auto;
  border-radius: 50%;
  outline: none;
}
.popup-dialog > .frame > .container .scrollable {
  padding-right: 1.875rem;
  overflow: auto;
  max-height: 11.875rem;
}
.popup-dialog > .frame > .container .button {
  padding: 0.5rem 0.875rem;
  font-size: 1.375rem;
}
.popup-dialog > .frame > .container .groups {
  width: 21.875rem;
  margin: 0 auto;
  display: flex;
  gap: 1.25rem;
  flex-direction: column;
  align-items: flex-start;
}
.popup-dialog > .frame > .container .groups .group {
  display: block;
}
.popup-dialog > .frame > .container .groups .group > span, .popup-dialog > .frame > .container .groups .group > a {
  cursor: pointer;
  position: relative;
  display: inline-block;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
  color: #fff;
  display: flex;
  align-items: stretch;
  justify-content: flex-start;
  transition: color 0.25s, background-color 0.25s;
}
.popup-dialog > .frame > .container .groups .group > span span, .popup-dialog > .frame > .container .groups .group > a span {
  background-color: #000;
  display: block;
  padding: 0.5rem 0.875rem;
  font-size: 1.375rem;
  line-height: 1.375rem;
  transition: color 0.25s, background-color 0.25s;
}
.popup-dialog > .frame > .container .groups .group > span::before, .popup-dialog > .frame > .container .groups .group > a::before {
  content: "";
  margin-right: 0.5rem;
  width: 2.375rem;
  background-color: #000;
  transition: color 0.25s, background-color 0.25s;
}
.popup-dialog > .frame > .container .groups .group > span::after, .popup-dialog > .frame > .container .groups .group > a::after {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  content: "";
  margin-right: 0.5rem;
  width: 2.375rem;
  -webkit-mask: url("../svg/caret-right-white.svg") no-repeat 50% 50%;
          mask: url("../svg/caret-right-white.svg") no-repeat 50% 50%;
  -webkit-mask-size: 1rem auto;
          mask-size: 1rem auto;
  background-color: #fff;
  transition: color 0.25s, background-color 0.25s;
}
.popup-dialog > .frame > .container .groups .group > span:hover, .popup-dialog > .frame > .container .groups .group > a:hover {
  color: #000;
}
.popup-dialog > .frame > .container .groups .group > span:hover span, .popup-dialog > .frame > .container .groups .group > a:hover span {
  background-color: #DC92F5;
}
.popup-dialog > .frame > .container .groups .group > span:hover::before, .popup-dialog > .frame > .container .groups .group > a:hover::before {
  background-color: #DC92F5;
}
.popup-dialog > .frame > .container .groups .group > span:hover::after, .popup-dialog > .frame > .container .groups .group > a:hover::after {
  background-color: #000;
}
.popup-dialog > .frame > .container a {
  color: inherit;
}
.popup-dialog > .frame > .container a.--gray:hover {
  color: #fff;
}
.popup-dialog > .frame > .container h2 {
  text-align: center;
  text-transform: uppercase;
  font-size: 1.125rem;
  font-weight: 800;
  font-style: italic;
  margin-bottom: 1.875rem;
  margin-right: 1.875rem;
}
.popup-dialog > .frame > .container h3 {
  font-size: 1.375rem;
  font-weight: 800;
  margin-bottom: 0.625rem;
  margin-top: 1.25rem;
}
.popup-dialog > .frame > .container strong {
  font-weight: 800;
}
.popup-dialog > .frame > .container table {
  margin-bottom: 1.875rem;
}
.popup-dialog > .frame > .container table td, .popup-dialog > .frame > .container table th {
  padding-right: 1.875rem;
  text-align: left;
}
.popup-dialog > .frame > .container ul {
  margin-bottom: 1.25rem;
}
.popup-dialog > .frame > .container ul:last-child {
  margin-bottom: 0;
}
.popup-dialog > .frame > .container ul li {
  margin-left: 1em;
}
.popup-dialog > .frame > .container .scrollable h2 {
  margin-right: 0;
  margin-top: 2.5rem;
}
.popup-dialog > .frame > .container .scrollable h2:first-child {
  margin-top: 0;
}
.popup-dialog > .frame > .container p {
  margin-bottom: 1.4em;
}
.popup-dialog > .frame > .container p:last-child {
  margin-bottom: 0;
}
.popup-dialog > .frame > .container .buttons {
  display: flex;
  justify-content: center;
  gap: 1.25rem;
  border-top: 0.125rem solid #144B5B;
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  margin-right: 1.875rem;
}
.popup-dialog.text-content > .frame {
  background-color: rgba(255, 255, 255, 0.2);
}
.popup-dialog.text-content > .frame .scrollable {
  max-height: calc(100vh - 9.375rem);
}
.popup-dialog.text-content > .frame > .container {
  background-color: rgba(255, 255, 255, 0.8980392157);
  width: 48.125rem;
}
.popup-dialog.--open {
  background-color: rgba(20, 75, 91, 0.3);
  pointer-events: auto;
  max-height: 100vh;
  transition: max-height 0s 0s, background-color 0.25s 0s;
}
.popup-dialog.--open > .frame {
  opacity: 1;
  transform: translateY(0rem);
}
.popup-dialog.--animate-out > .frame {
  transform: translateY(-2.5rem);
}
.popup-dialog[data-dialog-identifier=my-groups] > .frame > .container {
  width: 35.625rem;
}

.popup-dialog.feedback {
  background-color: transparent !important;
  padding: 0.9375rem;
  z-index: 2000;
}
.popup-dialog.feedback > .frame {
  background-color: rgba(255, 255, 255, 0.5019607843);
}
.popup-dialog.feedback > .frame .scrollable {
  max-height: calc(100vh - 13.125rem);
  padding-left: 0.3125rem;
  padding-right: 2.1875rem;
}
.popup-dialog.feedback > .frame > .container {
  background: rgba(208, 219, 222, 0.5019607843);
  width: 48.125rem;
}
.popup-dialog.feedback > .frame > .container .text {
  text-align: center;
  padding-bottom: 2.5rem;
}
.popup-dialog.feedback > .frame > .container .text h2 {
  margin-bottom: 0.625rem;
}
.popup-dialog.feedback > .frame > .container .text-input {
  padding: 0.625rem;
  border-radius: 0.375rem;
  border: none;
  background-color: #fff;
  color: #144B5B;
  font-size: 1.375rem;
}
.popup-dialog.feedback > .frame > .container textarea {
  width: 100%;
  resize: none;
  height: 6.25rem;
}
.popup-dialog.feedback > .frame > .container .radios {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.9375rem;
  margin-bottom: 0.9375rem;
}
.popup-dialog.feedback > .frame > .container .radios:last-child {
  margin-bottom: 0;
}
.popup-dialog.feedback > .frame > .container .radios .radio {
  position: relative;
}
.popup-dialog.feedback > .frame > .container .radios .radio input {
  position: absolute;
  opacity: 0;
}
.popup-dialog.feedback > .frame > .container .radios .radio label {
  cursor: pointer;
  padding: 0.5rem 1rem;
  font-size: 1rem;
  font-weight: 800;
  text-transform: uppercase;
  background-color: rgba(20, 75, 91, 0.3019607843);
  color: #144B5B;
}
.popup-dialog.feedback > .frame > .container .radios .radio input[type=radio]:checked + label {
  background-color: #000;
  color: #fff;
}
.popup-dialog.feedback > .frame > .container .range {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.9375rem;
}
.popup-dialog.feedback > .frame > .container .range .radios {
  margin-bottom: 0;
}
.popup-dialog.feedback > .frame > .container .range .label {
  position: relative;
  overflow: hidden;
  width: 100%;
  font-size: 0.75rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  display: flex;
  gap: 0.9375rem;
  white-space: nowrap;
}
.popup-dialog.feedback > .frame > .container .range .label.left::after {
  content: "";
  width: 100%;
  background: url("../svg/arrow-prop-left.svg") no-repeat 0 50%;
  background-size: auto 1rem;
}
.popup-dialog.feedback > .frame > .container .range .label.right {
  justify-content: flex-end;
}
.popup-dialog.feedback > .frame > .container .range .label.right::before {
  content: "";
  width: 100%;
  background: url("../svg/arrow-prop-right.svg") no-repeat 100% 50%;
  background-size: auto 1rem;
}
.popup-dialog.feedback > .frame > .container fieldset {
  text-align: center;
  padding: 2.5rem 0;
  border: none;
  border-top: 0.125rem solid #144B5B;
}
.popup-dialog.feedback > .frame > .container fieldset:last-child {
  padding-bottom: 0.3125rem;
}
.popup-dialog.feedback > .frame > .container fieldset label {
  display: block;
  margin-bottom: 0.9375rem;
}
.popup-dialog.feedback > .frame > .container fieldset .radio label {
  margin-bottom: 0;
}
.popup-dialog.feedback > .frame .buttons {
  display: flex;
  justify-content: center;
  padding-top: 0.9375rem;
}
.popup-dialog.feedback > .frame .buttons .button {
  border: none;
  padding: 0.5rem 1rem;
  font-size: 1.375rem;
}
.popup-dialog.feedback > .frame .buttons .button[disabled] {
  pointer-events: none;
  color: #B8C9CE;
  background-color: #D0DBDE;
}

body.page-template-page-template-groups .background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 40.625rem;
  z-index: 1;
  background-color: #EDE9D9;
}
body.page-template-page-template-groups .background::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url("../svg/frontpage-mask.svg") no-repeat 50% 100%;
  background-size: 100% auto;
  z-index: 1;
}
body.page-template-page-template-groups .background::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2.5625rem;
  background: #fff;
  z-index: 2;
}
body.page-template-page-template-groups .character-leader {
  position: fixed;
  right: 0;
  bottom: 0;
  z-index: 2;
}
body.page-template-page-template-groups .character-leader > img {
  display: block;
  width: 19.375rem;
  height: auto;
}

body.page-template-page-template-register .background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 40.625rem;
  z-index: 1;
  background-color: #EDE9D9;
}
body.page-template-page-template-register .background::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url("../svg/frontpage-mask.svg") no-repeat 50% 100%;
  background-size: 100% auto;
  z-index: 1;
}
body.page-template-page-template-register .background::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2.5625rem;
  background: #fff;
  z-index: 2;
}
body.page-template-page-template-register .character-leader {
  position: fixed;
  right: 0;
  bottom: 0;
  z-index: 2;
}
body.page-template-page-template-register .character-leader > img {
  display: block;
  width: 19.375rem;
  height: auto;
}

.back-link {
  position: fixed;
  bottom: 1.5625rem;
  left: 3.4375rem;
  z-index: 400;
}

.groups-content {
  position: relative;
  z-index: 3;
  max-width: 53.4375rem;
  margin: 0 auto;
  margin-top: 9.375rem;
  padding-bottom: 6.25rem;
  text-align: center;
}
.groups-content h1, .groups-content h2 {
  font-style: italic;
  text-transform: uppercase;
  margin-top: 1.5em;
  margin-bottom: 0.5em;
}
.groups-content h1:first-child, .groups-content h2:first-child {
  margin-top: 0;
}
.groups-content h1 {
  font-weight: 900;
  font-size: 2.8125rem;
  line-height: 2.875rem;
}
.groups-content h2 {
  font-weight: 800;
  font-size: 1.125rem;
  line-height: 1.25rem;
  margin-top: 3.75rem;
  margin-bottom: 1.25rem;
}
.groups-content hr {
  margin-top: 3.75rem;
  display: block;
  border: none;
  background-color: #144B5B;
  height: 0.09375rem;
}
.groups-content button {
  --color: #fff;
  --bgcolor: #000;
  --size: 2.375rem;
  display: inline-block;
  font-size: 1.375rem;
  line-height: 1.375rem;
  padding: 0.5rem 0.875rem;
  border-radius: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  position: relative;
  height: var(--size);
  font-weight: 900;
  text-transform: uppercase;
  color: var(--color);
  background-color: var(--bgcolor);
}
.groups-content form.create-group fieldset {
  border: none;
}
.groups-content form.create-group fieldset.equal {
  display: flex;
  justify-content: center;
  align-items: stretch;
  height: 2.375rem;
  gap: 0.5rem;
}
.groups-content form.create-group input[type=text], .groups-content form.create-group input[type=number] {
  font-weight: 300;
  border: none;
  font-size: 0.875rem;
  padding: 0 0.5rem;
  color: #144B5B;
}
.groups-content form.create-group input[type=text] {
  width: 18.75rem;
}
.groups-content form.create-group input[type=number] {
  width: 11.25rem;
}
.groups-content form.create-group p {
  margin: 0.8em auto;
  font-size: 0.8em;
}
.groups-content .groups {
  max-width: 31.25rem;
  margin: 0 auto;
  margin-top: 1.875rem;
}
.groups-content .groups .group {
  margin-bottom: 0.625rem;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.3125rem;
}
.groups-content .groups .group > a {
  cursor: pointer;
  position: relative;
  display: inline-block;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
  color: #fff;
  display: flex;
  align-items: stretch;
  justify-content: flex-start;
  transition: color 0.25s, background-color 0.25s;
}
.groups-content .groups .group > a span {
  background-color: #000;
  display: block;
  padding: 0.5rem 0.875rem;
  font-size: 1.375rem;
  line-height: 1.375rem;
  transition: color 0.25s, background-color 0.25s;
}
.groups-content .groups .group > a::before {
  content: "";
  margin-right: 0.5rem;
  width: 2.375rem;
  background-color: #000;
  transition: color 0.25s, background-color 0.25s;
}
.groups-content .groups .group > a::after {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  content: "";
  margin-right: 0.5rem;
  width: 2.375rem;
  -webkit-mask: url("../svg/caret-right-white.svg") no-repeat 50% 50%;
          mask: url("../svg/caret-right-white.svg") no-repeat 50% 50%;
  -webkit-mask-size: 1rem auto;
          mask-size: 1rem auto;
  background-color: #fff;
  transition: color 0.25s, background-color 0.25s;
}
.groups-content .groups .group > a:hover {
  color: #000;
}
.groups-content .groups .group > a:hover span {
  background-color: #DC92F5;
}
.groups-content .groups .group > a:hover::before {
  background-color: #DC92F5;
}
.groups-content .groups .group > a:hover::after {
  background-color: #000;
}
.groups-content .groups .group button {
  background-color: transparent;
  color: inherit;
  font-style: italic;
  text-transform: uppercase;
  font-weight: 500;
  font-size: 0.75rem;
  line-height: 1em;
  padding: 0.625rem;
  color: #144B5B;
}
.groups-content .groups .group button:hover {
  text-decoration: underline;
}

.register-content {
  position: relative;
  z-index: 3;
  max-width: 53.4375rem;
  margin: 0 auto;
  margin-top: 6.25rem;
  padding-bottom: 6.25rem;
  text-align: center;
}
.register-content a {
  color: inherit;
}
.register-content h1, .register-content h2 {
  font-style: italic;
  text-transform: uppercase;
  margin-top: 1.5em;
  margin-bottom: 0.5em;
}
.register-content h1:first-child, .register-content h2:first-child {
  margin-top: 0;
}
.register-content p.info {
  margin-bottom: 1.875rem;
}
.register-content h1 {
  font-weight: 900;
  font-size: 2.8125rem;
  line-height: 2.875rem;
}
.register-content h2 {
  font-weight: 800;
  font-size: 1.125rem;
  line-height: 1.25rem;
  margin-top: 3.75rem;
  margin-bottom: 1.25rem;
}
.register-content button {
  --color: #fff;
  --bgcolor: #000;
  --size: 2.375rem;
  display: inline-block;
  font-size: 1.375rem;
  line-height: 1.375rem;
  padding: 0.5rem 0.875rem;
  border-radius: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  position: relative;
  height: var(--size);
  font-weight: 900;
  text-transform: uppercase;
  color: var(--color);
  background-color: var(--bgcolor);
}
.register-content form#register {
  max-width: 26.25rem;
  margin: 0 auto;
}
.register-content form#register fieldset {
  border: none;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.9375rem;
  margin-bottom: 1.25rem;
}
.register-content form#register fieldset.wide {
  justify-content: space-between;
}
.register-content form#register fieldset.wide label {
  text-align: right;
  width: 100%;
}
.register-content form#register input[type=text], .register-content form#register input[type=email] {
  flex-shrink: 0;
  height: 2.375rem;
  font-weight: 300;
  width: 18.75rem;
  border: none;
  font-size: 0.875rem;
  padding: 0 0.5rem;
  color: #144B5B;
}
.register-content form#register button[type=submit] {
  margin-top: 0.3125rem;
}
.register-content form#register input[type=checkbox] {
  margin-right: 0.625rem;
}

body.page-template-page-template-groups {
  height: auto;
}

.frontpage-content {
  font-size: 1.25rem;
  height: 100vh;
  position: relative;
  overflow: hidden;
}
.frontpage-content .background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
}
.frontpage-content .background > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: 50% 50%;
     object-position: 50% 50%;
}
.frontpage-content .background::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 1.25rem;
  background: url("../svg/frontpage-mask.svg") no-repeat 50% 100%;
  background-size: 100% auto;
  z-index: 1;
}
.frontpage-content .background::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2.5625rem;
  background: #fff;
  z-index: 2;
}
.frontpage-content h2 {
  text-transform: uppercase;
  font-size: 1.875rem;
  line-height: 2rem;
  font-weight: 900;
  font-style: italic;
  margin-bottom: 0.625rem;
}
.frontpage-content h3 {
  text-transform: uppercase;
  font-size: 1.125rem;
  font-weight: 800;
  font-style: italic;
  margin-bottom: 0.625rem;
}
.frontpage-content strong {
  font-weight: 700;
}
.frontpage-content p {
  margin-bottom: 0.375rem;
}
.frontpage-content p:last-child {
  margin-bottom: 0;
}
.frontpage-content .intro {
  position: absolute;
  z-index: 10;
  left: 0;
  bottom: 0;
  padding: 2.5rem;
  width: 26.875rem;
}
.frontpage-content .intro .content .prop {
  display: none;
}
.frontpage-content .cmi-logo {
  position: absolute;
  top: 0;
  left: 0.5rem;
  z-index: 400;
}
.frontpage-content .cmi-logo img {
  width: 15rem;
  height: auto;
}
.frontpage-content .logo {
  position: absolute;
  z-index: 10;
  left: 50%;
  bottom: 0;
  padding: 2.5rem 0;
  transform: translateX(-50%);
  width: 21.25rem;
  text-align: center;
}
.frontpage-content .logo .selected-team {
  display: none;
  margin-bottom: 1.875rem;
}
.frontpage-content .logo .selected-team.--visible {
  display: block;
}
.frontpage-content .logo .selected-team .button {
  display: inline-block;
  width: auto;
  margin: 0 auto;
  text-align: center;
  background-color: #000;
  color: #fff;
  padding: 1.25rem 2.5rem;
  cursor: pointer;
}
.frontpage-content .logo .selected-team .button:hover {
  background-color: #DC92F5;
  color: #000;
}
.frontpage-content .logo .selected-team .button:not(.--large) {
  margin-top: 1.25rem;
  padding: 0.625rem 1.25rem;
}
.frontpage-content .logo .selected-team .button span {
  display: block;
}
.frontpage-content .logo .selected-team .button .start {
  font-size: 2.8125rem;
  line-height: 2.4375rem;
  margin-bottom: 0.625rem;
  font-weight: 900;
}
.frontpage-content .logo .selected-team .button .team-name {
  font-size: 0.75rem;
  font-weight: 600;
}
.frontpage-content .logo h1 {
  width: 17rem;
  margin: 0 auto;
}
.frontpage-content .logo h2 {
  margin-top: 0.625rem;
  color: #000;
  margin-bottom: 0;
  font-weight: 900;
  font-size: 0.875rem;
  text-transform: uppercase;
  font-style: normal;
  letter-spacing: 0.07em;
}
.frontpage-content .logo .disclaimer {
  opacity: 1;
  transition: opacity 1s 2s;
  margin-top: 0.9375rem;
  position: relative;
  margin-left: -6.25rem;
  margin-right: -6.25rem;
  font-style: italic;
}
.frontpage-content .logo .disclaimer:empty {
  display: none;
}
.frontpage-content .guide {
  position: absolute;
  z-index: 10;
  right: 0;
  bottom: 0;
  padding: 2.5rem;
  padding-right: 2.1875rem;
  width: 28.4375rem;
}
.frontpage-content .guide .content {
  position: relative;
}
.frontpage-content .guide .content a {
  text-decoration: none;
  font-weight: 700;
  color: inherit;
}
.frontpage-content .guide .content a:hover {
  text-decoration: underline;
}

.frontpage-content {
  --animation-time: 2s;
  --animation-delay: 0.5s;
  --animation-time-2: 1.5s;
  --animation-delay-2: 1s;
}
.frontpage-content .background {
  background-color: #EDE9D9;
  transition: background-color var(--animation-time-2) var(--animation-delay-2);
}
.frontpage-content .background > img {
  opacity: 1;
  transition: opacity var(--animation-time-2) var(--animation-delay-2), transform var(--animation-time-2) var(--animation-delay-2);
  transform: translateY(0) translateZ(0);
}
.frontpage-content .intro {
  transform: translateY(0) translateZ(0);
  transition: transform var(--animation-time) var(--animation-delay);
}
.frontpage-content .logo {
  transform: translateX(-50%) translateY(0) translateZ(0);
  transition: transform var(--animation-time) var(--animation-delay);
}
.frontpage-content .guide {
  transform: translateY(0) translateZ(0);
  transition: transform var(--animation-time) var(--animation-delay);
}

body.--loading .frontpage-content .background {
  background-color: #fff;
}
body.--loading .frontpage-content .background > img {
  opacity: 0;
  transform: translateY(10%) translateZ(0);
}
body.--loading .frontpage-content .intro {
  transform: translateY(50vh) translateZ(0);
}
body.--loading .frontpage-content .logo {
  transform: translateX(-50%) translateY(calc(-50vh + 50%)) translateZ(0);
}
body.--loading .frontpage-content .logo .disclaimer {
  opacity: 0;
}
body.--loading .frontpage-content .guide {
  transform: translateY(50vh) translateZ(0);
}

body.single-oppiryhma {
  background-color: #EDE9D9;
}

.story-chooser-content {
  background-color: #EDE9D9;
  position: relative;
  height: 100vh;
  overflow: hidden;
}
.story-chooser-content .intro {
  position: absolute;
  top: 15rem;
  left: 5.625rem;
  z-index: 10;
}
.story-chooser-content .intro .content {
  position: relative;
  width: 25rem;
  font-size: 1.375rem;
  line-height: 122%;
}
.story-chooser-content .intro .content h2 {
  text-transform: uppercase;
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
  font-style: italic;
  margin-bottom: 1.125rem;
}
.story-chooser-content .stories {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 5rem;
  display: flex;
  align-items: stretch;
  justify-content: flex-end;
  gap: 3.375rem;
  padding-right: 3.375rem;
}
.story-chooser-content .stories .story {
  --color: #fff;
  position: relative;
  width: 16.875rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: stretch;
  padding-bottom: 6.5625rem;
}
.story-chooser-content .stories .story .picture {
  --offset: 0;
}
.story-chooser-content .stories .story .picture > img {
  top: 0;
  position: absolute;
  display: block;
  height: 113%;
  width: auto;
  transition: transform 0.5s;
  transform: translateY(var(--offset));
}
.story-chooser-content .stories .story:not(.locked):has(a:hover) .picture {
  --offset: -0.625rem;
}
.story-chooser-content .stories .story:nth-child(1) .picture > img {
  left: -5rem;
}
.story-chooser-content .stories .story:nth-child(2) .picture > img {
  left: 50%;
  transform: translateX(-50%) translateX(1.875rem) translateY(var(--offset));
}
.story-chooser-content .stories .story:nth-child(3) .picture > img {
  right: -3.75rem;
}
.story-chooser-content .stories .story a {
  position: relative;
  display: block;
  color: #fff;
  z-index: 10;
  min-height: 8.4375rem;
  text-decoration: none;
}
.story-chooser-content .stories .story a .subheading {
  color: var(--color);
  margin-bottom: 0.5rem;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
}
.story-chooser-content .stories .story a .subheading .icon {
  flex-shrink: 0;
  width: 2.375rem;
  height: 2.375rem;
  background-color: #000;
  position: relative;
  margin-right: 0.5rem;
}
.story-chooser-content .stories .story a .subheading .icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.875rem;
  height: 1.875rem;
  transform: translate(-50%, -50%);
  background-color: var(--color);
  -webkit-mask: url("../svg/caret-right.svg") no-repeat 50% 50%;
          mask: url("../svg/caret-right.svg") no-repeat 50% 50%;
  -webkit-mask-size: auto 1.25rem;
          mask-size: auto 1.25rem;
}
.story-chooser-content .stories .story a .subheading .level {
  font-size: 1.375rem;
  line-height: 1.375rem;
  font-weight: 900;
  text-transform: uppercase;
  background-color: #000;
  display: flex;
  align-items: center;
  padding: 0 0.875rem;
}
.story-chooser-content .stories .story a .subheading .level .indicators {
  margin-left: 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.story-chooser-content .stories .story a .subheading .level .indicators .indicator {
  flex-shrink: 0;
  width: 1.25rem;
  height: 1.25rem;
  background-color: var(--color);
  -webkit-mask: url("../svg/icon-level-x-o.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-level-x-o.svg") no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.story-chooser-content .stories .story a .subheading .level .indicators .indicator.active {
  -webkit-mask-image: url("../svg/icon-level-x.svg");
          mask-image: url("../svg/icon-level-x.svg");
}
.story-chooser-content .stories .story a .heading {
  background-color: #000;
  padding: 0.375rem 0.875rem;
}
.story-chooser-content .stories .story a .heading h2 {
  text-transform: uppercase;
  color: var(--color);
  font-size: 2.0625rem;
  font-weight: 900;
  line-height: 2.4375rem;
}
.story-chooser-content .stories .story a .heading .info {
  display: none;
  margin-top: 0.625rem;
}
.story-chooser-content .stories .story a .heading .info .time {
  border-bottom: 0.125rem solid #fff;
  padding-bottom: 0.9375rem;
  font-weight: 700;
  font-size: 0.875rem;
}
.story-chooser-content .stories .story a .heading .info .completion {
  display: flex;
  padding-top: 0.75rem;
  padding-bottom: 0.5625rem;
}
.story-chooser-content .stories .story a .heading .info .completion > div {
  width: 50%;
  flex-shrink: 0;
  text-align: center;
}
.story-chooser-content .stories .story a .heading .info .completion > div .number {
  font-size: 1.375rem;
  font-weight: 800;
  line-height: 1.5rem;
}
.story-chooser-content .stories .story a .heading .info .completion > div .text {
  font-size: 0.875rem;
  font-weight: 300;
}
.story-chooser-content .stories .story a:hover .heading .info {
  display: block;
}
.story-chooser-content .stories .story.locked a {
  cursor: not-allowed;
}
.story-chooser-content .stories .story.locked a .subheading .icon {
  background-color: var(--color);
}
.story-chooser-content .stories .story.locked a .subheading .icon::before {
  background-color: #000;
  -webkit-mask-image: url("../svg/icon-lock.svg");
          mask-image: url("../svg/icon-lock.svg");
  -webkit-mask-size: auto 1.5rem;
          mask-size: auto 1.5rem;
}
.story-chooser-content .intro .content, .story-chooser-content .footer .buttons, .story-chooser-content .story > a {
  opacity: 0;
  transform: translateY(2.5rem);
  transition: opacity 0.25s, transform 0.25s;
}
.story-chooser-content .footer .buttons {
  transition-delay: 0.3s;
}
.story-chooser-content .story:nth-child(1) .picture {
  transition-delay: 0.1s;
}
.story-chooser-content .story:nth-child(1) > a {
  transition-delay: 0.2s;
}
.story-chooser-content .story:nth-child(2) .picture {
  transition-delay: 0.2s;
}
.story-chooser-content .story:nth-child(2) > a {
  transition-delay: 0.3s;
}
.story-chooser-content .story:nth-child(3) .picture {
  transition-delay: 0.3s;
}
.story-chooser-content .story:nth-child(3) > a {
  transition-delay: 0.4s;
}
.story-chooser-content.--animate-in .intro .content, .story-chooser-content.--animate-in .footer .buttons, .story-chooser-content.--animate-in .story > a {
  opacity: 1;
  transform: translateY(0);
}

.footer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2100;
}
.footer.--bar {
  background-color: #D0DBDE;
  padding: 1.5625rem 3.5rem;
  display: flex;
  justify-content: flex-start;
}
.footer .announcer {
  position: absolute;
  bottom: 1.5625rem;
  width: 60.9375rem;
  left: 50%;
  transform: translateX(-50%);
  background-color: rgba(255, 255, 255, 0.6980392157);
  box-shadow: 0 0 1rem rgba(20, 75, 91, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  padding: 1.5rem;
  min-height: 7.75rem;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  border-radius: 0.375rem;
  opacity: 0;
  pointer-events: none;
}
.footer .announcer .text {
  font-weight: 200;
  font-size: 1.9375rem;
  line-height: 2.375rem;
}

body:not(.--custom-announcement)[data-announcer-visible=true] .footer .announcer, body:not(.--custom-announcement)[data-announcer-visible=true] #app .footer {
  opacity: 1;
}

.swipe-mask {
  display: none;
}

body.--swipe-loading .swipe-mask {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 90000;
  pointer-events: none;
  background-color: #144B5B;
}

.swipe {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 90000;
  pointer-events: none;
}
.swipe canvas {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100vw;
  height: 100vw;
  transform: translateY(-50%);
}
.swipe .--togglable {
  opacity: 0;
}
.swipe .--togglable.--visible {
  opacity: 1;
}

body.page-template-default:not(.home) {
  overflow: initial;
  padding: 11.25rem;
}
body.page-template-default:not(.home) .cmi-logo {
  position: absolute;
  top: 0;
  left: 0.5rem;
  z-index: 400;
}
body.page-template-default:not(.home) .cmi-logo img {
  width: 15rem;
  height: auto;
}
body.page-template-default:not(.home) .small-logo {
  position: fixed;
  top: auto;
  bottom: 2rem;
}
body.page-template-default:not(.home) article.content {
  margin: 0 auto;
  padding-bottom: 6.25rem;
}
body.page-template-default:not(.home) article.content h1 {
  text-transform: uppercase;
  font-size: 1.875rem;
  line-height: 2rem;
  font-weight: 900;
  font-style: italic;
  margin-bottom: 0.625rem;
}
body.page-template-default:not(.home) article.content h2 {
  text-transform: uppercase;
  font-size: 1.125rem;
  font-weight: 800;
  font-style: italic;
  margin-bottom: 0.625rem;
}
body.page-template-default:not(.home) article.content h3 {
  margin-bottom: 0.625rem;
}
body.page-template-default:not(.home) article.content h4 {
  margin-bottom: 0.625rem;
}
body.page-template-default:not(.home) article.content strong {
  font-weight: 700;
}
body.page-template-default:not(.home) article.content p {
  margin-bottom: 1.875rem;
}
body.page-template-default:not(.home) article.content p:last-child {
  margin-bottom: 0;
}
body.page-template-default:not(.home) article.content ul, body.page-template-default:not(.home) article.content ol {
  margin-left: 1em;
  margin-bottom: 1.875rem;
}
body.page-template-default:not(.home) article.content ul:last-child, body.page-template-default:not(.home) article.content ol:last-child {
  margin-bottom: 0;
}

/*! Handmade with love by https://esmes.fi */
/* RESET */
*,
::before,
::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
}

html {
  margin: 0;
  padding: 0;
  height: 100%;
}

body {
  margin: 0;
  padding: 0;
  height: 100%;
  -webkit-text-size-adjust: 100%;
}

/*input,
textarea {
  border: 0;
  border-radius: 0; // Fix awful iOS default
  font: inherit;
  -webkit-appearance: none;
}*/
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
}

/* HTML5 for old-ie */
article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section {
  display: block;
}

template {
  display: none;
}

address,
button,
input,
optgroup,
select,
textarea {
  font: inherit;
}

a img {
  border-style: none;
}

/* Responsive SVG */
img[src*=".svg"] {
  width: 100%;
  height: auto;
}

@keyframes loader-opacity {
  0% {
    opacity: 1;
  }
  8% {
    opacity: 0;
  }
  25% {
    opacity: 0;
  }
  33% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}
@keyframes loader-rotation {
  0% {
    transform: rotateZ(0deg);
  }
  33% {
    transform: rotateZ(90deg);
  }
  100% {
    transform: rotateZ(90deg);
  }
}
#app {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100vh;
  min-height: 44.5rem;
  background-color: var(--color-background);
  transition: background-color 1s;
  --title-delay: 1.5s;
  --title-color: #144B5B;
  --pause-icon: url("../svg/icon-pause.svg");
}
#app * {
  outline: 0;
}
#app.--paused {
  --pause-icon: url("../svg/icon-play.svg");
}
#app.--paused .phase.--active {
  filter: blur(0.625rem);
}
#app.--paused .phase.--active {
  filter: blur(0.625rem);
}
#app.--paused section[data-section-type=create_questions] .phase.--active {
  filter: none;
}
#app.--paused section[data-section-type=create_questions] .phase.--active .words-container {
  filter: blur(0.625rem);
}
#app.--paused section[data-section-type=negotiations] .phase.--active {
  filter: none;
}
#app.--paused section[data-section-type=negotiations] .phase.--active .words-container {
  filter: blur(0.625rem);
}
#app button:not(.control), #app a.button {
  --color: #144B5B;
  --bgcolor: #144B5B4D;
  --size: 2.375rem;
  display: inline-block;
  font-size: 1.375rem;
  line-height: 1.375rem;
  padding: 0.5rem 0.875rem;
  border-radius: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  position: relative;
  height: var(--size);
  font-weight: 900;
  text-transform: uppercase;
  color: var(--color);
  background-color: var(--bgcolor);
  transition: color 0.25s, background-color 0.25s;
}
#app button:not(.control):hover, #app a.button:hover {
  --color: #fff;
  --bgcolor: #144B5B;
}
#app button:not(.control).icon, #app a.button.icon {
  background-color: var(--bgcolor);
  margin-left: calc(var(--size) + 0.5rem);
}
#app button:not(.control).icon::before, #app a.button.icon::before {
  display: block;
  position: absolute;
  top: 0;
  right: 100%;
  content: "";
  margin-right: 0.5rem;
  width: var(--size);
  height: var(--size);
  background: var(--bgcolor);
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: auto 1.125rem;
  transition: color 0.25s, background-color 0.25s;
}
#app button:not(.control).icon::after, #app a.button.icon::after {
  display: block;
  position: absolute;
  top: 0;
  right: 100%;
  content: "";
  margin-right: 0.5rem;
  width: var(--size);
  height: var(--size);
  background: var(--color);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 50% 50%;
          mask-position: 50% 50%;
  -webkit-mask-size: auto 1.125rem;
          mask-size: auto 1.125rem;
  z-index: 1;
  transition: color 0.25s, background-color 0.25s;
}
#app button:not(.control).--large, #app a.button.--large {
  --size: 3.4375rem;
  padding: 0.5rem 1rem;
  font-size: 2.0625rem;
  line-height: 2.4375rem;
}
#app button:not(.control).--large.icon, #app a.button.--large.icon {
  margin-left: calc(var(--size) + 0.5rem);
}
#app button:not(.control).--large.icon::after, #app a.button.--large.icon::after {
  -webkit-mask-size: auto 2rem;
          mask-size: auto 2rem;
}
#app button:not(.control).--round, #app a.button.--round {
  display: inline-flex;
  align-items: center;
  --size: 3.1875rem;
  --bgcolor: #000;
  font-weight: 800;
  font-size: 1.875rem;
  line-height: 2.1875rem;
  padding: 0;
  padding-left: calc(var(--size) + 0.5rem);
  color: var(--team-color);
  text-transform: none;
}
#app button:not(.control).--round.icon::before, #app a.button.--round.icon::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  margin-right: 0.5rem;
  width: var(--size);
  height: var(--size);
  background: var(--bgcolor);
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: auto 1.125rem;
  border-radius: calc(0.5 * var(--size));
}
#app button:not(.control).--round.icon::after, #app a.button.--round.icon::after {
  content: "";
  left: 0;
  top: 0;
  right: auto;
  bottom: auto;
  width: var(--size);
  height: var(--size);
  position: absolute;
  background-color: var(--team-color);
  -webkit-mask: url("../svg/icon-plus.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-plus.svg") no-repeat 50% 50%;
  -webkit-mask-size: 1.375rem auto;
          mask-size: 1.375rem auto;
  z-index: 1;
}
#app button:not(.control).--round span, #app a.button.--round span {
  height: var(--size);
  padding: 0 1.5rem;
  background-color: var(--bgcolor);
  display: inline-flex;
  align-items: center;
  border-radius: calc(0.5 * var(--size));
  transition: color 0.25s, background-color 0.25s;
}
#app button:not(.control).--round.--large, #app a.button.--round.--large {
  text-transform: uppercase;
}
#app button:not(.control).--restart::after, #app a.button.--restart::after {
  -webkit-mask-image: url("../svg/icon-replay.svg");
          mask-image: url("../svg/icon-replay.svg");
}
#app button:not(.control).--forwards::after, #app a.button.--forwards::after {
  -webkit-mask-image: url("../svg/caret-right.svg");
          mask-image: url("../svg/caret-right.svg");
}
#app button:not(.control).--backwards::after, #app a.button.--backwards::after {
  -webkit-mask-image: url("../svg/caret-left.svg");
          mask-image: url("../svg/caret-left.svg");
}
#app button:not(.control):not([disabled]).--black, #app a.button:not([disabled]).--black {
  --color: #fff;
  --bgcolor: #000;
}
#app button:not(.control):not([disabled]).--black.--forwards::after, #app a.button:not([disabled]).--black.--forwards::after {
  -webkit-mask-image: url("../svg/caret-right-white.svg");
          mask-image: url("../svg/caret-right-white.svg");
}
#app button:not(.control):not([disabled]).--black.--backwards::after, #app a.button:not([disabled]).--black.--backwards::after {
  -webkit-mask-image: url("../svg/caret-left-white.svg");
          mask-image: url("../svg/caret-left-white.svg");
}
#app button:not(.control)[disabled], #app a.button[disabled] {
  pointer-events: none;
  cursor: default;
  opacity: 0.4;
}
#app button:not(.control)[disabled].--hide, #app a.button[disabled].--hide {
  display: none;
}
#app button:not(.control).--black:hover, #app a.button.--black:hover {
  --color: #000 !important;
  --bgcolor: var(--color-highlight, #DC92F5) !important;
}
#app button.--large-round {
  --size: p(55);
  color: #fff;
  background-color: #000;
  font-size: 2.0625rem;
  line-height: 2.4375rem;
  padding: 0.5rem 1.5rem;
  border-radius: 1.75rem;
  transition: color 0.25s, background-color 0.25s;
}
#app button.--large-round:hover {
  color: #000;
  background-color: var(--color-highlight, #DC92F5);
}
#app > .background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
}
#app > .background .graphic-container {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 180rem;
  height: 111.25rem;
  transform: translate(-50%, -50%);
  transition: transform 10s;
}
#app > .background .graphic-container .graphic {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-graphic);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 50% 50%;
          mask-position: 50% 50%;
  -webkit-mask-image: var(--mask-image);
          mask-image: var(--mask-image);
  -webkit-mask-size: 100% auto;
          mask-size: 100% auto;
  transition: background-color 1s 0s, opacity 0s 0.5s;
}
#app > .background .graphic-container .graphic.--frontpage {
  opacity: 0.01;
}
#app > .background .graphic-container .graphic.--primary {
  transform: translateY(0%);
}
#app > .background .graphic-container .graphic.--secondary {
  transform: translateY(100%);
}
#app > .background.--intro .graphic-container.--has-frontpage-override .graphic.--primary {
  opacity: 0;
}
#app > .background.--intro .graphic-container.--has-frontpage-override .graphic.--primary.--frontpage {
  opacity: 1;
}
#app > .background .sub-escalation {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-graphic);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 50% 50%;
          mask-position: 50% 50%;
  -webkit-mask-size: 180rem auto;
          mask-size: 180rem auto;
  transition: background-color 1s, opacity 1s 0.3s;
}
#app > .background .sub-escalation[data-sub-escalation-level="1"] {
  -webkit-mask-image: url("../svg/eskalaatio-1.svg");
          mask-image: url("../svg/eskalaatio-1.svg");
}
#app > .background .sub-escalation[data-sub-escalation-level="2"] {
  -webkit-mask-image: url("../svg/eskalaatio-2.svg");
          mask-image: url("../svg/eskalaatio-2.svg");
}
#app > .background .sub-escalation[data-sub-escalation-level="3"] {
  -webkit-mask-image: url("../svg/eskalaatio-3.svg");
          mask-image: url("../svg/eskalaatio-3.svg");
}
#app > .background .sub-escalation[data-sub-escalation-level="4"] {
  -webkit-mask-image: url("../svg/eskalaatio-4.svg");
          mask-image: url("../svg/eskalaatio-4.svg");
}
#app > .background .sub-escalation[data-sub-escalation-level="5"] {
  -webkit-mask-image: url("../svg/eskalaatio-5.svg");
          mask-image: url("../svg/eskalaatio-5.svg");
}
#app[data-sub-escalation-level=""] > .background.--animate-move .graphic-container .graphic, #app[data-sub-escalation-level="0"] > .background.--animate-move .graphic-container .graphic {
  transition: background-color 1s, transform 1s, opacity 0s 0.5s !important;
}
#app[data-sub-escalation-level=""] > .background.--animate-next .graphic-container .graphic.--primary, #app[data-sub-escalation-level="0"] > .background.--animate-next .graphic-container .graphic.--primary {
  transform: translateY(-100%);
}
#app[data-sub-escalation-level=""] > .background.--animate-next .graphic-container .graphic.--secondary, #app[data-sub-escalation-level="0"] > .background.--animate-next .graphic-container .graphic.--secondary {
  transform: translateY(0%);
}
#app > .background.--intro .graphic-container {
  transform: translate(-50%, -50%) translateY(3.125rem) translateZ(0);
}
#app > .background.--intro .graphic-container .graphic {
  transition: background-color 1s, transform 1s, opacity 0s 0.5s;
  transition-delay: 0.2s;
}
#app > .background.--intro .graphic-container .graphic.--primary {
  transform: translateY(100%);
}
#app > .background.--intro-in .graphic-container {
  transform: translate(-50%, -50%) translateZ(0);
}
#app > .background.--intro-in .graphic-container .graphic.--primary {
  transform: translateY(0%);
}
#app[data-sub-escalation-level="1"] > .background .sub-escalation[data-sub-escalation-level="1"] {
  opacity: 1;
}
#app[data-sub-escalation-level="2"] > .background .sub-escalation[data-sub-escalation-level="2"] {
  opacity: 1;
}
#app[data-sub-escalation-level="3"] > .background .sub-escalation[data-sub-escalation-level="3"] {
  opacity: 1;
}
#app[data-sub-escalation-level="4"] > .background .sub-escalation[data-sub-escalation-level="4"] {
  opacity: 1;
}
#app[data-sub-escalation-level="5"] > .background .sub-escalation[data-sub-escalation-level="5"] {
  opacity: 1;
}
#app[data-escalation-level="9"] > .background .sub-escalation {
  opacity: 0 !important;
}
#app[data-escalation-level="1"] {
  background-color: #EDE9D9;
  --color-graphic: #ffffff !important;
}
#app[data-escalation-level="2"] {
  background-color: #EDE9D9;
  --color-graphic: #D0DBDE !important;
}
#app[data-escalation-level="3"] {
  background-color: #EDE9D9;
  --color-graphic: #A1B7BD !important;
}
#app[data-escalation-level="4"] {
  background-color: #D0DBDE;
  --color-graphic: #B8C9CE !important;
}
#app[data-escalation-level="5"] {
  background-color: #B8C9CE;
  --color-graphic: #89A5AD !important;
}
#app[data-escalation-level="6"] {
  background-color: #89A5AD;
  --color-graphic: #5A818C !important;
}
#app[data-escalation-level="7"] {
  background-color: #436F7C;
  --color-graphic: #144B5B !important;
}
#app[data-escalation-level="8"] {
  background-color: #144B5B;
  --color-graphic: #2B5D6B !important;
}
#app[data-escalation-level="8"][data-sub-escalation-level="5"] {
  background-color: #2B5D6B;
  --color-graphic: #144B5B !important;
}
#app[data-escalation-level="9"] {
  background-color: #F5F3EB;
  --color-graphic: #EDE9D9 !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="0"][data-escalation-level="1"] {
  --color-graphic: #f6f0d7 !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="0"][data-escalation-level="2"] {
  --color-graphic: #e8db9e !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="0"][data-escalation-level="3"] {
  --color-graphic: #e0cd7c !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="0"][data-escalation-level="4"] {
  background-color: #ede2b1;
  --color-graphic: #e0cd7c !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="0"][data-escalation-level="5"] {
  background-color: #e4d48d;
  --color-graphic: #d3b84f !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="0"][data-escalation-level="6"] {
  background-color: #dbc66c;
  --color-graphic: #c1992c !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="1"][data-escalation-level="1"] {
  --color-graphic: #effaf3 !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="1"][data-escalation-level="2"] {
  --color-graphic: #c0eace !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="1"][data-escalation-level="3"] {
  --color-graphic: #a3dfb6 !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="1"][data-escalation-level="4"] {
  background-color: #dff4e6;
  --color-graphic: #b1e4c2 !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="1"][data-escalation-level="5"] {
  background-color: #cfefd9;
  --color-graphic: #96dbab !important;
}
#app[data-story=koruton-kaveruus][data-active-team-index="1"][data-escalation-level="6"] {
  background-color: #a3dfb6;
  --color-graphic: #7ed094 !important;
}
#app[data-story=koruton-kaveruus][data-escalation-level="8"] {
  background-color: #2B5D6B;
  --color-graphic: #144B5B !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="0"][data-escalation-level="1"] {
  --color-graphic: #f6f0d7 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="0"][data-escalation-level="2"] {
  --color-graphic: #e8db9e !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="0"][data-escalation-level="3"] {
  --color-graphic: #e0cd7c !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="0"][data-escalation-level="4"] {
  background-color: #ede2b1;
  --color-graphic: #e0cd7c !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="0"][data-escalation-level="5"] {
  background-color: #e0cd7c;
  --color-graphic: #d3b84f !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="0"][data-escalation-level="6"] {
  background-color: #d3b84f;
  --color-graphic: #c1992c !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="2"][data-escalation-level="1"] {
  --color-graphic: #edf5f8 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="2"][data-escalation-level="2"] {
  --color-graphic: #cae1e9 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="2"][data-escalation-level="3"] {
  --color-graphic: #a8cedb !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="2"][data-escalation-level="4"] {
  background-color: #dbebf0;
  --color-graphic: #b9d7e2 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="2"][data-escalation-level="5"] {
  background-color: #b9d7e2;
  --color-graphic: #89bbcd !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="2"][data-escalation-level="6"] {
  background-color: #99c5d4;
  --color-graphic: #7bb2c6 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="1"][data-escalation-level="1"] {
  --color-graphic: #f8effd !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="1"][data-escalation-level="2"] {
  --color-graphic: #ead1f8 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="1"][data-escalation-level="3"] {
  --color-graphic: #ddb4f4 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="1"][data-escalation-level="4"] {
  background-color: #f1e1fb;
  --color-graphic: #e3c3f6 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="1"][data-escalation-level="5"] {
  background-color: #e3c3f6;
  --color-graphic: #d098f1 !important;
}
#app[data-story=suhdeselkkauksia][data-active-team-index="1"][data-escalation-level="6"] {
  background-color: #d7a5f2;
  --color-graphic: #ca8aee !important;
}
#app[data-story=suhdeselkkauksia][data-active-section=connections][data-active-team-index="0"][data-escalation-level="6"] {
  background-color: #d3b84f;
  --color-graphic: #c1992c !important;
}
#app[data-story=suhdeselkkauksia][data-active-section=connections][data-active-team-index="1"][data-escalation-level="6"] {
  background-color: #d7a5f2;
  --color-graphic: #ca8aee !important;
}
#app[data-story=suhdeselkkauksia][data-active-section=connections][data-active-team-index="2"][data-escalation-level="6"] {
  background-color: #99c5d4;
  --color-graphic: #7bb2c6 !important;
}
#app[data-active-section=connections] > .header .content .info strong {
  --color-highlight: #2B5D6B !important;
}
#app[data-story=kasvukipuja][data-active-team-index="0"][data-escalation-level="1"] {
  --color-graphic: #f8effd !important;
}
#app[data-story=kasvukipuja][data-active-team-index="0"][data-escalation-level="2"] {
  --color-graphic: #ead1f8 !important;
}
#app[data-story=kasvukipuja][data-active-team-index="0"][data-escalation-level="3"] {
  --color-graphic: #ddb4f4 !important;
}
#app[data-story=kasvukipuja][data-active-team-index="0"][data-escalation-level="4"] {
  background-color: #f1e1fb;
  --color-graphic: #e3c3f6 !important;
}
#app[data-story=kasvukipuja][data-active-team-index="0"][data-escalation-level="5"] {
  background-color: #e3c3f6;
  --color-graphic: #d098f1 !important;
}
#app[data-story=kasvukipuja][data-active-team-index="0"][data-escalation-level="6"] {
  background-color: #d7a5f2;
  --color-graphic: #c47dec !important;
}
#app[data-story=kasvukipuja][data-active-team-index="1"][data-escalation-level="1"] {
  --color-graphic: #f4fce1 !important;
}
#app[data-story=kasvukipuja][data-active-team-index="1"][data-escalation-level="2"] {
  --color-graphic: #ccef96 !important;
}
#app[data-story=kasvukipuja][data-active-team-index="1"][data-escalation-level="3"] {
  --color-graphic: #bee78c !important;
}
#app[data-story=kasvukipuja][data-active-team-index="1"][data-escalation-level="4"] {
  background-color: #e9fac4;
  --color-graphic: #ccef96 !important;
}
#app[data-story=kasvukipuja][data-active-team-index="1"][data-escalation-level="5"] {
  background-color: #dcf7a0;
  --color-graphic: #aedf82 !important;
}
#app[data-story=kasvukipuja][data-active-team-index="1"][data-escalation-level="6"] {
  background-color: #bee78c;
  --color-graphic: #92cd6f !important;
}
#app > .settings {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 950;
  background-color: #000;
  color: #fff;
  transform: translateY(-105%);
  transition: transform 0.6s;
  padding: 3.75rem 6.25rem;
  padding-bottom: 2.5rem;
}
#app > .settings h3 {
  font-size: 1.125rem;
  font-style: italic;
  font-weight: 800;
  line-height: 1.25rem;
  text-transform: uppercase;
}
#app > .settings .panes {
  width: 100%;
  position: relative;
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  padding-bottom: 2.5rem;
}
#app > .settings .panes .pane {
  width: 33.33%;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
#app > .settings .panes .pane.center {
  text-align: center;
}
#app > .settings .panes .pane.right {
  align-items: flex-end;
  text-align: right;
}
#app > .settings .save-disclaimer {
  text-align: center;
  margin: 0 auto;
  max-width: 50rem;
  padding-bottom: 1.875rem;
  font-size: 1.375rem;
  font-weight: 300;
}
#app > .settings .save-disclaimer strong {
  font-weight: 700;
}
#app > .settings nav {
  border-top: 0.125rem solid #fff;
  padding: 0;
  padding-top: 1.25rem;
}
#app > .settings nav ul li a {
  color: #fff;
}
#app.--settings-open > .settings {
  transform: translateY(0);
}
#app .controls button[data-action=open-settings] {
  display: block;
}
#app.--settings-open .controls button[data-action=open-settings]::before {
  opacity: 0;
}
#app.--settings-open .controls button[data-action=open-settings]::after {
  opacity: 1;
}
#app > .progress {
  position: absolute;
  top: 0;
  left: 0;
  text-align: center;
  width: 6.875rem;
  padding: 2.1875rem 0;
  box-shadow: 0 0 0.75rem rgba(20, 75, 91, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  background-color: rgba(255, 255, 255, 0.4);
  border-top-right-radius: 0.375rem;
  border-bottom-right-radius: 0.375rem;
  opacity: 1;
  transition: opacity 0.3s;
  z-index: 90;
  transform: translateX(-105%);
  transition: transform 0.5s;
}
#app > .progress .level {
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  flex-direction: column;
}
#app > .progress .level .indicators {
  margin-top: 0.3125rem;
  display: flex;
  align-items: center;
  gap: 0.1875rem;
}
#app > .progress .level .indicators .indicator {
  flex-shrink: 0;
  width: 0.625rem;
  height: 0.625rem;
  background-color: currentColor;
  -webkit-mask: url("../svg/icon-level-x-o.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-level-x-o.svg") no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
}
#app > .progress .level .indicators .indicator.active {
  -webkit-mask-image: url("../svg/icon-level-x.svg");
          mask-image: url("../svg/icon-level-x.svg");
}
#app > .progress .title {
  margin-top: 1.125rem;
  margin-bottom: 1.5625rem;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
}
#app > .progress .rounds {
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: column;
}
#app > .progress .rounds .round {
  position: relative;
  width: 0.75rem;
  height: 0.75rem;
  border: 0.125rem solid currentColor;
  border-radius: 50% 50%;
  margin-bottom: 0.75rem;
}
#app > .progress .rounds .round[data-section-type="2_extra"], #app > .progress .rounds .round[data-section-type="3_extra"] {
  display: none;
}
#app > .progress .rounds .round::after {
  content: "";
  display: block;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-0.0625rem);
  width: 0.125rem;
  height: 0.875rem;
  background-color: currentColor;
}
#app > .progress .rounds .round.--active {
  background-color: currentColor;
}
#app > .progress .rounds .round.--current {
  border-color: transparent;
  height: 1.375rem;
  width: 1.375rem;
  background: url("../svg/icon-cross.svg") no-repeat 50% 50%;
  background-size: 1rem auto;
}
#app > .progress .rounds .round[data-section-type=end] {
  width: 1.5rem;
  height: 1.5rem;
  margin-bottom: 0;
}
#app > .progress .rounds .round[data-section-type=end].--current {
  background-color: currentColor;
}
#app > .progress .rounds .round[data-section-type=end]::after {
  display: none;
}
#app > .header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
}
#app > .header .content {
  position: absolute;
  top: 0;
  width: 60.9375rem;
  left: 50%;
  transform: translate(-50%, -105%);
  transition: transform 0.5s;
  background-color: rgba(255, 255, 255, 0.4);
  box-shadow: 0 0 0.75rem rgba(20, 75, 91, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  padding: 0.625rem;
  padding-top: 0;
  display: flex;
  align-items: stretch;
  border-bottom-left-radius: 0.375rem;
  border-bottom-right-radius: 0.375rem;
}
#app > .header .content .teams {
  position: relative;
  margin-right: -1.5625rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.5625rem;
  padding-left: 1.5625rem;
}
#app > .header .content .teams .team {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 2.375rem;
  z-index: 1;
  width: 9.375rem;
  transition: color 0.4s;
}
#app > .header .content .teams .team .name {
  padding: 0 0.5625rem;
  text-transform: uppercase;
  font-size: 1.125rem;
  font-style: italic;
}
#app > .header .content .teams .team .score {
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  width: 3.4375rem;
  text-align: center;
}
#app > .header .content .teams .team::after {
  content: "";
  position: absolute;
  background-color: var(--color);
  width: 3.4375rem;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  border-radius: 1.1875rem;
  transition: width 0.2s, background-color 0.4s;
}
#app > .header .content .teams .team.--active .name {
  font-weight: 800;
}
#app > .header .content .teams .team.--active::after {
  width: 100%;
  outline: 1px solid #fff;
}
#app > .header .content .teams .team.--score-added.--active {
  color: #fff;
  transition: color 0.1s;
}
#app > .header .content .teams .team.--score-added::after {
  transition: width 0.2s, background-color 0.1s;
  background-color: var(--color-highlight);
}
#app > .header .content .info {
  width: 100%;
  min-height: 10.375rem;
  background-color: rgba(255, 255, 255, 0.6980392157);
  border-bottom-left-radius: 0.375rem;
  border-bottom-right-radius: 0.375rem;
  padding: 0.625rem 0.625rem;
  padding-top: 1.25rem;
  padding-left: 3.125rem;
  font-size: 1.34375rem;
  line-height: 1.6875rem;
  font-weight: 300;
}
#app > .header .content .info strong {
  font-weight: 700;
  color: var(--color-highlight);
}
#app > .header .content .info h3 {
  font-size: 1.125rem;
  font-weight: 800;
  font-style: italic;
  line-height: 1.25rem;
  margin-bottom: 0.375rem;
  text-transform: uppercase;
}
#app > .header .content .info h3:empty {
  display: none;
}
#app > .header .content .timer-container {
  width: 8.4375rem;
  padding-top: 0.9375rem;
  padding-left: 0.625rem;
  flex-shrink: 0;
  display: none;
  align-items: center;
  justify-content: space-between;
  flex-direction: column;
}
#app > .header .content .timer-container .round-timer {
  position: relative;
  width: 6.25rem;
  height: 6.25rem;
}
#app > .header .content .timer-container .round-timer .progress {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: conic-gradient(var(--color-highlight) var(--progress, 0%), 0, transparent);
  border-radius: 50% 50%;
  opacity: 0.8;
  -webkit-mask: radial-gradient(2.375rem, rgba(0, 0, 0, 0) 99%, #000);
          mask: radial-gradient(2.375rem, rgba(0, 0, 0, 0) 99%, #000);
}
#app > .header .content .timer-container .round-timer .time {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translateY(-50%);
  font-size: 2.8125rem;
  line-height: 2.8125rem;
  font-weight: 900;
  font-style: italic;
}
#app > .header .content .timer-container button.pause {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-color: rgba(20, 75, 91, 0.3019607843);
  color: #144B5B;
  padding: 0.5rem 0.875rem;
  padding-left: 2.0625rem;
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 900;
  text-transform: uppercase;
  position: relative;
  border: none;
  transition: color 0.25s, background-color 0.25s;
}
#app > .header .content .timer-container button.pause::before {
  content: "";
  position: absolute;
  background-color: #144B5B;
  top: 50%;
  left: 0.625rem;
  width: 1rem;
  height: 1rem;
  -webkit-mask: var(--pause-icon) no-repeat 50% 50%;
          mask: var(--pause-icon) no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
  transform: translateY(-50%);
  transition: color 0.25s, background-color 0.25s;
}
#app > .header .content .timer-container button.pause:hover {
  background-color: #144B5B;
  color: #fff;
}
#app > .header .content .timer-container button.pause:hover::before {
  background-color: #fff;
}
#app > .header .content .note {
  display: none;
  padding-top: 0.625rem;
  padding-left: 0.625rem;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
}
#app > .header .content .note .icon {
  position: relative;
  width: 4.375rem;
  height: 4.375rem;
  border-radius: 4.375rem;
  background-color: var(--color-highlight);
  margin-bottom: 0.625rem;
}
#app > .header .content .note .icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 2.8125rem;
  height: 2.8125rem;
}
#app > .header .content .note p {
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
}
#app > .header .content .note.guide {
  max-width: 6.875rem;
}
#app > .header .content .note.guide .icon::after {
  background: url("../svg/icon-guide.svg") no-repeat 50% 50%;
  background-size: contain;
}
#app > .header .content .note.pen-and-paper {
  max-width: 6.25rem;
}
#app > .header .content .note.pen-and-paper .icon::after {
  width: 3rem;
  height: 3rem;
  background: url("../svg/icon-pen-and-paper.svg") no-repeat 50% 50%;
  background-size: contain;
  top: 56%;
  left: 42%;
}
#app.--started > .progress {
  transform: translateX(0);
}
#app.--started > .header .content {
  transform: translate(-50%, 0);
}
#app > .quick-timer {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2000;
  background-color: rgba(20, 75, 91, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s;
}
#app > .quick-timer.--active {
  pointer-events: auto;
  opacity: 1;
}
#app > .quick-timer .time {
  color: #fff;
  font-size: 28.125rem;
  font-weight: 900;
  font-style: italic;
}
#app .phase > .info-data {
  display: none !important;
}
#app .dialog {
  width: 50rem;
}
#app .dialog .container {
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  background-color: rgba(255, 255, 255, 0.4);
  border-radius: 0.375rem;
  padding: 0.9375rem;
  text-align: center;
}
#app .dialog .container .backdrop {
  background-color: rgba(255, 255, 255, 0.7);
  border-radius: 0.375rem;
}
#app .dialog .container .content-container {
  padding: 1.25rem 2.5rem;
  transition: filter 0.25s;
  filter: none;
}
#app .dialog .container .content-container h3 {
  text-transform: uppercase;
  font-size: 1.125rem;
  font-weight: 800;
  font-style: italic;
}
#app .dialog .container .content-container .round-details {
  margin-top: 1.25rem;
  font-size: 1.125rem;
  line-height: 1.25rem;
  font-weight: 500;
  font-style: italic;
  display: flex;
  justify-content: center;
  align-items: center;
}
#app .dialog .container .content-container .round-details .time {
  text-align: right;
  text-transform: uppercase;
}
#app .dialog .container .content-container .round-details .details {
  text-align: left;
}
#app .dialog .container .content-container .round-details > div {
  border-left: 0.125rem solid rgba(20, 75, 91, 0.5);
  padding: 0rem 0.625rem;
}
#app .dialog .container .content-container .round-details > div:first-child {
  border-left: 0;
}
#app .dialog .container .content-container .content {
  margin-top: 1.25rem;
  font-size: 1.375rem;
  line-height: 1.6875rem;
  font-weight: 300;
}
#app .dialog .container .content-container .content p {
  margin-bottom: 1.4em;
}
#app .dialog .container .content-container .content p:last-child {
  margin-bottom: 0;
}
#app .dialog .container .content-container .content strong {
  font-weight: 700;
  color: var(--color-highlight);
}
#app .dialog .container .content-container .cta {
  font-size: 1.375rem;
  line-height: 1.6875rem;
  margin-top: 1.875rem;
  font-weight: 700;
}
#app .dialog .container .content-container .notes {
  margin-top: 1.25rem;
  border-top: 0.125rem solid #144B5B;
  padding-top: 1.25rem;
  display: flex;
  justify-content: center;
  gap: 2.5rem;
}
#app .dialog .container .content-container .notes .note {
  display: flex;
  align-items: center;
  justify-content: center;
}
#app .dialog .container .content-container .notes .note .icon {
  flex-shrink: 0;
  position: relative;
  width: 4.375rem;
  height: 4.375rem;
  border-radius: 4.375rem;
  background-color: var(--color-highlight);
  margin-right: 1.25rem;
}
#app .dialog .container .content-container .notes .note .icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 2.8125rem;
  height: 2.8125rem;
}
#app .dialog .container .content-container .notes .note p {
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
}
#app .dialog .container .content-container .notes .note.points {
  text-align: left;
}
#app .dialog .container .content-container .notes .note.points .icon {
  background-color: transparent;
  border-radius: 0;
}
#app .dialog .container .content-container .notes .note.points .icon > img {
  width: auto;
  height: 4.375rem;
  display: block;
}
#app .dialog .container .content-container .notes .note.points .icon::after {
  display: none;
}
#app .dialog .container .content-container .notes .note.guide {
  max-width: 12.5rem;
}
#app .dialog .container .content-container .notes .note.guide .icon::after {
  background: url("../svg/icon-guide.svg") no-repeat 50% 50%;
  background-size: contain;
}
#app .dialog .container .content-container .notes .note.pen-and-paper {
  max-width: 16.875rem;
}
#app .dialog .container .content-container .notes .note.pen-and-paper .icon::after {
  width: 3rem;
  height: 3rem;
  background: url("../svg/icon-pen-and-paper.svg") no-repeat 50% 50%;
  background-size: contain;
  top: 56%;
  left: 42%;
}
#app .dialog .container .buttons {
  margin-top: 0.9375rem;
  text-align: center;
  transition: filter 0.25s;
  filter: none;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.5rem;
}
#app .dialog .container .buttons button[data-action=replay-announcer] {
  text-align: left;
  max-width: 8.125rem;
  --size: 3.4375rem;
  font-size: 1rem;
  padding: 0 1rem;
}
#app .dialog .container .buttons button[data-action=replay-announcer]::after {
  -webkit-mask-size: 2rem auto;
          mask-size: 2rem auto;
}
#app .phase[data-type=intro] {
  display: none;
  justify-content: center;
  min-height: 100vh;
  padding-top: 3.125rem;
  padding-bottom: 10.9375rem;
}
#app .phase[data-type=intro].--active {
  display: flex;
}
#app .phase[data-type=info] {
  display: none;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding-top: 11.5625rem;
  padding-bottom: 10.9375rem;
}
#app .phase[data-type=info].--active {
  display: flex;
}
#app .phase[data-type=info] .dialog {
  width: 37.5rem;
}
#app .phase[data-type=info] .dialog .container .content-container h3 {
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
}
#app .phase[data-type=info] .dialog .container .content-container .cta .buttons {
  margin-top: 1.875rem;
}
#app[data-round-timer-active=true] > .header .content .timer-container {
  display: flex;
}
#app[data-active-section=start] > .progress {
  opacity: 0;
  pointer-events: none;
}
#app .small-logo {
  top: auto;
  left: 2rem;
  bottom: 2rem;
}
#app section[data-section-type=start] {
  height: 100%;
  width: 100%;
  position: relative;
}
#app section[data-section-type=start] .picture {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
}
#app section[data-section-type=start] .picture > img {
  display: block;
  height: 100%;
  width: auto;
}
#app section[data-section-type=start] .content {
  position: absolute;
  top: 4rem;
  left: 4rem;
  z-index: 5;
}
#app section[data-section-type=start] .content .intro {
  position: relative;
}
#app section[data-section-type=start] .content .intro .prop::after {
  bottom: 0.375rem;
}
#app section[data-section-type=start] .content .intro .level {
  font-size: 1.125rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  display: flex;
  align-items: center;
}
#app section[data-section-type=start] .content .intro .level .indicators {
  margin-left: 0.625rem;
  display: flex;
  align-items: center;
  gap: 0.1875rem;
}
#app section[data-section-type=start] .content .intro .level .indicators .indicator {
  flex-shrink: 0;
  width: 0.875rem;
  height: 0.875rem;
  background-color: currentColor;
  -webkit-mask: url("../svg/icon-level-x-o.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-level-x-o.svg") no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
}
#app section[data-section-type=start] .content .intro .level .indicators .indicator.active {
  -webkit-mask-image: url("../svg/icon-level-x.svg");
          mask-image: url("../svg/icon-level-x.svg");
}
#app section[data-section-type=start] .content .intro h2 {
  margin-top: 1.875rem;
  font-size: 4rem;
  line-height: 4.0625rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
  max-width: 31.25rem;
}
#app section[data-section-type=start] .content .buttons {
  margin-top: 3.75rem;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  gap: 1.25rem;
}
#app section[data-section-type=start] .leader-note {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-background);
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 1.125rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  z-index: 300;
  text-transform: uppercase;
  opacity: 1;
  transition: opacity 0.25s;
}
#app section[data-section-type=start] .leader-note.--hidden {
  pointer-events: none;
  opacity: 0;
}
#app section[data-section-type=start] .leader-note .loader {
  margin: 0 auto;
  margin-top: 1.125rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.1875rem;
}
#app section[data-section-type=start] .leader-note .loader i {
  flex-shrink: 0;
  width: 0.875rem;
  height: 0.875rem;
  display: block;
  position: relative;
  --animation-time: 1.5s;
  animation-duration: var(--animation-time);
  animation-name: loader-rotation;
  animation-iteration-count: infinite;
  animation-fill-mode: forwards;
}
#app section[data-section-type=start] .leader-note .loader i:nth-child(2), #app section[data-section-type=start] .leader-note .loader i:nth-child(2)::after {
  animation-delay: calc(var(--animation-time) / 3 * 1);
}
#app section[data-section-type=start] .leader-note .loader i:nth-child(3), #app section[data-section-type=start] .leader-note .loader i:nth-child(3)::after {
  animation-delay: calc(var(--animation-time) / 3 * 2);
}
#app section[data-section-type=start] .leader-note .loader i::before, #app section[data-section-type=start] .leader-note .loader i::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: currentColor;
  -webkit-mask: url("../svg/icon-level-x-o.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-level-x-o.svg") no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
}
#app section[data-section-type=start] .leader-note .loader i::after {
  -webkit-mask-image: url("../svg/icon-level-x.svg");
          mask-image: url("../svg/icon-level-x.svg");
  animation-duration: var(--animation-time);
  animation-name: loader-opacity;
  animation-iteration-count: infinite;
  animation-fill-mode: forwards;
}
#app section[data-section-type=start] .picture, #app section[data-section-type=start] .content .intro, #app section[data-section-type=start] .content .buttons {
  opacity: 0;
  transform: translateY(2.5rem);
  transition: opacity 0.25s, transform 0.25s;
}
#app section[data-section-type=start] .content .buttons {
  transition-delay: 0.1s;
}
#app section[data-section-type=start] .picture {
  transition-delay: 0.2s;
}
#app section[data-section-type=start].--animate-in .picture, #app section[data-section-type=start].--animate-in .content .intro, #app section[data-section-type=start].--animate-in .content .buttons {
  opacity: 1;
  transform: translateY(0);
}
#app .footer {
  opacity: 0;
  pointer-events: none;
}
#app[data-active-section=start] .header .content, #app[data-active-section=video] .header .content, #app[data-active-section=infovideo] .header .content, #app[data-active-section=extra] .header .content {
  transform: translate(-50%, -105%);
}
#app[data-active-section=start] .footer, #app[data-active-section=video] .footer, #app[data-active-section=infovideo] .footer, #app[data-active-section=extra] .footer {
  opacity: 0;
}
#app[data-active-section=keywords] .header .content, #app[data-active-section=matrix] .header .content, #app[data-active-section=end] .header .content {
  transform: translate(-50%, -105%);
}
#app[data-active-section=team-select] .header .content .teams {
  opacity: 0;
}
#app[data-active-section=create_questions] .header .timer-container {
  display: none !important;
}
#app[data-active-section=negotiations] .header .timer-container {
  display: none !important;
}
#app[data-active-section=lines] > .header .content .info h3 {
  font-size: 2.625rem;
  line-height: 1.2em;
}
#app[data-active-phase=intro] .header .content, #app[data-active-phase=results] .header .content, #app[data-active-phase=end-video] .header .content {
  transform: translate(-50%, -105%);
}
#app[data-note=pen-and-paper] > .header .content .note.pen-and-paper {
  display: flex;
}
#app[data-note=guide] > .header .content .note.guide {
  display: flex;
}

.character-animator, .character-faces {
  position: relative;
  --width: 16.25rem;
  --height: 37.5rem;
  width: var(--width);
  height: var(--height);
  overflow: hidden;
  transition: transform 0.25s cubic-bezier(0.56, -1.5, 0.83, 0.67), opacity 0s 0.25s;
  opacity: 0;
  transform: translateY(3.75rem);
}
.character-animator .character-frame, .character-faces .character-frame {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--width);
  height: var(--height);
  opacity: 0.01;
}
.character-animator .character-frame > img, .character-faces .character-frame > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
}
.character-animator[data-animator-frame="1"] .frame-1, .character-faces[data-animator-frame="1"] .frame-1 {
  opacity: 1;
}
.character-animator[data-animator-frame="2"] .frame-2, .character-faces[data-animator-frame="2"] .frame-2 {
  opacity: 1;
}
.character-animator[data-animator-frame="3"] .frame-3, .character-faces[data-animator-frame="3"] .frame-3 {
  opacity: 1;
}
.character-animator[data-animator-frame="4"] .frame-4, .character-faces[data-animator-frame="4"] .frame-4 {
  opacity: 1;
}
.character-animator .character-frame.frame-neutral, .character-faces .character-frame.frame-neutral {
  opacity: 1;
}
.character-animator.--correct .character-frame.frame-neutral, .character-faces.--correct .character-frame.frame-neutral {
  opacity: 0;
}
.character-animator.--correct .character-frame.frame-correct, .character-faces.--correct .character-frame.frame-correct {
  opacity: 1;
}
.character-animator.--incorrect .character-frame.frame-neutral, .character-faces.--incorrect .character-frame.frame-neutral {
  opacity: 0;
}
.character-animator.--incorrect .character-frame.frame-incorrect, .character-faces.--incorrect .character-frame.frame-incorrect {
  opacity: 1;
}
.character-animator.--animate-in, .character-faces.--animate-in {
  transition: transform 0.25s cubic-bezier(0.34, 2, 0.64, 1), opacity 0s 0s;
  opacity: 1;
  transform: translateY(0);
}

body[data-announcer-playing=true] #app .phase:not(.--replaying)[data-type=intro] .dialog .container .content-container, body[data-announcer-playing=true] #app .phase:not(.--replaying)[data-type=intro] .dialog .container .buttons {
  pointer-events: none;
  filter: blur(0.5rem);
}

body.tarina-template-tarina-template-3_teams #app .small-logo {
  top: 1.5625rem;
  bottom: auto;
}
body.tarina-template-tarina-template-3_teams #app section[data-section-type=start] .content {
  top: auto;
  bottom: 4rem;
}

body.--feedback-open #app > .progress {
  transform: translateX(-105%);
}
body.--feedback-open #app > .sections, body.--feedback-open #app > .controls {
  pointer-events: none;
  transition: opacity 0.25s;
  opacity: 0 !important;
}

section.element {
  position: relative;
}
section.element .container {
  max-width: var(--container-max-width);
  padding: 0 var(--safety-padding);
  margin: 0 auto;
}
section.element:last-child {
  margin-bottom: 0;
}

.element.text-content {
  margin: 3.125rem 1.5625rem;
}

.timer {
  display: none;
}
.timer.--active {
  display: block;
}

section {
  position: relative;
}
section .phases .phase {
  display: none;
}
section .phases .phase.--active {
  display: block;
}
section .phases .results-container {
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  background-color: rgba(255, 255, 255, 0.4);
  border-radius: 0.375rem;
  padding: 0.9375rem;
}
section .phases .backdrop {
  background-color: rgba(255, 255, 255, 0.7);
  border-radius: 0.375rem;
}
section .phases .buttons {
  margin-top: 1.75rem;
  text-align: right;
}
section .phases .phase.results .results-container {
  width: 60.9375rem;
}
section .phases .phase.results .backdrop {
  text-align: center;
  padding: 2.5rem;
  position: relative;
}
section .phases .phase.results h3 {
  font-weight: 500;
  font-style: italic;
  font-size: 1.125rem;
  text-transform: uppercase;
}
section .phases .phase.results .results-content {
  margin-top: 2.1875rem;
  margin-bottom: 2.1875rem;
  min-height: 17.8125rem;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: flex-start;
  gap: 2.1875rem;
}
section .phases .phase.results .results-content .team {
  display: flex;
  align-items: center;
  gap: 1.5625rem;
}
section .phases .phase.results .results-content .team .icon {
  opacity: 1;
  transition: opacity 0.25s;
  position: relative;
  width: 5rem;
  height: 5rem;
}
section .phases .phase.results .results-content .team .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
section .phases .phase.results .results-content .team .score {
  min-width: 2.5rem;
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 300;
  text-transform: uppercase;
  font-style: italic;
}
section .phases .phase.results .results-content .team .pearls {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  opacity: 1;
  transition: opacity 0.3s;
}
section .phases .phase.results .results-content .team .pearls i {
  display: block;
  position: relative;
  width: 0.9375rem;
  height: 1.875rem;
  opacity: 0;
  transform: translateX(0.3125rem);
  transition: opacity 0.05s, transform 0.1s;
}
section .phases .phase.results .results-content .team .pearls i::after {
  content: "";
  position: absolute;
  top: 0;
  width: 1.875rem;
  height: 1.875rem;
  background: transparent var(--score-element) no-repeat 50% 50%;
  background-size: contain;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(1) {
  transition-delay: 0.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(2) {
  transition-delay: 0.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(3) {
  transition-delay: 0.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(4) {
  transition-delay: 0.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(5) {
  transition-delay: 1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(6) {
  transition-delay: 1.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(7) {
  transition-delay: 1.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(8) {
  transition-delay: 1.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(9) {
  transition-delay: 1.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(10) {
  transition-delay: 1.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(11) {
  transition-delay: 1.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(12) {
  transition-delay: 1.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(13) {
  transition-delay: 1.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(14) {
  transition-delay: 1.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(15) {
  transition-delay: 2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(16) {
  transition-delay: 2.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(17) {
  transition-delay: 2.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(18) {
  transition-delay: 2.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(19) {
  transition-delay: 2.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(20) {
  transition-delay: 2.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(21) {
  transition-delay: 2.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(22) {
  transition-delay: 2.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(23) {
  transition-delay: 2.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(24) {
  transition-delay: 2.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(25) {
  transition-delay: 3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(26) {
  transition-delay: 3.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(27) {
  transition-delay: 3.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(28) {
  transition-delay: 3.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(29) {
  transition-delay: 3.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(30) {
  transition-delay: 3.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(31) {
  transition-delay: 3.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(32) {
  transition-delay: 3.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(33) {
  transition-delay: 3.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(34) {
  transition-delay: 3.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(35) {
  transition-delay: 4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(36) {
  transition-delay: 4.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(37) {
  transition-delay: 4.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(38) {
  transition-delay: 4.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(39) {
  transition-delay: 4.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(40) {
  transition-delay: 4.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(41) {
  transition-delay: 4.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(42) {
  transition-delay: 4.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(43) {
  transition-delay: 4.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(44) {
  transition-delay: 4.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(45) {
  transition-delay: 5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(46) {
  transition-delay: 5.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(47) {
  transition-delay: 5.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(48) {
  transition-delay: 5.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(49) {
  transition-delay: 5.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(50) {
  transition-delay: 5.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(51) {
  transition-delay: 5.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(52) {
  transition-delay: 5.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(53) {
  transition-delay: 5.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(54) {
  transition-delay: 5.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(55) {
  transition-delay: 6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(56) {
  transition-delay: 6.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(57) {
  transition-delay: 6.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(58) {
  transition-delay: 6.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(59) {
  transition-delay: 6.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(60) {
  transition-delay: 6.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(61) {
  transition-delay: 6.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(62) {
  transition-delay: 6.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(63) {
  transition-delay: 6.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(64) {
  transition-delay: 6.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(65) {
  transition-delay: 7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(66) {
  transition-delay: 7.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(67) {
  transition-delay: 7.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(68) {
  transition-delay: 7.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(69) {
  transition-delay: 7.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(70) {
  transition-delay: 7.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(71) {
  transition-delay: 7.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(72) {
  transition-delay: 7.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(73) {
  transition-delay: 7.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(74) {
  transition-delay: 7.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(75) {
  transition-delay: 8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(76) {
  transition-delay: 8.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(77) {
  transition-delay: 8.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(78) {
  transition-delay: 8.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(79) {
  transition-delay: 8.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(80) {
  transition-delay: 8.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(81) {
  transition-delay: 8.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(82) {
  transition-delay: 8.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(83) {
  transition-delay: 8.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(84) {
  transition-delay: 8.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(85) {
  transition-delay: 9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(86) {
  transition-delay: 9.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(87) {
  transition-delay: 9.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(88) {
  transition-delay: 9.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(89) {
  transition-delay: 9.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(90) {
  transition-delay: 9.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(91) {
  transition-delay: 9.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(92) {
  transition-delay: 9.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(93) {
  transition-delay: 9.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(94) {
  transition-delay: 9.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(95) {
  transition-delay: 10s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(96) {
  transition-delay: 10.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(97) {
  transition-delay: 10.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(98) {
  transition-delay: 10.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(99) {
  transition-delay: 10.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(100) {
  transition-delay: 10.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(101) {
  transition-delay: 10.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(102) {
  transition-delay: 10.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(103) {
  transition-delay: 10.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(104) {
  transition-delay: 10.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(105) {
  transition-delay: 11s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(106) {
  transition-delay: 11.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(107) {
  transition-delay: 11.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(108) {
  transition-delay: 11.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(109) {
  transition-delay: 11.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(110) {
  transition-delay: 11.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(111) {
  transition-delay: 11.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(112) {
  transition-delay: 11.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(113) {
  transition-delay: 11.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(114) {
  transition-delay: 11.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(115) {
  transition-delay: 12s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(116) {
  transition-delay: 12.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(117) {
  transition-delay: 12.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(118) {
  transition-delay: 12.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(119) {
  transition-delay: 12.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(120) {
  transition-delay: 12.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(121) {
  transition-delay: 12.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(122) {
  transition-delay: 12.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(123) {
  transition-delay: 12.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(124) {
  transition-delay: 12.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(125) {
  transition-delay: 13s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(126) {
  transition-delay: 13.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(127) {
  transition-delay: 13.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(128) {
  transition-delay: 13.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(129) {
  transition-delay: 13.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(130) {
  transition-delay: 13.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(131) {
  transition-delay: 13.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(132) {
  transition-delay: 13.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(133) {
  transition-delay: 13.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(134) {
  transition-delay: 13.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(135) {
  transition-delay: 14s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(136) {
  transition-delay: 14.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(137) {
  transition-delay: 14.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(138) {
  transition-delay: 14.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(139) {
  transition-delay: 14.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(140) {
  transition-delay: 14.5s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(141) {
  transition-delay: 14.6s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(142) {
  transition-delay: 14.7s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(143) {
  transition-delay: 14.8s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(144) {
  transition-delay: 14.9s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(145) {
  transition-delay: 15s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(146) {
  transition-delay: 15.1s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(147) {
  transition-delay: 15.2s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(148) {
  transition-delay: 15.3s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(149) {
  transition-delay: 15.4s;
}
section .phases .phase.results .results-content .team .pearls i:nth-child(150) {
  transition-delay: 15.5s;
}
section .phases .phase.results .results-content .team .character-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  overflow: hidden;
}
section .phases .phase.results .results-content .team .character-container .name {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 4rem;
  line-height: 4.0625rem;
  font-weight: 900;
  font-style: italic;
  text-transform: uppercase;
  opacity: 0;
  transition: opacity 0.25s;
}
section .phases .phase.results .results-content .team .character-container .character-animator {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 18.75rem;
  --width: 16.25rem;
  --height: 37.5rem;
  border-bottom-right-radius: 0.375rem;
}
section .phases .phase.results .results-content .team.--winner .icon {
  opacity: 1 !important;
}
section .phases .phase.results .results-content .team.--winner .score {
  font-weight: 900;
}
section .phases .phase.results .results-content .team.--winner .character-container .name {
  opacity: 1;
}
section .phases .phase.results .results-content:has(.team.--winner) .team .icon {
  opacity: 0.5;
}
section .phases .phase.results .results-content.--animate-in .team .pearls i {
  opacity: 1;
  transform: translateX(0);
}
section .phases .phase.results .results-content:has(.team.--winner) .pearls {
  opacity: 0;
}
section .phases .phase.results .final-results-content {
  margin-top: 5rem;
  margin-bottom: 5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5rem;
}
section .phases .phase.results .final-results-content .team {
  display: flex;
  flex-direction: column;
  align-items: center;
}
section .phases .phase.results .final-results-content .team .icon {
  position: relative;
  width: 5rem;
  height: 5rem;
}
section .phases .phase.results .final-results-content .team .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
section .phases .phase.results .final-results-content .team .name {
  margin: 0.625rem 0;
  font-size: 1.125rem;
  line-height: 1.25rem;
  font-weight: 500;
  font-style: italic;
  text-transform: uppercase;
}
section .phases .phase.results .final-results-content .team .score {
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
}
section .phases .phase.results .buttons {
  margin-top: 1rem;
}
section .phases .phase.standard-results.results {
  height: 100vh;
  justify-content: center;
  align-items: flex-start;
}
section .phases .phase.standard-results.results.--active {
  display: flex;
}
section .phases .phase.standard-results.results .results-container {
  margin-top: 1.5625rem;
  opacity: 0;
  transform: translateY(2.5rem);
  transition: opacity 0.25s, transform 0.25s;
}
section .phases .phase.standard-results.results.--animate-in .results-container {
  opacity: 1;
  transform: translateY(0);
}
section .phases .phase.standard-results.results.--animate-out .results-container {
  opacity: 0;
  transform: translateY(-2.5rem);
}
section button.hide[disabled] {
  display: none;
}

#sections section:not(.--active) {
  display: none !important;
  pointer-events: none;
}

section .phase .dialog {
  opacity: 0;
  transform: translateY(2.5rem);
}
section .phase.--active .dialog {
  transition: opacity 0.25s, transform 0.25s;
}
section .phase.--animate-in .dialog {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.25s, transform 0.25s;
}
section .phase.--animate-out .dialog {
  opacity: 0;
  transform: translateY(-2.5rem);
}

section[data-section-type=video] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(20, 75, 91, 0.6980392157);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  z-index: 800;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: opacity 0.25s;
  opacity: 0;
}
section[data-section-type=video].--active {
  display: flex;
}
section[data-section-type=video] .container {
  position: relative;
  overflow: hidden;
  border-radius: 0.375rem;
  background-color: #144B5B;
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  transform: translateY(2.5rem);
  transition: transform 0.25s;
}
section[data-section-type=video] .container .video-container {
  background-color: #000;
  height: 41.25rem;
  width: 73.3125rem;
}
section[data-section-type=video] .container video {
  background-color: #000;
  display: block;
  height: 41.25rem;
  width: 73.3125rem;
}
section[data-section-type=video] .container .after-complete {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  background-color: rgba(255, 255, 255, 0.8);
}
section[data-section-type=video] .container .after-complete .buttons {
  pointer-events: none;
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  position: relative;
  z-index: 1;
}
section[data-section-type=video] .container .after-complete.--visible {
  opacity: 1;
  pointer-events: auto;
}
section[data-section-type=video] .container .after-complete.--visible .buttons {
  pointer-events: auto;
  display: flex;
}
section[data-section-type=video].--animate-in {
  opacity: 1;
}
section[data-section-type=video].--animate-in .container {
  transform: translateY(0);
}
section[data-section-type=video].--animate-out {
  transition: opacity 0.25s;
  opacity: 0;
}
section[data-section-type=video].--animate-out .container {
  transform: translateY(-2.5rem);
}

section[data-section-type=infovideo] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 800;
  display: flex;
  justify-content: center;
  align-items: center;
}
section[data-section-type=infovideo].--active {
  display: flex;
}
section[data-section-type=infovideo] .container {
  position: relative;
  transition: transform 0.5s;
  z-index: 15;
}
section[data-section-type=infovideo] .container .video {
  position: relative;
  background-color: rgba(255, 255, 255, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  padding: 0.9375rem;
  border-radius: 0.375rem;
  opacity: 0;
  transition: opacity 0.5s;
  pointer-events: none;
}
section[data-section-type=infovideo] .container .video .video-container {
  background-color: #000;
  position: relative;
  z-index: 10;
  position: relative;
  overflow: hidden;
  border-radius: 0.375rem;
  height: 39.375rem;
  width: 22.125rem;
}
section[data-section-type=infovideo] .container .video .video-container video {
  background-color: #000;
  display: block;
  height: 39.375rem;
  width: 22.125rem;
}
section[data-section-type=infovideo] .container .video .video-container .after-complete {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  background-color: rgba(255, 255, 255, 0.8666666667);
}
section[data-section-type=infovideo] .container .video .video-container .after-complete .buttons {
  pointer-events: none;
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  position: relative;
  z-index: 1;
}
section[data-section-type=infovideo] .container .video .video-container .after-complete.--visible {
  opacity: 1;
  pointer-events: auto;
}
section[data-section-type=infovideo] .container .video .video-container .after-complete.--visible .buttons {
  pointer-events: auto;
  display: flex;
}
section[data-section-type=infovideo] .container::after {
  background-color: var(--title-color);
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18.75rem;
  height: 18.75rem;
  -webkit-mask: url("../svg/title-infovideo.svg") no-repeat 50% 50%;
          mask: url("../svg/title-infovideo.svg") no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
  transform: translate(-50%, -50%) translateY(2.5rem);
  transition: transform 0.25s, opacity 0.25s;
  z-index: -1;
  opacity: 0;
}
section[data-section-type=infovideo] .keywords-container {
  position: absolute;
  top: 0;
  left: 50%;
  right: 0;
  bottom: 0;
  padding: 2.5rem;
  padding-left: 1.25rem;
  padding-top: 3.5rem;
  display: flex;
  align-items: stretch;
  opacity: 0;
  transition: opacity 0.5s 0.5s;
  z-index: 10;
}
section[data-section-type=infovideo] .keywords-container .keywords {
  width: 100%;
  border: 0.125rem solid #144B5B;
  border-top: 0;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
section[data-section-type=infovideo] .keywords-container .keywords .heading {
  width: 100%;
  position: relative;
  text-align: center;
  margin-bottom: 1.875rem;
}
section[data-section-type=infovideo] .keywords-container .keywords .heading h3 {
  display: flex;
  margin: 0 auto;
  font-size: 1.875rem;
  line-height: 2rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
}
section[data-section-type=infovideo] .keywords-container .keywords .heading h3::before, section[data-section-type=infovideo] .keywords-container .keywords .heading h3::after {
  content: "";
  display: block;
  width: 100%;
  border-top: 0.125rem solid #144B5B;
}
section[data-section-type=infovideo] .keywords-container .keywords .heading h3 span {
  margin: 0 2.5rem;
  display: block;
  white-space: nowrap;
  flex-shrink: 0;
  position: relative;
  transform: translateY(-50%);
}
section[data-section-type=infovideo] .keywords-container .keywords .heading h3 span::before, section[data-section-type=infovideo] .keywords-container .keywords .heading h3 span::after {
  content: "";
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  background: url("../svg/icon-close.svg") no-repeat 50% 50%;
  background-size: contain;
}
section[data-section-type=infovideo] .keywords-container .keywords .heading h3 span::before {
  margin-right: 1.25rem;
}
section[data-section-type=infovideo] .keywords-container .keywords .heading h3 span::after {
  margin-left: 1.25rem;
}
section[data-section-type=infovideo] .keywords-container .keywords .words {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.25rem;
  margin-bottom: 3.125rem;
  font-size: 1.875rem;
  font-weight: 800;
}
section[data-section-type=infovideo] .keywords-container .keywords .words .word {
  line-height: 2.1875rem;
  background-color: #859aa2;
  padding: 0.625rem 1.25rem;
  border-radius: 2.1875rem;
  position: relative;
  transition: background-color 0.3s;
}
section[data-section-type=infovideo] .keywords-container .keywords .words .word::before {
  content: "?";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #5a7580;
  opacity: 1;
  transition: opacity 0.3s;
}
section[data-section-type=infovideo] .keywords-container .keywords .words .word span {
  color: #000;
  opacity: 0;
  transition: opacity 0.3s;
}
section[data-section-type=infovideo] .keywords-container .keywords button {
  margin-top: auto;
  margin-bottom: 3.125rem;
}
section[data-section-type=infovideo].--animate-in .container::after {
  opacity: 1;
  transform: translate(-50%, -50%);
}
section[data-section-type=infovideo].--animation-phase-2 .container .video {
  transition-delay: var(--title-delay);
  opacity: 1;
  pointer-events: all;
}
section[data-section-type=infovideo].--animation-phase-2 .container::after {
  transition: transform 0.5s, opacity 0.25s;
  transition-delay: var(--title-delay);
  transform: translate(-50%, -50%) translate(-14.6875rem, -11.25rem) rotate(-30deg) scale(0.66, 0.66);
}
section[data-section-type=infovideo].--video-completed .keywords-container {
  opacity: 1;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word {
  background-color: var(--color-highlight-light);
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word::before {
  opacity: 0;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word span {
  opacity: 1;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(1) {
  transition-delay: 1.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(1)::before {
  transition-delay: 1.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(1) span {
  transition-delay: 1.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(2) {
  transition-delay: 2s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(2)::before {
  transition-delay: 2s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(2) span {
  transition-delay: 2s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(3) {
  transition-delay: 2.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(3)::before {
  transition-delay: 2.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(3) span {
  transition-delay: 2.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(4) {
  transition-delay: 3s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(4)::before {
  transition-delay: 3s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(4) span {
  transition-delay: 3s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(5) {
  transition-delay: 3.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(5)::before {
  transition-delay: 3.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(5) span {
  transition-delay: 3.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(6) {
  transition-delay: 4s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(6)::before {
  transition-delay: 4s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(6) span {
  transition-delay: 4s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(7) {
  transition-delay: 4.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(7)::before {
  transition-delay: 4.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(7) span {
  transition-delay: 4.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(8) {
  transition-delay: 5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(8)::before {
  transition-delay: 5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(8) span {
  transition-delay: 5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(9) {
  transition-delay: 5.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(9)::before {
  transition-delay: 5.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(9) span {
  transition-delay: 5.5s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(10) {
  transition-delay: 6s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(10)::before {
  transition-delay: 6s;
}
section[data-section-type=infovideo].--video-completed .keywords-container .keywords .words .word:nth-child(10) span {
  transition-delay: 6s;
}
section[data-section-type=infovideo].has-keywords.--video-completed .container {
  transform: translateX(calc(-50% - 1.25rem));
}
section[data-section-type=infovideo].--animate-out .container {
  transition: opacity 0.25s, transform 0.25s;
  opacity: 0;
  transform: translateY(-2.5rem);
}
section[data-section-type=infovideo].--animate-out .container .video .video-container video {
  display: none;
}
section[data-section-type=infovideo][data-escalation-level="7"], section[data-section-type=infovideo][data-escalation-level="8"] {
  --title-color: #fff;
}

section[data-section-type=keywords] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 50;
  display: flex;
  justify-content: center;
  align-items: center;
}
section[data-section-type=keywords].--active {
  display: flex;
}
section[data-section-type=keywords] .container {
  position: absolute;
  top: 0;
  left: 6.875rem;
  right: 0;
  bottom: 0;
  padding: 2.5rem;
  padding-top: 3.5rem;
  display: flex;
  align-items: stretch;
  opacity: 0;
  transition: opacity 0.5s 0.5s;
}
section[data-section-type=keywords] .container .keywords {
  width: 100%;
  border: 0.125rem solid #144B5B;
  border-top: 0;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
}
section[data-section-type=keywords] .container .keywords .heading {
  width: 100%;
  position: relative;
  text-align: center;
  margin-bottom: 1.875rem;
}
section[data-section-type=keywords] .container .keywords .heading h3 {
  display: flex;
  margin: 0 auto;
  font-size: 1.875rem;
  line-height: 2rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
}
section[data-section-type=keywords] .container .keywords .heading h3::before, section[data-section-type=keywords] .container .keywords .heading h3::after {
  content: "";
  display: block;
  width: 100%;
  border-top: 0.125rem solid #144B5B;
}
section[data-section-type=keywords] .container .keywords .heading h3 span {
  margin: 0 2.5rem;
  display: block;
  white-space: nowrap;
  flex-shrink: 0;
  position: relative;
  transform: translateY(-50%);
}
section[data-section-type=keywords] .container .keywords .heading h3 span::before, section[data-section-type=keywords] .container .keywords .heading h3 span::after {
  content: "";
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  background: url("../svg/icon-close.svg") no-repeat 50% 50%;
  background-size: contain;
}
section[data-section-type=keywords] .container .keywords .heading h3 span::before {
  margin-right: 1.25rem;
}
section[data-section-type=keywords] .container .keywords .heading h3 span::after {
  margin-left: 1.25rem;
}
section[data-section-type=keywords] .container .keywords .centerer {
  display: flex;
  align-items: center;
  height: 100%;
}
section[data-section-type=keywords] .container .keywords .centerer .words {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin: 0 auto;
  margin-top: 3.75rem;
  width: 51.25rem;
  gap: 2.5rem 5rem;
  font-size: 1.875rem;
  font-weight: 800;
}
section[data-section-type=keywords] .container .keywords .centerer .words .word {
  line-height: 2.1875rem;
  background-color: #859aa2;
  padding: 0.625rem 1.25rem;
  border-radius: 2.1875rem;
  position: relative;
  transition: background-color 0.3s;
}
section[data-section-type=keywords] .container .keywords .centerer .words .word::before {
  content: "?";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #5a7580;
  opacity: 1;
  transition: opacity 0.3s;
}
section[data-section-type=keywords] .container .keywords .centerer .words .word span {
  color: #000;
  opacity: 0;
  transition: opacity 0.3s;
}
section[data-section-type=keywords] .container .keywords button {
  margin-top: 4.375rem;
  margin-bottom: 10rem;
}
section[data-section-type=keywords].--animate-in .container {
  opacity: 1;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word {
  background-color: var(--color-highlight-light);
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word::before {
  opacity: 0;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word span {
  opacity: 1;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(1) {
  transition-delay: 1.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(1)::before {
  transition-delay: 1.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(1) span {
  transition-delay: 1.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(2) {
  transition-delay: 2s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(2)::before {
  transition-delay: 2s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(2) span {
  transition-delay: 2s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(3) {
  transition-delay: 2.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(3)::before {
  transition-delay: 2.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(3) span {
  transition-delay: 2.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(4) {
  transition-delay: 3s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(4)::before {
  transition-delay: 3s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(4) span {
  transition-delay: 3s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(5) {
  transition-delay: 3.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(5)::before {
  transition-delay: 3.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(5) span {
  transition-delay: 3.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(6) {
  transition-delay: 4s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(6)::before {
  transition-delay: 4s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(6) span {
  transition-delay: 4s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(7) {
  transition-delay: 4.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(7)::before {
  transition-delay: 4.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(7) span {
  transition-delay: 4.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(8) {
  transition-delay: 5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(8)::before {
  transition-delay: 5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(8) span {
  transition-delay: 5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(9) {
  transition-delay: 5.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(9)::before {
  transition-delay: 5.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(9) span {
  transition-delay: 5.5s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(10) {
  transition-delay: 6s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(10)::before {
  transition-delay: 6s;
}
section[data-section-type=keywords].--animate-in .container .keywords .words .word:nth-child(10) span {
  transition-delay: 6s;
}

#app section[data-section-type=extra] {
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 10;
}
#app section[data-section-type=extra] > .container {
  position: relative;
  min-width: 50rem;
}
#app section[data-section-type=extra] > .container .phases {
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  background-color: rgba(255, 255, 255, 0.4);
  border-radius: 0.375rem;
  padding: 0.9375rem;
  opacity: 0;
  transition: opacity 0.5s;
}
#app section[data-section-type=extra] > .container .phases .phase {
  width: 48.125rem;
}
#app section[data-section-type=extra] > .container .phases .phase.--results {
  width: 59.0625rem;
}
#app section[data-section-type=extra] > .container form .heading-container {
  position: relative;
  margin-bottom: 1.25rem;
  padding: 1.25rem;
  text-align: center;
  font-weight: 500;
  font-size: 1.125rem;
  font-style: italic;
  line-height: 1.25rem;
  text-transform: uppercase;
}
#app section[data-section-type=extra] > .container form .heading-container .heading {
  opacity: 1;
  transition: opacity 0.3s;
}
#app section[data-section-type=extra] > .container form .heading-container .heading h3 {
  font-size: 1.125rem;
  font-weight: 800;
  margin-bottom: 1.25rem;
}
#app section[data-section-type=extra] > .container form .heading-container .message {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
}
#app section[data-section-type=extra] > .container form .question-container {
  padding: 1.25rem;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  border-bottom: 0.125rem solid #144B5B;
  margin-bottom: 3.125rem;
}
#app section[data-section-type=extra] > .container form .question-container .team {
  border-right: 0.125rem solid #144B5B;
  padding-right: 1.25rem;
  margin-right: 1.25rem;
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
  display: flex;
  align-items: center;
}
#app section[data-section-type=extra] > .container form .question-container .team .icon {
  width: 3.75rem;
  height: 3.75rem;
  margin-right: 0.625rem;
  position: relative;
}
#app section[data-section-type=extra] > .container form .question-container .team .icon img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#app section[data-section-type=extra] > .container form .question-container .question {
  font-weight: 800;
  font-size: 1.375rem;
  line-height: 1.5rem;
  display: flex;
  align-items: center;
}
#app section[data-section-type=extra] > .container form fieldset.question {
  border: 0;
  outline: 0;
  display: flex;
  flex-direction: column;
  gap: 1.625rem;
  width: 28.125rem;
  margin: 0 auto;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton {
  cursor: pointer;
  position: relative;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton input {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton span {
  margin-left: 3.375rem;
  font-size: 1.6875rem;
  line-height: 1.875rem;
  font-weight: 800;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone;
  background-color: #000;
  color: var(--color);
  padding: 0.5rem 1.5rem;
  border-radius: 1.875rem;
  transition: color 0.25s, background-color 0.25s;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton span em {
  font-style: normal;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton::before {
  content: "";
  position: absolute;
  top: -0.5rem;
  left: 0;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 1.375rem;
  background-color: #000;
  transition: color 0.25s, background-color 0.25s;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton::after {
  content: "";
  position: absolute;
  top: -0.5rem;
  left: 0;
  width: 2.75rem;
  height: 2.75rem;
  padding-top: 0.25rem;
  text-align: center;
  vertical-align: middle;
  font-size: 1.875rem;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--color);
  transition: color 0.25s, background-color 0.25s;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:nth-child(1)::after {
  content: "A";
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:nth-child(2)::after {
  content: "B";
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:nth-child(3)::after {
  content: "C";
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:nth-child(4)::after {
  content: "D";
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:nth-child(5)::after {
  content: "E";
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:nth-child(6)::after {
  content: "F";
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--incorrect span {
  background-color: #e5eaec;
  color: #b4c1c7;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--incorrect::before {
  background-color: #e5eaec;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--incorrect::after {
  content: "";
  background-color: #b4c1c7;
  -webkit-mask: url("../svg/icon-incorrect.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-incorrect.svg") no-repeat 50% 50%;
  -webkit-mask-size: 1.125rem auto;
          mask-size: 1.125rem auto;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--correct span {
  background-color: #e5eaec;
  color: #b4c1c7;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--correct::before {
  background-color: var(--color-highlight);
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--correct::after {
  content: "";
  background-color: #000;
  -webkit-mask: url("../svg/icon-correct.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-correct.svg") no-repeat 50% 50%;
  -webkit-mask-size: 1.25rem auto;
          mask-size: 1.25rem auto;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:not(.--correct):not(.--incorrect):hover span {
  background-color: var(--color);
  color: #000;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:not(.--correct):not(.--incorrect):hover::before {
  background-color: var(--color);
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton:not(.--correct):not(.--incorrect):hover::after {
  color: #000;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--answered.--incorrect::before {
  background-color: #89A5AD;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--answered.--incorrect::after {
  background-color: #144B5B;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--answered.--incorrect span {
  background-color: #89A5AD;
  color: #144B5B;
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--answered.--correct::before {
  background-color: var(--color-highlight-light);
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--answered.--correct::after {
  background-color: var(--color-highlight-dark);
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--answered.--correct span {
  background-color: var(--color-highlight-light);
  color: var(--color-highlight-dark);
}
#app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--incorrect, #app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--correct, #app section[data-section-type=extra] > .container form fieldset.question .radiobutton.--answered {
  cursor: default;
}
#app section[data-section-type=extra] > .container form.--correct .heading-container .heading {
  opacity: 0;
}
#app section[data-section-type=extra] > .container form.--correct .heading-container .message.--correct {
  opacity: 1;
}
#app section[data-section-type=extra] > .container form.--incorrect .heading-container .heading {
  opacity: 0;
}
#app section[data-section-type=extra] > .container form.--incorrect .heading-container .message.--incorrect {
  opacity: 1;
}
#app section[data-section-type=extra] > .container::before {
  z-index: -1;
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18.75rem;
  height: 18.75rem;
  background-color: var(--title-color);
  -webkit-mask: url("../svg/title-extra.svg") no-repeat 50% 50%;
          mask: url("../svg/title-extra.svg") no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
  opacity: 0;
  transform: translate(-50%, -50%) translateY(2.5rem);
  transition: transform 0.25s, opacity 0.25s;
}
#app section[data-section-type=extra] button:not(.control)[disabled].--hide {
  display: initial;
  opacity: 0;
  pointer-events: none;
}
#app section[data-section-type=extra].--animate-in > .container::before {
  opacity: 1;
  transform: translate(-50%, -50%);
}
#app section[data-section-type=extra].--animation-phase-2 > .container::before {
  transition: transform 0.5s, opacity 0.25s;
  transition-delay: var(--title-delay);
  transform: translate(-50%, -50%) translateX(-28.125rem) translateY(6.25rem) rotate(-30deg) scale(0.66, 0.66);
}
#app section[data-section-type=extra].--animation-phase-2 > .container .phases {
  transition-delay: var(--title-delay);
  opacity: 1;
}
#app section[data-section-type=extra].--animate-out > .container {
  transition: opacity 0.25s, transform 0.25s;
  opacity: 0;
  transform: translateY(-2.5rem);
}
#app section[data-section-type=extra][data-escalation-level="7"], #app section[data-section-type=extra][data-escalation-level="8"] {
  --title-color: #fff;
}

#app[data-active-phase=results] section[data-section-type=extra] > .container::before {
  transition: opacity 0.25s;
  opacity: 0;
}

#app[data-story=kasvukipuja] section[data-section-type=extra] {
  --color-highlight-dark: #636ED2;
}
#app[data-story=kasvukipuja] section[data-section-type=extra] > .container form fieldset.question {
  --color-highlight: #A1A8E4;
}

section[data-section-type="2_choices"] .phase.questionform {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
section[data-section-type="2_choices"] .phase.questionform.--active {
  display: flex;
}
section[data-section-type="2_choices"] .phase.questionform .frame {
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
}
section[data-section-type="2_choices"] .phase.questionform .frame .round-info {
  flex-grow: 0;
  text-align: center;
  padding-top: 5.9375rem;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #144B5B;
}
section[data-section-type="2_choices"] .phase.questionform .character-container {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%) translateY(-3.125rem);
  width: 25rem;
  height: 37.5rem;
}
section[data-section-type="2_choices"] .phase.questionform .character-container .character-faces {
  --width: 35rem;
  --height: 68.75rem;
}
section[data-section-type="2_choices"] form.questions {
  height: 100%;
}
section[data-section-type="2_choices"] form.questions fieldset {
  border: none;
  display: none;
  height: 100%;
}
section[data-section-type="2_choices"] form.questions fieldset.question {
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 3.75rem;
  text-align: center;
}
section[data-section-type="2_choices"] form.questions fieldset.question p {
  color: #000;
  font-weight: 800;
  font-size: 2.4375rem;
  line-height: 3.125rem;
  width: 32.5rem;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers {
  display: flex;
  gap: 9.375rem;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton {
  color: #fff;
  background-color: #000;
  border-radius: 2.25rem;
  font-size: 2.4375rem;
  line-height: 3.125rem;
  padding: 0.5rem 3.4375rem;
  min-width: 9.0625rem;
  font-weight: 800;
  position: relative;
  cursor: pointer;
  transition: color 0.3s, background-color 0.3s;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton span em {
  font-style: normal;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton span em::before {
  content: "";
  background-color: #fff;
  position: absolute;
  width: 3.4375rem;
  height: 3.4375rem;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50% 50%;
  opacity: 0;
  transition: opacity 0.3s;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton span em::after {
  content: "";
  position: absolute;
  width: 3.4375rem;
  height: 3.4375rem;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity 0.3s;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton input {
  display: none;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton:not(.--correct):not(.--incorrect):hover {
  color: #000;
  background-color: #fff;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton.--correct span em::before, section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton.--incorrect span em::before {
  opacity: 1;
  background-color: #fff;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton.--correct span em::after, section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton.--incorrect span em::after {
  opacity: 1;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton.--correct {
  background-color: var(--color-highlight);
  color: var(--color-highlight-dark);
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton.--correct span em::after {
  background-color: var(--color-highlight);
  -webkit-mask: url("../svg/icon-correct.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-correct.svg") no-repeat 50% 50%;
  -webkit-mask-size: 2.125rem auto;
          mask-size: 2.125rem auto;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton.--incorrect {
  background-color: #144B5B;
  color: #144B5B;
}
section[data-section-type="2_choices"] form.questions fieldset.question .answers label.radiobutton.--incorrect span em::after {
  background-color: #144B5B;
  -webkit-mask: url("../svg/icon-incorrect.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-incorrect.svg") no-repeat 50% 50%;
  -webkit-mask-size: 1.875rem auto;
          mask-size: 1.875rem auto;
}
section[data-section-type="2_choices"] form.questions fieldset.--active {
  display: flex;
}
section[data-section-type="2_choices"] form.questions fieldset.--answered {
  pointer-events: none;
}

#app section[data-section-type=create_questions] .phase.questions, #app section[data-section-type=create_questions] .phase.questionform {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=create_questions] .phase.questions.--active, #app section[data-section-type=create_questions] .phase.questionform.--active {
  display: flex;
}
#app section[data-section-type=create_questions] .phase.questions .buttons, #app section[data-section-type=create_questions] .phase.questionform .buttons {
  margin-top: 1.25rem;
}
#app section[data-section-type=create_questions] .phase.questions .frame, #app section[data-section-type=create_questions] .phase.questionform .frame {
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 1.25rem 2.5rem;
  padding-top: 8.75rem;
  display: flex;
}
#app section[data-section-type=create_questions] .phase.questions .frame .round-info, #app section[data-section-type=create_questions] .phase.questionform .frame .round-info {
  flex-grow: 0;
  text-align: center;
  padding-top: 5.9375rem;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid, #app section[data-section-type=create_questions] .phase.questionform .frame .grid {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams {
  width: 100%;
  display: flex;
  align-items: stretch;
  height: 100%;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team {
  width: 50%;
  border-left: 0.125rem solid #144B5B;
  padding: 0 2.5rem;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team:first-child, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team:first-child {
  border-left: 0;
  padding-left: 0;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team:last-child, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team:last-child {
  padding-right: 0;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .info, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .info {
  padding: 1.25rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.25rem;
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .info .icon, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .info .icon {
  position: relative;
  width: 6.25rem;
  height: 6.25rem;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .info .icon > img, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .info .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .info .name, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .info .name {
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .score-container, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .score-container {
  padding: 2.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.25rem;
  font-size: 1.125rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .score-container .score, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .score-container .score {
  font-size: 4rem;
  line-height: 4.0625rem;
  font-weight: 900;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .score-container .text, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .score-container .text {
  max-width: 7.8125rem;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .button-container, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .button-container {
  text-align: center;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .button-container button, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .button-container button {
  margin-left: 0;
  background-color: transparent;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .button-container button:hover, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .button-container button:hover {
  color: #000;
}
#app section[data-section-type=create_questions] .phase.questions .frame .grid .teams .team .button-container button:hover::after, #app section[data-section-type=create_questions] .phase.questionform .frame .grid .teams .team .button-container button:hover::after {
  background-color: #000;
}
#app section[data-section-type=create_questions] .phase.questions .words-container, #app section[data-section-type=create_questions] .phase.questionform .words-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 3.75rem 0;
}
#app section[data-section-type=create_questions] .phase.questions .words-container h3, #app section[data-section-type=create_questions] .phase.questionform .words-container h3 {
  color: #000;
  text-align: center;
  font-size: 1.875rem;
  line-height: 2.1875rem;
  font-weight: 800;
  margin-bottom: 4.375rem;
}
#app section[data-section-type=create_questions] .phase.questions .words-container .words, #app section[data-section-type=create_questions] .phase.questionform .words-container .words {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  display: flex;
  flex-wrap: wrap;
  width: 34.6875rem;
  gap: 0.625rem;
}
#app section[data-section-type=create_questions] .phase.questions .words-container .words .word, #app section[data-section-type=create_questions] .phase.questionform .words-container .words .word {
  background-color: #000;
  color: var(--color-highlight);
  font-size: 2.4375rem;
  font-weight: 800;
  text-align: center;
  min-width: 9.375rem;
  line-height: 3.125rem;
  padding: 0.9375rem 2.0625rem;
  border-radius: 2.5rem;
}
#app section[data-section-type=create_questions] .phase.questions .timer-container, #app section[data-section-type=create_questions] .phase.questionform .timer-container {
  width: 34.375rem;
  flex-shrink: 0;
  border-left: 0.125rem solid #144B5B;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
#app section[data-section-type=create_questions] .phase.questions .timer-container .round-timer, #app section[data-section-type=create_questions] .phase.questionform .timer-container .round-timer {
  position: relative;
  width: 23.75rem;
  height: 23.75rem;
}
#app section[data-section-type=create_questions] .phase.questions .timer-container .round-timer .progress, #app section[data-section-type=create_questions] .phase.questionform .timer-container .round-timer .progress {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: conic-gradient(var(--color-highlight-light) var(--progress, 0%), 0, transparent);
  border-radius: 50% 50%;
  -webkit-mask: radial-gradient(9.375rem, rgba(0, 0, 0, 0) 99%, #000);
          mask: radial-gradient(9.375rem, rgba(0, 0, 0, 0) 99%, #000);
}
#app section[data-section-type=create_questions] .phase.questions .timer-container .round-timer .time, #app section[data-section-type=create_questions] .phase.questionform .timer-container .round-timer .time {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translateY(-50%);
  font-size: 7.5rem;
  line-height: 7.5rem;
  font-weight: 900;
  font-style: italic;
}
#app section[data-section-type=create_questions] .phase.questions .timer-container .round-timer button.pause, #app section[data-section-type=create_questions] .phase.questionform .timer-container .round-timer button.pause {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-color: rgba(20, 75, 91, 0.3019607843);
  color: #144B5B;
  padding: 0.5rem 0.875rem;
  padding-left: 2.0625rem;
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 900;
  text-transform: uppercase;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, 5rem);
  border: none;
}
#app section[data-section-type=create_questions] .phase.questions .timer-container .round-timer button.pause::before, #app section[data-section-type=create_questions] .phase.questionform .timer-container .round-timer button.pause::before {
  content: "";
  position: absolute;
  background-color: #144B5B;
  top: 50%;
  left: 0.625rem;
  width: 1rem;
  height: 1rem;
  -webkit-mask: var(--pause-icon) no-repeat 50% 50%;
          mask: var(--pause-icon) no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
  transform: translateY(-50%);
}

#app section[data-section-type=wordcloud] .phase.questionform {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=wordcloud] .phase.questionform.--active {
  display: flex;
}
#app section[data-section-type=wordcloud] .phase.questionform .frame {
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 2.5rem 0;
  padding-bottom: 1.25rem;
  display: flex;
  flex-direction: column;
}
#app section[data-section-type=wordcloud] .phase.questionform .frame .round-info {
  margin: 0 2.5rem;
  flex-grow: 0;
  text-align: center;
  padding-top: 5.9375rem;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=wordcloud] .phase.questionform .frame .question-container {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  height: 100%;
  padding-top: 1.25rem;
  position: relative;
  z-index: 10;
}
#app section[data-section-type=wordcloud] .phase.questionform .frame .question-container .question {
  text-align: center;
  width: 14.375rem;
  flex-shrink: 0;
  color: #000;
  font-weight: 900;
  font-size: 1.875rem;
  line-height: 2.1875rem;
}
#app section[data-section-type=wordcloud] .phase.questionform .frame .question-container .question strong {
  font-size: 2.4375rem;
  line-height: 3.125rem;
}
#app section[data-section-type=wordcloud] .phase.questionform .frame .question-container .questions {
  height: 100%;
  display: flex;
  align-items: center;
  border-left: 0.125rem solid #144B5B;
}
#app section[data-section-type=wordcloud] .phase.questionform .character-container {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%) translateY(-3.125rem);
  width: 25rem;
  height: 37.5rem;
}
#app section[data-section-type=wordcloud] .phase.questionform .character-container .character-faces {
  --width: 35rem;
  --height: 68.75rem;
}
#app section[data-section-type=wordcloud] form.wordcloud {
  width: 53.75rem;
  margin-left: 2.5rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button {
  position: relative;
  color: #fff;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .word {
  text-transform: none;
  color: #fff;
  font-size: 1.6875rem;
  line-height: 1.75rem;
  font-weight: 800;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button button {
  background-color: #000;
  padding: 0.9375rem 1.25rem;
  border-radius: 1.8125rem;
  height: 3.625rem;
  transition: color 0.3s, background-color 0.3s;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog {
  display: none;
  white-space: nowrap;
  min-width: calc(100% + 0.125rem);
  margin-left: -0.0625rem;
  border-radius: 1.8125rem;
  color: #144B5B;
  background-color: #fff;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  z-index: 100;
  flex-direction: column;
  align-items: center;
  padding: 0.9375rem 1.25rem;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .word {
  color: #000;
  margin-bottom: 0.625rem;
  cursor: pointer;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .title {
  margin-bottom: 0.625rem;
  font-size: 1.125rem;
  line-height: 1.25rem;
  text-transform: uppercase;
  font-weight: 800;
  font-style: italic;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons {
  display: flex;
  gap: 0.625rem;
  justify-content: center;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button {
  position: relative;
  width: 3.4375rem;
  height: 3.4375rem;
  padding: 0;
  transition: color 0.3s, background-color 0.3s;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #fff;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 50% 50%;
          mask-position: 50% 50%;
  -webkit-mask-size: 1.875rem auto;
          mask-size: 1.875rem auto;
  transition: color 0.3s, background-color 0.3s;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button.--yes {
  background-color: var(--color-highlight);
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button.--yes::after {
  -webkit-mask-image: url("../svg/icon-correct.svg");
          mask-image: url("../svg/icon-correct.svg");
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button.--no {
  background-color: #144B5B;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button.--no::after {
  -webkit-mask-image: url("../svg/icon-incorrect.svg");
          mask-image: url("../svg/icon-incorrect.svg");
  -webkit-mask-size: 1.5625rem auto;
          mask-size: 1.5625rem auto;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button:hover {
  background-color: #000;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button:hover.--yes::after {
  background-color: var(--color-highlight);
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button .confirm-dialog .confirm-buttons button:hover.--no::after {
  background-color: #859aa2;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button.--open .confirm-dialog {
  display: flex;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button.--answered {
  pointer-events: none;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button.--correct {
  pointer-events: none;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button.--correct > button {
  background-color: #fff;
  color: #000;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button.--incorrect {
  pointer-events: none;
}
#app section[data-section-type=wordcloud] form.wordcloud .confirm-button.--incorrect > button {
  color: #000;
  background-color: #144B5B;
}
#app section[data-section-type=wordcloud] form.wordcloud[data-disabled=true] {
  pointer-events: none;
}
#app section[data-section-type=wordcloud] form.wordcloud[data-disabled=true] .confirm-button > button {
  background-color: #144B5B;
}
#app section[data-section-type=wordcloud] form.wordcloud[data-disabled=false] .confirm-button > button:not(.--correct):not(.--incorrect):hover {
  background-color: #fff;
  color: #000;
}

#app section[data-section-type=matrix] .phase[data-type=rounds] {
  color: #fff;
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=matrix] .phase[data-type=rounds].--active {
  display: flex;
}
#app section[data-section-type=matrix] .rounds {
  width: 100%;
  display: flex;
}
#app section[data-section-type=matrix] .rounds .round {
  width: 100%;
  display: none;
  position: relative;
}
#app section[data-section-type=matrix] .rounds .round .frame {
  width: 100%;
  border: 0.125rem solid #fff;
  padding: 2.5rem;
  padding-top: 0;
  display: flex;
  flex-direction: column;
}
#app section[data-section-type=matrix] .rounds .round .frame .round-info {
  flex-grow: 0;
  text-align: center;
  padding-top: 0.9375rem;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #fff;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices {
  display: flex;
  height: 100%;
  gap: 3.125rem;
  position: relative;
  z-index: 10;
  opacity: 0;
  transition: opacity 0.25s;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice {
  width: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 3.125rem 5.625rem;
  position: relative;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice:nth-child(1) {
  transform: translateX(-1.5625rem);
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice:nth-child(2) {
  transform: translateX(1.5625rem);
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice button {
  width: 100%;
  padding: 0;
  position: relative;
  color: var(--team-color);
  height: auto;
  background: transparent;
  text-transform: none;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice button span {
  position: relative;
  font-size: 1.875rem;
  line-height: 2.1875rem;
  font-weight: 800;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone;
  background-color: #000;
  color: var(--team-color);
  padding: 0.8125rem 2.1875rem;
  border-radius: 1.875rem;
  transition: color 0.25s, background-color 0.25s;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice button span em {
  font-style: normal;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice button.--quote span::before {
  content: "";
  position: absolute;
  top: -0.5rem;
  left: -0.9375rem;
  width: 2.5rem;
  height: 1.875rem;
  background-color: var(--team-color);
  -webkit-mask: url("../svg/icon-quote.svg") no-repeat 50% 50%;
          mask: url("../svg/icon-quote.svg") no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
  transition: color 0.25s, background-color 0.25s;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice button.--long span {
  font-size: 1.6875rem;
  line-height: 1.875rem;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice button:hover span {
  background-color: var(--team-color);
  color: #000;
}
#app section[data-section-type=matrix] .rounds .round .frame .choices .choice button:hover span::before {
  background-color: #000;
}
#app section[data-section-type=matrix] .rounds .round.--active {
  display: flex;
}
#app section[data-section-type=matrix] .rounds .round.--animate-in .frame .choices {
  opacity: 1;
}
#app section[data-section-type=matrix] .rounds .round .character-container {
  position: absolute;
  left: 50%;
  margin-left: -12.5rem;
  top: 6.25rem;
  width: 31.25rem;
  height: 67.9375rem;
}
#app section[data-section-type=matrix] .rounds .round .character-container .character-faces {
  --width: 25rem;
  --height: 56.25rem;
}
#app section[data-section-type=matrix] .rounds .round .extra-texts {
  pointer-events: none;
  opacity: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: rgba(255, 255, 255, 0.4);
  box-shadow: 0 0 0.75rem rgba(20, 75, 91, 0.2);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  border-radius: 0.375rem;
  padding: 0.9375rem;
  z-index: 100;
}
#app section[data-section-type=matrix] .rounds .round .extra-texts .background {
  width: 48.125rem;
  background-color: rgba(255, 255, 255, 0.7);
  border-radius: 0.375rem;
  padding: 1.25rem 2.5rem;
  display: flex;
  text-align: center;
  justify-content: center;
  align-items: center;
  color: #144B5B;
  font-size: 1.9375rem;
  line-height: 2.375rem;
  font-weight: 200;
}
#app section[data-section-type=matrix] .rounds .round.--extra-texts-playing .frame > div {
  transition: opacity 0.25s;
  opacity: 0 !important;
}
#app section[data-section-type=matrix] .rounds .round.--extra-texts-playing .extra-texts {
  transition: opacity 0.25s 0.25s;
  opacity: 1;
  pointer-events: auto;
}
#app section[data-section-type=matrix] .rounds .round.escalation .frame {
  padding: 1.75rem;
  align-items: center;
  justify-content: center;
}
#app section[data-section-type=matrix] .rounds .round.escalation .frame .container {
  position: relative;
  overflow: hidden;
  border-radius: 0.375rem;
  background-color: #144B5B;
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  flex-shrink: 0;
}
#app section[data-section-type=matrix] .rounds .round.escalation .frame .container video {
  background-color: #000;
  display: block;
  width: 62.25rem;
  height: 35rem;
}
#app section[data-section-type=matrix] .rounds .round.escalation .frame .container .after-complete {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  background-color: rgba(255, 255, 255, 0.8);
}
#app section[data-section-type=matrix] .rounds .round.escalation .frame .container .after-complete .buttons {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=matrix] .rounds .round.escalation .frame .container .after-complete.--visible {
  opacity: 1;
  pointer-events: auto;
}
#app section[data-section-type=matrix] .rounds:has(.--extra-texts-playing) .character-container {
  transition: none;
  opacity: 0;
}

#app section[data-section-type=team-select] .phase {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=team-select] .phase.--active {
  display: flex;
}
#app section[data-section-type=team-select] .phase .frame {
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 2.5rem 0;
  padding-bottom: 0;
  display: flex;
  flex-direction: column;
  z-index: 1;
}
#app section[data-section-type=team-select] .phase .frame .buttons {
  position: relative;
  margin: 0;
  display: flex;
  height: 10.625rem;
  justify-content: center;
  align-items: center;
  text-align: center;
  overflow: hidden;
  transition: height 0.5s;
  will-change: height;
}
#app section[data-section-type=team-select] .phase .frame .buttons button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#app section[data-section-type=team-select] .phase .frame .buttons button[data-action=complete] {
  margin-left: 1.25rem;
}
#app section[data-section-type=team-select] .phase .frame .buttons .fade-out {
  pointer-events: none !important;
  opacity: 0;
}
#app section[data-section-type=team-select] .phase .teams {
  height: 100%;
  margin-top: 6.25rem;
  margin-bottom: 1.25rem;
  display: flex;
  align-items: stretch;
}
#app section[data-section-type=team-select] .phase .teams > .team {
  position: relative;
  width: 100%;
  flex-basis: 1;
  border-left: 0.125rem solid #144B5B;
  display: flex;
  align-items: stretch;
  transition: width 0.5s;
  will-change: width;
  overflow: hidden;
}
#app section[data-section-type=team-select] .phase .teams > .team:first-child {
  border: none;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-thumbnail {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 5;
  transition: opacity 0.5s;
  opacity: 1;
  margin: 0 5rem;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-thumbnail .container {
  text-align: center;
  width: 100%;
  max-width: 12.5rem;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: opacity 0.5s;
  opacity: 0;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-thumbnail .container.placeholder {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-thumbnail .container .icon {
  width: 100%;
  min-width: 12.5rem;
  position: relative;
  overflow: hidden;
  margin-bottom: 1.25rem;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-thumbnail .container .icon > img {
  position: relative;
  display: block;
  width: 100%;
  height: auto;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-thumbnail .container .name {
  font-weight: 800;
  font-size: 1.125rem;
  font-style: italic;
  text-transform: uppercase;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-thumbnail .container.placeholder .name {
  opacity: 0.5;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info {
  display: flex;
  align-items: stretch;
  border-top: 0.125rem solid #144B5B;
  border-bottom: 0.125rem solid #144B5B;
  transition: opacity 0.5s;
  opacity: 0;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 2.5rem;
  right: 2.5rem;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container {
  min-height: 26.875rem;
  width: 19.125rem;
  flex-shrink: 0;
  position: relative;
  display: flex;
  align-items: stretch;
  padding: 1.25rem;
  padding-bottom: 1.875rem;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 3.125rem;
  --width: 12.5rem;
  --height: 27.25rem;
  width: var(--width);
  height: var(--height);
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container canvas.carousel {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--width);
  height: var(--height);
  z-index: 2;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .character {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--width);
  height: var(--height);
  z-index: 3;
  opacity: 0;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .character .character-frame {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--width);
  height: var(--height);
  opacity: 0.01;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .character .character-frame > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .character[data-animator-frame="1"] .frame-1 {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .character[data-animator-frame="2"] .frame-2 {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .character[data-animator-frame="3"] .frame-3 {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .character[data-animator-frame="4"] .frame-4 {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .character-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--width);
  height: var(--height);
  background-color: transparent;
  -webkit-mask-image: var(--mask-image);
          mask-image: var(--mask-image);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 0 0;
          mask-position: 0 0;
  -webkit-mask-size: 100% auto;
          mask-size: 100% auto;
  z-index: 4;
  opacity: 1;
  transition: opacity 1s;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container canvas.splash {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 18.75rem;
  height: 18.75rem;
  z-index: 2;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container .shadow {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 12.5rem;
  height: 2.3125rem;
  border-radius: 50% 50%;
  background-color: var(--color-highlight-light);
  z-index: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container.--selected canvas.carousel {
  opacity: 0;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container.--selected .character {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container.--selected .character-mask {
  background-color: #fff;
  opacity: 0;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .character-container .carousel-container.--selected .shadow {
  background-color: var(--color);
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info {
  width: 31.25rem;
  margin: 1.25rem 0;
  padding-left: 1.25rem;
  padding-top: 0.625rem;
  border-left: 0.125rem solid #144B5B;
  font-size: 1.125rem;
  text-transform: uppercase;
  font-style: italic;
  font-weight: 500;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .placeholder-xxx {
  position: relative;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .placeholder-xxx span {
  opacity: 0;
  transition: opacity 0.5s;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .placeholder-xxx::before {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  content: "";
  width: 5rem;
  height: 0.625rem;
  background: url("../svg/placeholder-small.svg") no-repeat 0 50%;
  background-size: auto 100%;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .team {
  font-size: 0.75rem;
  font-weight: 800;
  margin-bottom: 0.3125rem;
  margin-left: 1.25rem;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .name {
  margin-left: 1.25rem;
  font-size: 2.8125rem;
  font-weight: 900;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .name.placeholder-xxx::before {
  width: 7.5rem;
  height: 1.0625rem;
  background: url("../svg/placeholder-large.svg") no-repeat 0 50%;
  background-size: auto 100%;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .details-container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.875rem;
  width: 100%;
  margin-top: 0.9375rem;
  margin-bottom: 1.25rem;
  padding: 1.25rem 0;
  border-top: 0.125rem solid #144B5B;
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .details-container .level-container {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .details-container .level-container .level {
  font-weight: 800;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .details-container .level-container .level.placeholder-xxx::before {
  left: 50%;
  transform: translate(-50%, -50%);
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .details-container .icons {
  border-left: 0.125rem solid #144B5B;
  display: flex;
  align-items: stretch;
  gap: 1.875rem;
  padding-left: 1.875rem;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .details-container .icons .icon {
  width: 3.75rem;
  height: 3.75rem;
  position: relative;
  border-radius: 1.875rem;
  overflow: hidden;
  background-color: var(--color-highlight-light);
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .details-container .icons .icon::before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  content: "?";
  color: var(--color-highlight);
  font-weight: 900;
  font-size: 2.8125rem;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .details-container .icons .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  opacity: 0;
  transition: opacity 0.5s;
  z-index: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .info-container {
  margin-left: 1.25rem;
  margin-bottom: 1.25rem;
  display: flex;
  justify-content: flex-start;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .info-container .title {
  margin-right: 0.5rem;
}
#app section[data-section-type=team-select] .phase .teams > .team .team-info .info .info-container span {
  font-weight: 800;
}
#app section[data-section-type=team-select] .phase .teams > .team.--info-visible .team-thumbnail {
  opacity: 0;
}
#app section[data-section-type=team-select] .phase .teams > .team.--info-visible .team-info {
  opacity: 1;
  transition-delay: 1s;
}
#app section[data-section-type=team-select] .phase .teams > .team.--reveal-info .team-info .placeholder-xxx span {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team.--reveal-info .team-info .placeholder-xxx::before {
  opacity: 0;
}
#app section[data-section-type=team-select] .phase .teams > .team.--reveal-info .team-info .details-container .icons .icon > img {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team.--complete .team-thumbnail {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team.--complete .team-thumbnail .container.placeholder {
  opacity: 0;
}
#app section[data-section-type=team-select] .phase .teams > .team.--complete .team-thumbnail .container.team {
  opacity: 1;
}
#app section[data-section-type=team-select] .phase .teams > .team.--complete .team-info {
  transition-delay: 0s;
  opacity: 0;
}
#app section[data-section-type=team-select] .phase.--animating .buttons {
  height: 0;
}
#app section[data-section-type=team-select] .phase.--animating .teams > .team {
  transition: width 0.5s 0.5s;
}
#app section[data-section-type=team-select] .phase.--animating .teams > .team:not(.--active) {
  width: 22.5rem;
}
#app section[data-section-type=team-select] .phase.--animating .teams > .team.--active {
  width: calc(100% - 22.5rem);
}
#app section[data-section-type=team-select] .phase[data-team-count="3"] .teams > .team .team-thumbnail {
  margin: 0 2.5rem;
}
#app section[data-section-type=team-select] .phase[data-team-count="3"] .teams > .team .team-thumbnail .container {
  max-width: 12.5rem;
}
#app section[data-section-type=team-select] .phase[data-team-count="3"] .teams > .team .team-thumbnail .container .icon {
  min-width: 7.5rem;
}
#app section[data-section-type=team-select] .phase[data-team-count="3"].--animating .teams > .team:not(.--active) {
  width: 12.5rem;
}
#app section[data-section-type=team-select] .phase[data-team-count="3"].--animating .teams > .team.--active {
  width: calc(100% - 12.5rem - 12.5rem);
}

#app section[data-section-type=lines] .phase[data-type=rounds] {
  color: #fff;
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=lines] .phase[data-type=rounds].--active {
  display: flex;
}
#app section[data-section-type=lines] .rounds {
  width: 100%;
  display: flex;
}
#app section[data-section-type=lines] .rounds .round {
  width: 100%;
  display: none;
  position: relative;
}
#app section[data-section-type=lines] .rounds .round.--active {
  display: flex;
}
#app section[data-section-type=lines] .rounds .round .frame {
  position: relative;
  width: 100%;
  padding: 2.5rem;
  padding-bottom: 1.25rem;
  display: flex;
  flex-direction: column;
}
#app section[data-section-type=lines] .rounds .round .frame::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  border: 0.125rem solid #fff;
  pointer-events: none;
}
#app section[data-section-type=lines] .rounds .round .frame .grid {
  pointer-events: none;
  position: absolute;
  top: 11.875rem;
  left: 1.25rem;
  right: 1.25rem;
  bottom: 1.25rem;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}
#app section[data-section-type=lines] .rounds .round .frame .grid > div {
  width: 33.33%;
  border-left: 0.125rem solid #fff;
  position: relative;
}
#app section[data-section-type=lines] .rounds .round .frame .grid > div:first-child {
  border: none;
}
#app section[data-section-type=lines] .rounds .round .frame .grid > div::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 1.25rem;
  right: 1.25rem;
  border-top: 0.125rem solid #fff;
}
#app section[data-section-type=lines] .rounds .round .frame .round-info {
  flex-grow: 0;
  text-align: center;
  padding-top: 5.9375rem;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #fff;
}
#app section[data-section-type=lines] .rounds .round .frame .choices {
  z-index: 10;
  display: flex;
  height: 100%;
  flex-wrap: wrap;
  position: relative;
  margin: 0 -1.25rem;
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice {
  flex-shrink: 0;
  width: calc((100% - 5rem) * 0.33);
  height: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1.25rem 2rem;
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice button {
  width: 90%;
  padding: 0;
  position: relative;
  color: var(--team-color);
  height: auto;
  background: transparent;
  text-transform: none;
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice button span {
  position: relative;
  font-size: 1.6875rem;
  line-height: 2rem;
  font-weight: 800;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone;
  background-color: #000;
  color: var(--team-color);
  transition: color 0.25s, background-color 0.25s;
  padding: 0.8125rem 1.875rem;
  border-radius: 1.875rem;
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice button span em {
  font-style: normal;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice button:hover span {
  color: #000;
  background-color: var(--team-color);
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice button.--long {
  width: 100%;
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice button.--long span {
  font-size: 1.5rem;
  line-height: 1.75rem;
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice button.--very-long {
  width: 100%;
}
#app section[data-section-type=lines] .rounds .round .frame .choices .choice button.--very-long span {
  font-size: 1.25rem;
  line-height: 1.5625rem;
}
#app section[data-section-type=lines] .rounds .round[data-team=team-1] .frame .grid {
  left: 6.25rem;
  right: 1.25rem;
}
#app section[data-section-type=lines] .rounds .round[data-team=team-1] .frame .choices {
  left: 5.3125rem;
}
#app section[data-section-type=lines] .rounds .round[data-team=team-2] .frame .grid {
  left: 1.25rem;
  right: 6.25rem;
}
#app section[data-section-type=lines] .rounds .round[data-team=team-2] .frame .choices {
  left: -5.3125rem;
  justify-content: flex-end;
}
#app section[data-section-type=lines] .rounds .round.continue .frame {
  z-index: 1;
  justify-content: center;
  align-items: center;
}
#app section[data-section-type=lines] .rounds .round.end-video {
  position: static;
}
#app section[data-section-type=lines] .rounds .round.end-video.--animate-in .video-container {
  opacity: 1;
}
#app section[data-section-type=lines] .rounds .round.end-video.--animate-in .video-container .container {
  transform: translateY(0);
}
#app section[data-section-type=lines] .rounds .round.end-video.--animate-out {
  transition: opacity 0.25s;
}
#app section[data-section-type=lines] .rounds .round.end-video.--animate-out .video-container {
  opacity: 0;
}
#app section[data-section-type=lines] .rounds .round.end-video.--animate-out .video-container .container {
  transform: translateY(-2.5rem);
}
#app section[data-section-type=lines] .video-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(20, 75, 91, 0.6980392157);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  z-index: 800;
  display: flex;
  opacity: 0;
  justify-content: center;
  align-items: center;
  transition: opacity 0.25s;
}
#app section[data-section-type=lines] .video-container .container {
  position: relative;
  overflow: hidden;
  border-radius: 0.375rem;
  background-color: #144B5B;
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  transform: translateY(2.5rem);
  transition: transform 0.25s;
}
#app section[data-section-type=lines] .video-container .container video {
  display: block;
  background-color: #000;
  height: 41.25rem;
  width: 73.3125rem;
}
#app section[data-section-type=lines] .video-container .container .after-complete {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  background-color: rgba(255, 255, 255, 0.8);
}
#app section[data-section-type=lines] .video-container .container .after-complete .buttons {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=lines] .video-container .container .after-complete.--visible {
  opacity: 1;
  pointer-events: auto;
}
#app section[data-section-type=lines] .characters {
  pointer-events: none;
  z-index: 2;
}
#app section[data-section-type=lines] .characters .character-scaler {
  position: absolute;
  top: 50%;
  margin-top: -13.75rem;
  width: 37.5rem;
  height: 42.5rem;
  transition: transform 0.5s;
  z-index: 1;
}
#app section[data-section-type=lines] .characters .character-scaler.left {
  left: -3.125rem;
  transform: scale(0.75) translateX(18.75rem) translateY(1.875rem);
  transform-origin: -10% 130%;
}
#app section[data-section-type=lines] .characters .character-scaler.right {
  bottom: -6.25rem;
  right: -17.5rem;
  transform: scale(0.75) translateX(-18.75rem) translateY(1.875rem);
  transform-origin: 110% 140%;
}
#app section[data-section-type=lines] .characters .character-scaler .character-container {
  position: absolute;
  left: 50%;
  margin-left: -18.75rem;
  top: 0;
  width: 31.25rem;
  height: 69rem;
}
#app section[data-section-type=lines] .characters .character-scaler .character-container .character-faces {
  --width: 31.25rem;
  --height: 69rem;
}
#app section[data-section-type=lines] .characters .character-content {
  position: absolute;
  top: 12.5rem;
  left: 50%;
  transform: translateX(-50%);
}
#app section[data-section-type=lines][data-team=team-1] .characters .character-scaler.left {
  transform: scale(1);
}
#app section[data-section-type=lines][data-team=team-2] .characters .character-scaler.right {
  transform: scale(1);
}
#app section[data-section-type=lines].teams-3 .rounds .round .frame .grid {
  left: 1.25rem;
  right: 1.25rem;
}
#app section[data-section-type=lines].teams-3 .rounds .round .frame .grid > div {
  flex-grow: 1;
}
#app section[data-section-type=lines].teams-3 .rounds .round .frame .grid > div:nth-child(2) {
  flex-grow: 0;
  width: 18.5rem;
}
#app section[data-section-type=lines].teams-3 .rounds .round .frame .choices {
  left: 0 !important;
  margin: 0;
  justify-content: space-between;
}
#app section[data-section-type=lines].teams-3 .rounds .round .frame .choices .choice {
  width: 27.3125rem;
  padding: 1.25rem 2.1875rem;
}
#app section[data-section-type=lines].teams-3 .rounds .round .frame .choices .choice:last-child {
  width: 18.375rem !important;
  order: -1;
}
#app section[data-section-type=lines].teams-3 .rounds .round .frame .choices .choice:first-child {
  order: -2;
}
#app section[data-section-type=lines].teams-3 .rounds .round .frame .choices .choice button span {
  font-size: 1.375rem !important;
  line-height: 1.5rem !important;
}
#app section[data-section-type=lines].teams-3 .characters {
  pointer-events: none;
  z-index: 2;
}
#app section[data-section-type=lines].teams-3 .characters .character-scaler {
  position: absolute;
  left: 50%;
  top: 50%;
  margin-top: -3.75rem;
  width: 37.5rem;
  height: 42.5rem;
  margin-left: -13.75rem;
  transition: transform 0.25s, opacity 0.25s;
  transition-delay: 0s;
  z-index: 1;
  opacity: 0;
  transform: translateY(1.875rem);
}
#app section[data-section-type=lines].teams-3 .characters .character-scaler .character-container {
  position: absolute;
  left: 50%;
  margin-left: -18.75rem;
  top: 0;
  width: 35rem;
  height: 69rem;
}
#app section[data-section-type=lines].teams-3 .characters .character-scaler .character-container .character-faces {
  --width: 35rem;
  --height: 69rem;
}
#app section[data-section-type=lines].teams-3[data-team=team-1] .characters .character-scaler[data-team=team-1] {
  transition-delay: 0s;
  transform: translate(0);
  opacity: 1;
}
#app section[data-section-type=lines].teams-3[data-team=team-2] .characters .character-scaler[data-team=team-2] {
  transition-delay: 0s;
  transform: translate(0);
  opacity: 1;
}
#app section[data-section-type=lines].teams-3[data-team=team-3] .characters .character-scaler[data-team=team-3] {
  transition-delay: 0.25s;
  transform: translate(0);
  opacity: 1;
}

#app section[data-section-type=end] {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 50;
  display: flex;
  justify-content: center;
  align-items: center;
}
#app section[data-section-type=end].--active {
  display: flex;
}
#app section[data-section-type=end] .container {
  position: absolute;
  top: 0;
  left: 6.875rem;
  right: 0;
  bottom: 0;
  padding: 2.5rem;
  padding-top: 3.5rem;
  display: flex;
  align-items: stretch;
  opacity: 0;
  transition: opacity 0.5s 0.5s;
}
#app section[data-section-type=end] .container .frame {
  position: relative;
  width: 100%;
  border: 0.125rem solid #144B5B;
  border-top: 0;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  padding-bottom: 7.5rem;
}
#app section[data-section-type=end] .container .frame .heading {
  width: 100%;
  position: relative;
  text-align: center;
  margin-bottom: 1.875rem;
}
#app section[data-section-type=end] .container .frame .heading h3 {
  display: flex;
  margin: 0 auto;
  font-size: 1.875rem;
  line-height: 2rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
}
#app section[data-section-type=end] .container .frame .heading h3::before, #app section[data-section-type=end] .container .frame .heading h3::after {
  content: "";
  display: block;
  width: 100%;
  border-top: 0.125rem solid #144B5B;
}
#app section[data-section-type=end] .container .frame .heading h3 span {
  margin: 0 2.5rem;
  display: block;
  white-space: nowrap;
  flex-shrink: 0;
  position: relative;
  transform: translateY(-50%);
}
#app section[data-section-type=end] .container .frame .heading h3 span::before, #app section[data-section-type=end] .container .frame .heading h3 span::after {
  content: "";
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  background: url("../svg/icon-close.svg") no-repeat 50% 50%;
  background-size: contain;
}
#app section[data-section-type=end] .container .frame .heading h3 span::before {
  margin-right: 1.25rem;
}
#app section[data-section-type=end] .container .frame .heading h3 span::after {
  margin-left: 1.25rem;
}
#app section[data-section-type=end] .container .frame a.button {
  position: absolute;
  bottom: 2.5rem;
  right: 2.5rem;
  z-index: 10;
}
#app section[data-section-type=end] .container .frame .graphics {
  pointer-events: none;
  position: absolute;
  transform: translate(50%, 50%);
  right: 6.25rem;
  bottom: 6.25rem;
}
#app section[data-section-type=end] .container .frame .graphics .graphic {
  width: 41.875rem;
  height: 41.875rem;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#app section[data-section-type=end] .container .frame .graphics .graphic .image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#app section[data-section-type=end] .container .frame .graphics .graphic .image > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#app section[data-section-type=end] .container .frame .final-results {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
}
#app section[data-section-type=end] .container .frame .final-results .team-name {
  text-transform: uppercase;
  font-style: italic;
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
  margin-bottom: 1.875rem;
}
#app section[data-section-type=end] .container .frame .final-results .results {
  position: relative;
  width: 12.5rem;
}
#app section[data-section-type=end] .container .frame .final-results .results .final-results-content {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-direction: column;
  gap: 2.5rem;
  transition: transform 1s;
}
#app section[data-section-type=end] .container .frame .final-results .results .final-results-content .team {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1.25rem;
}
#app section[data-section-type=end] .container .frame .final-results .results .final-results-content .team .icon {
  position: relative;
  width: 5rem;
  height: 5rem;
}
#app section[data-section-type=end] .container .frame .final-results .results .final-results-content .team .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#app section[data-section-type=end] .container .frame .final-results .results .final-results-content .team .score-container {
  text-align: left;
}
#app section[data-section-type=end] .container .frame .final-results .results .final-results-content .team .score-container .name {
  margin-bottom: 0.625rem;
  font-size: 1.125rem;
  line-height: 1.25rem;
  font-weight: 500;
  font-style: italic;
  text-transform: uppercase;
}
#app section[data-section-type=end] .container .frame .final-results .results .final-results-content .team .score-container .score {
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
  text-transform: uppercase;
  font-style: italic;
}
#app section[data-section-type=end] .container .frame .final-results .results .combined-total-score {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity 1s 0.25s, color 0.25s;
}
#app section[data-section-type=end] .container .frame .final-results .results .combined-total-score .final-score {
  width: 21.25rem;
  font-size: 7.5rem;
  line-height: 7.5rem;
  text-transform: uppercase;
  font-style: italic;
  font-weight: 900;
  text-align: center;
}
#app section[data-section-type=end] .container .frame .final-results .results .combined-total-score > canvas {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -60%);
  width: 21.25rem;
  height: 21.25rem;
}
#app section[data-section-type=end] .container .frame .final-results .results .combined-total-score.--highlight {
  color: var(--color-highlight);
}
#app section[data-section-type=end] .container .frame .final-results .results.--show-total-score .final-results-content {
  transform: translateX(-23.125rem);
}
#app section[data-section-type=end] .container .frame .final-results .results.--show-total-score .combined-total-score {
  opacity: 1;
}
#app section[data-section-type=end].--animate-in .container {
  opacity: 1;
}

@keyframes tarina1-spin-1 {
  0% {
    transform: rotate(130deg);
  }
  100% {
    transform: rotate(-230deg);
  }
}
@keyframes tarina1-spin-2 {
  0% {
    transform: rotate(90deg);
  }
  100% {
    transform: rotate(-270deg);
  }
}
@keyframes tarina3-wobble {
  0% {
    transform: rotate(10deg);
  }
  50% {
    transform: rotate(25deg);
  }
  100% {
    transform: rotate(10deg);
  }
}
#app[data-story=koruton-kaveruus] section[data-section-type=end] .container .frame .graphics {
  right: 6.25rem;
  bottom: 7.5rem;
}
#app[data-story=koruton-kaveruus] section[data-section-type=end] .container .frame .graphics .graphic {
  width: 38.75rem;
  height: 38.75rem;
}
#app[data-story=koruton-kaveruus] section[data-section-type=end] .container .frame .graphics .graphic .image {
  transform-origin: 52% 45%;
}
#app[data-story=koruton-kaveruus] section[data-section-type=end] .container .frame .graphics .graphic.--bottom {
  transform: translate(-50%, -50%) translateY(-12.5rem) translateX(5rem);
}
#app[data-story=koruton-kaveruus] section[data-section-type=end] .container .frame .graphics .graphic.--bottom .image {
  animation: tarina1-spin-1 150s linear infinite;
}
#app[data-story=koruton-kaveruus] section[data-section-type=end] .container .frame .graphics .graphic.--top .image {
  animation: tarina1-spin-2 160s linear infinite;
}

#app[data-story=suhdeselkkauksia] section[data-section-type=end] .container .frame .final-results .results .combined-total-score.--highlight {
  color: var(--color-highlight);
}
#app[data-story=suhdeselkkauksia] section[data-section-type=end] .container .frame .graphics {
  right: 7.5rem;
  bottom: 6.25rem;
}
#app[data-story=suhdeselkkauksia] section[data-section-type=end] .container .frame .graphics .graphic {
  width: 31.25rem;
  height: 31.25rem;
}
#app[data-story=suhdeselkkauksia] section[data-section-type=end] .container .frame .graphics .graphic .image {
  transform-origin: 50% 50%;
}
#app[data-story=suhdeselkkauksia] section[data-section-type=end] .container .frame .graphics .graphic.--top {
  transform: translate(-50%, -50%) translateY(-12.5rem) translateX(5rem);
}
#app[data-story=suhdeselkkauksia] section[data-section-type=end] .container .frame .graphics .graphic.--top .image {
  animation: tarina1-spin-1 150s linear infinite;
}
#app[data-story=suhdeselkkauksia] section[data-section-type=end] .container .frame .graphics .graphic.--bottom .image {
  animation: tarina1-spin-2 160s linear infinite;
}

#app[data-story=kasvukipuja] section[data-section-type=end] .container .frame .final-results .results .combined-total-score.--highlight {
  color: var(--color-highlight);
}
#app[data-story=kasvukipuja] section[data-section-type=end] .container .frame .graphics {
  right: 7.5rem;
  bottom: 6.25rem;
}
#app[data-story=kasvukipuja] section[data-section-type=end] .container .frame .graphics .graphic {
  width: 43.75rem;
  height: 43.75rem;
}
#app[data-story=kasvukipuja] section[data-section-type=end] .container .frame .graphics .graphic .image {
  transform-origin: 50% 50%;
}
#app[data-story=kasvukipuja] section[data-section-type=end] .container .frame .graphics .graphic.--top {
  transform: translate(-50%, -50%) translateY(-7.5rem) translateX(3.125rem);
}
#app[data-story=kasvukipuja] section[data-section-type=end] .container .frame .graphics .graphic.--top .image {
  animation: tarina3-wobble 50s ease infinite;
}

@keyframes animate-slot-in {
  0% {
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
section[data-section-type=drag-order] .phase.questionform {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
section[data-section-type=drag-order] .phase.questionform.--active {
  display: flex;
}
section[data-section-type=drag-order] .phase.questionform .frame {
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 2.5rem;
  padding-top: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 37.5rem;
  padding-top: 10.3125rem;
}
section[data-section-type=drag-order] .phase.questionform .frame .round-info {
  flex-grow: 0;
  text-align: center;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #144B5B;
  display: none;
}
section[data-section-type=drag-order] .phase.questionform .frame .characters {
  pointer-events: none;
  width: 31.25rem;
  height: 37.5rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateY(-3.125rem);
  right: -3.75rem;
}
section[data-section-type=drag-order] .phase.questionform .frame .characters .character-container {
  position: absolute;
  top: 0;
  left: 0;
}
section[data-section-type=drag-order] .phase.questionform .frame .characters .character-container .character-faces {
  --width: 37.5rem;
  --height: 75rem;
}
section[data-section-type=drag-order] form.drag-order {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  padding: 2.1875rem 2.5rem;
}
section[data-section-type=drag-order] form.drag-order fieldset {
  border: 0;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables {
  position: relative;
  margin-top: 2.1875rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .picture {
  border-radius: 1.375rem;
  position: absolute;
  top: 0;
  left: 0;
  width: 23.4375rem;
  height: 28.125rem;
  box-shadow: 1.125rem 1.125rem 0 #000;
  z-index: 1;
  cursor: move;
  cursor: grab;
  cursor: -moz-grab;
  cursor: -webkit-grab;
  transform: scale(0.2667) translateY(0) translateZ(0);
  transition: box-shadow 0.25s, border-radius 0.25s, transform 0.25s, z-index 0s 0.25s;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .picture:active {
  cursor: grabbing;
  cursor: -moz-grabbing;
  cursor: -webkit-grabbing;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .picture > div {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 1.375rem;
  transition: border-radius 0.25s;
  background: #666 var(--image) no-repeat 50% 50%;
  background-size: cover;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .picture > img {
  border-radius: 1.375rem;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: border-radius 0.25s;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .picture.--being-dragged {
  z-index: 215;
  border-radius: 0.875rem !important;
  box-shadow: 0.75rem 0.75rem 0 #000 !important;
  transform: scale(0.421) rotate(-5deg) translateZ(0) !important;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .picture.--being-dragged > img {
  border-radius: 0.875rem !important;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .picture.--being-dragged > div {
  border-radius: 0.875rem !important;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures {
  display: flex;
  justify-content: center;
  gap: 1.5625rem;
  position: relative;
  z-index: 220;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot {
  position: relative;
  width: 6.25rem;
  height: 7.5rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(255, 255, 255, 0.4);
  z-index: -200;
  border-radius: 0.375rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot:nth-child(2), section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot:nth-child(4), section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot:nth-child(6) {
  margin-top: 1.25rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot .picture {
  top: -10.375rem;
  left: -8.6875rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot .picture:hover {
  z-index: 2;
  border-radius: 0.375rem;
  box-shadow: 0.3125rem 0.3125rem 0 #000;
  transform: scale(1) translateY(0) translateZ(0);
  transition: box-shadow 0.25s, border-radius 0.25s, transform 0.25s, z-index 0s 0s;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot .picture:hover > img {
  border-radius: 0.375rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot .picture:hover > div {
  border-radius: 0.375rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .pictures .picture-slot .picture.--topmost {
  z-index: 3;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots {
  display: flex;
  justify-content: center;
  gap: 1.5625rem;
  position: relative;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot {
  border-radius: 0.375rem;
  width: 9.875rem;
  height: 11.875rem;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot::before {
  pointer-events: none;
  border-radius: 0.375rem;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #fff;
  -webkit-mask: url("../img/frame.png") no-repeat 0 0;
          mask: url("../img/frame.png") no-repeat 0 0;
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  transition: background-color 0.25s;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot::after {
  pointer-events: none;
  border-radius: 0.375rem;
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  content: attr(data-index);
  font-size: 4rem;
  line-height: 4rem;
  font-style: italic;
  font-weight: 900;
  transition: background-color 0.25s, color 0.25s;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot.--has-text::after {
  display: none;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot.--has-text .text {
  pointer-events: none;
  padding: 0.5625rem;
  text-align: center;
  color: #fff;
  font-size: 1.125rem;
  line-height: 1.25rem;
  font-weight: 800;
  text-transform: uppercase;
  font-style: italic;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot .picture {
  top: -8.125rem;
  left: -6.8125rem;
  border-radius: 0.875rem;
  box-shadow: 0.75rem 0.75rem 0 #000;
  transform: scale(0.423);
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot .picture > img {
  border-radius: 0.875rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot .picture > div {
  border-radius: 0.875rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot .picture.--correct {
  pointer-events: none;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot .picture.--correct::before {
  content: "";
  z-index: 1;
  border-radius: 0.875rem;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #55D48F;
  animation-name: animate-slot-in;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot .picture.--correct::after {
  content: "";
  z-index: 1;
  border-radius: 0.875rem;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #fff;
  background: url("../svg/icon-correct-color.svg") no-repeat 50% 50%;
  background-size: 8.125rem auto;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot .picture.--incorrect::before {
  content: "";
  z-index: 1;
  border-radius: 0.875rem;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #144B5B;
  animation-name: animate-slot-in;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot .picture.--incorrect::after {
  content: "";
  z-index: 1;
  border-radius: 0.875rem;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #fff;
  background: url("../svg/icon-incorrect-color.svg") no-repeat 50% 50%;
  background-size: 8.125rem auto;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot.--dragging-over::before {
  background-color: #55D48F;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot.--dragging-over::after {
  color: #55D48F;
  background-color: rgba(85, 212, 143, 0.4);
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot:not(.--prevent-hover) .picture:not(.--correct):hover {
  z-index: 250;
  border-radius: 0.375rem;
  box-shadow: 0.3125rem 0.3125rem 0 #000;
  transform: scale(1) translateY(0) translateZ(0);
  transition: box-shadow 0.25s, border-radius 0.25s, transform 0.25s, z-index 0s 0s;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot:not(.--prevent-hover) .picture:not(.--correct):hover > img {
  border-radius: 0.375rem;
}
section[data-section-type=drag-order] form.drag-order fieldset.draggables .slots .slot:not(.--prevent-hover) .picture:not(.--correct):hover > div {
  border-radius: 0.375rem;
}
section[data-section-type=drag-order] form.drag-order.--complete .rounds {
  transition: opacity 0.25s;
  opacity: 0;
}
section[data-section-type=drag-order] form.drag-order.--complete fieldset.pictures-container {
  transition: opacity 0.25s;
  opacity: 0;
}
section[data-section-type=drag-order] form.drag-order.--complete fieldset.slots-container {
  transition: transform 0.5s 0.25s;
  transform: translateY(-75%);
}
section[data-section-type=drag-order][data-escalation-level="7"] .phase.questionform .frame {
  border: 0.125rem solid #fff;
}
section[data-section-type=drag-order][data-escalation-level="7"] .phase.questionform .frame form.drag-order .round-info {
  color: #fff;
  border-bottom: 0.125rem solid #fff;
}

#app section[data-section-type=pool] {
  /*form.pool {
    user-select: none;
    button {
      appearance: none;
      background-color: transparent;
      border: 2px solid #aaa;
      border-radius: 10px;
      padding: 5px 10px;
      &.--correct {
        pointer-events: none;
        border-color: #bada55;
      }
      &.--incorrect {
        pointer-events: none;
        border-color: #ff4444;
      }
    }
    &[data-disabled="true"] {
      pointer-events: none;
      opacity: 0.5;
    }
  }*/
}
#app section[data-section-type=pool] .phase.questionform {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=pool] .phase.questionform.--active {
  display: flex;
}
#app section[data-section-type=pool] .phase.questionform .frame {
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 2.5rem;
  padding-top: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
#app section[data-section-type=pool] .phase.questionform .frame .round-info {
  flex-grow: 0;
  text-align: center;
  padding-top: 5.9375rem;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #144B5B;
  display: none;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container {
  display: flex;
  align-items: stretch;
  height: 100%;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .questions {
  width: 15rem;
  flex-grow: 0;
  flex-shrink: 0;
  border-right: 0.125rem solid #144B5B;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-top: 1.25rem;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .questions .question {
  width: 14.375rem;
  position: relative;
  left: -1.5625rem;
  text-align: center;
  font-size: 2.4375rem;
  font-weight: 800;
  line-height: 3.125rem;
  color: #000;
  display: none;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers {
  padding: 4.375rem 1.25rem;
  padding-right: 2.5rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  align-self: center;
  gap: 3.125rem 0;
  position: relative;
  z-index: 10;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer {
  width: 25%;
  padding: 0 0.625rem;
  text-align: center;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button {
  padding: 0;
  position: relative;
  color: #fff;
  height: auto;
  background: transparent;
  text-transform: none;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button::before, #app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3.4375rem;
  height: 3.4375rem;
  background: url("../svg/icon-correct-color.svg") no-repeat 50% 50%;
  background-size: contain;
  transform: translate(-50%, -50%);
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button::after {
  background: url("../svg/icon-incorrect-color.svg") no-repeat 50% 50%;
  background-size: contain;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button span {
  position: relative;
  font-size: 1.375rem;
  line-height: 1.5rem;
  font-weight: 800;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone;
  background-color: #000;
  color: #fff;
  padding: 0.625rem 1.125rem;
  border-radius: 1.875rem;
  transition: color 0.25s, background-color 0.25s;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button span em {
  font-style: normal;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button:not(.--locked):hover span {
  background-color: #fff;
  color: #000;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button.--locked {
  pointer-events: none;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button.--locked span {
  color: #000;
  background-color: var(--color-team-highlight);
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button.--correct {
  pointer-events: none;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button.--correct::before {
  opacity: 1;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button.--correct span {
  color: #55D48F;
  background-color: #77DDA5;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button.--incorrect {
  pointer-events: none;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button.--incorrect::after {
  opacity: 1;
}
#app section[data-section-type=pool] .phase.questionform .frame .question-container .answers .answer button.--incorrect span {
  color: #144B5B;
  background-color: #2B5D6B;
}
#app section[data-section-type=pool] .phase.questionform .frame .characters {
  pointer-events: none;
  width: 31.25rem;
  height: 37.5rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateY(-5rem);
  right: -3.75rem;
}
#app section[data-section-type=pool] .phase.questionform .frame .characters .character-container {
  position: absolute;
  top: 0;
  left: 0;
}
#app section[data-section-type=pool] .phase.questionform .frame .characters .character-container .character-faces {
  --width: 37.5rem;
  --height: 75rem;
}
#app section[data-section-type=pool] form.pool {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  padding-top: 2.1875rem;
  height: 100%;
  display: flex;
  flex-direction: column;
}
#app section[data-section-type=pool] form.pool fieldset {
  border: 0;
}

#app section[data-section-type=connections] .phase.questionform {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=connections] .phase.questionform.--active {
  display: flex;
}
#app section[data-section-type=connections] .phase.questionform .frame {
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 2.5rem 0;
  padding-bottom: 1.25rem;
  display: flex;
  flex-direction: column;
  min-height: 39.375rem;
}
#app section[data-section-type=connections] .phase.questionform .frame form fieldset {
  border: 0;
}
#app section[data-section-type=connections] .phase.questionform .frame form .round-info {
  margin: 0 2.5rem;
  flex-grow: 0;
  text-align: center;
  padding-top: 5.9375rem;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector {
  margin: 0 2.5rem;
  padding-right: 6.875rem;
  color: #000;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .question {
  text-align: center;
  font-weight: 800;
  font-size: 1.875rem;
  padding: 0.75rem 1.5625rem;
  max-width: 14.625rem;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .answerbutton {
  padding: 0.75rem 0.9375rem;
  font-weight: 800;
  font-size: 1.6875rem;
  border-left: 0.125rem solid #144B5B;
  cursor: pointer;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team {
  position: relative;
  padding: 0 0.9375rem;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team .pillbox {
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 2.1875rem 2.1875rem;
  overflow: hidden;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team .pillbox::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color);
  transition: transform 0.25s, background-color 0.25s;
  border-radius: 2.1875rem 2.1875rem;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team .pillbox:hover::before {
  background-color: #fff;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team .pillbox .icon {
  width: 4.375rem;
  height: 4.375rem;
  border-radius: 50% 50%;
  overflow: hidden;
  position: relative;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team .pillbox .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team .pillbox .name {
  position: relative;
  z-index: 1;
  padding: 0 1.25rem;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team.--disabled {
  pointer-events: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .team.--disabled .pillbox::before {
  transform: translateX(-100%) translateX(4.375rem);
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .all {
  position: relative;
  color: #fff;
  padding: 0 0.9375rem;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .all .pillbox {
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 2.1875rem 2.1875rem;
  overflow: hidden;
  height: 4.375rem;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .all .pillbox::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #000;
  transition: opacity 0.25s, background-color 0.25s;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .all .pillbox .name {
  color: #fff;
  position: relative;
  z-index: 1;
  padding: 0 1.25rem;
  transition: color 0.25s;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .all .pillbox:hover::before {
  background-color: #fff;
}
#app section[data-section-type=connections] .phase.questionform .frame form .team-selector .all .pillbox:hover .name {
  color: #000;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions {
  margin: 0;
  padding-bottom: 1.25rem;
  padding-right: 6.875rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1.875rem 1.875rem;
  padding-top: 1.875rem;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 2;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button {
  width: 20%;
  padding: 0;
  position: relative;
  color: #fff;
  height: auto;
  background: transparent;
  text-transform: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--hidden {
  display: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button::before, #app section[data-section-type=connections] .phase.questionform .frame form .questions button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3.4375rem;
  height: 3.4375rem;
  background: url("../svg/icon-correct-color.svg") no-repeat 50% 50%;
  background-size: contain;
  transform: translate(-50%, -50%);
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button::after {
  background: url("../svg/icon-incorrect-color.svg") no-repeat 50% 50%;
  background-size: contain;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button span {
  position: relative;
  font-size: 1.375rem;
  line-height: 1.5rem;
  font-weight: 800;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone;
  background-color: #000;
  color: #fff;
  padding: 0.625rem 1.25rem;
  border-radius: 1.875rem;
  transition: color 0.25s, background-color 0.25s;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button span em {
  font-style: normal;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button:not(.--locked):hover span {
  background-color: #ddd;
  color: #444;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--selected span {
  background-color: #fff !important;
  color: #000 !important;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered {
  pointer-events: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--locked {
  pointer-events: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--locked span {
  color: #000;
  background-color: var(--color-team-highlight);
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--correct {
  pointer-events: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--correct::before {
  opacity: 1;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--correct span {
  color: #55D48F;
  background-color: #77DDA5;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--incorrect {
  pointer-events: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--incorrect::after {
  opacity: 1;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--incorrect span {
  color: #144B5B;
  background-color: #2B5D6B;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--neutral {
  pointer-events: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--neutral::before {
  background: url("../svg/icon-neutral-color.svg") no-repeat 50% 50%;
  background-size: contain;
  opacity: 1;
}
#app section[data-section-type=connections] .phase.questionform .frame form .questions button.--answered.--neutral span {
  color: #E7EDEF;
  background-color: #fff;
}
#app section[data-section-type=connections] .phase.questionform .frame form[data-disabled=true] .team-selector {
  pointer-events: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form[data-disabled=true] .team-selector .answerbutton {
  cursor: default;
}
#app section[data-section-type=connections] .phase.questionform .frame form[data-disabled=true] .team-selector .team .pillbox::before {
  transform: translateX(-100%) translateX(4.375rem);
}
#app section[data-section-type=connections] .phase.questionform .frame form[data-disabled=true] .team-selector .all .pillbox .name {
  color: #000;
}
#app section[data-section-type=connections] .phase.questionform .frame form[data-disabled=true] .team-selector .all .pillbox::before {
  opacity: 0;
}
#app section[data-section-type=connections] .phase.questionform .frame form[data-disabled=true] .questions {
  pointer-events: none;
}
#app section[data-section-type=connections] .phase.questionform .frame form[data-disabled=true] .questions button span {
  background-color: #144B5B;
}
#app section[data-section-type=connections] .phase.questionform .character-container {
  position: absolute;
  right: -1.25rem;
  top: 2.5rem;
  width: 25rem;
  height: 37.5rem;
}
#app section[data-section-type=connections] .phase.questionform .character-container .character-faces {
  position: absolute;
  top: 0;
  left: 0;
  --width: 35rem;
  --height: 75rem;
}
#app section[data-section-type=connections] .round-dialog {
  display: flex;
  opacity: 0;
  pointer-events: none;
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 900;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding-top: 11.5625rem;
  padding-bottom: 10.9375rem;
}
#app section[data-section-type=connections] .round-dialog .dialog {
  opacity: 0;
  transition: opacity 0.25s, transform 0.25s;
  width: 37.5rem;
}
#app section[data-section-type=connections] .round-dialog .dialog .container .content-container h3 {
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
}
#app section[data-section-type=connections] .round-dialog .dialog .container .content-container .cta:empty {
  display: none;
}
#app section[data-section-type=connections] .round-dialog .dialog .container .content-container .cta .buttons {
  margin-top: 1.875rem;
}
#app section[data-section-type=connections] .round-dialog.--active {
  opacity: 1;
  pointer-events: all;
}
#app section[data-section-type=connections] .round-dialog.--active .dialog {
  transform: translateY(0);
  opacity: 1;
}

#app section[data-section-type=thoughts] .phase.questionform {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=thoughts] .phase.questionform.--active {
  display: flex;
}
#app section[data-section-type=thoughts] .phase.questionform .frame {
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 2.5rem 0;
  padding-bottom: 1.25rem;
  display: flex;
  flex-direction: column;
  min-height: 39.375rem;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form fieldset {
  border: 0;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .round-info {
  margin: 0 2.5rem;
  flex-grow: 0;
  text-align: center;
  padding-top: 5.9375rem;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector {
  margin: 0 2.5rem;
  padding-right: 7.5rem;
  color: #000;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .question {
  text-align: center;
  font-weight: 800;
  font-size: 1.875rem;
  padding: 0.75rem 2.5rem;
  max-width: 14.625rem;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .answerbutton {
  padding: 0.75rem 1.25rem;
  font-weight: 800;
  font-size: 1.6875rem;
  border-left: 0.125rem solid #144B5B;
  cursor: pointer;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .team {
  position: relative;
  padding: 0 1.875rem;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .team .pillbox {
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 2.1875rem 2.1875rem;
  overflow: hidden;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .team .pillbox::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color);
  transition: transform 0.25s, background-color 0.25s;
  border-radius: 2.1875rem 2.1875rem;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .team .pillbox:hover::before {
  background-color: #fff;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .team .pillbox .icon {
  width: 4.375rem;
  height: 4.375rem;
  border-radius: 50% 50%;
  overflow: hidden;
  position: relative;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .team .pillbox .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .team .pillbox .name {
  position: relative;
  z-index: 1;
  padding: 0 1.25rem;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .all {
  position: relative;
  color: #fff;
  padding: 0 1.875rem;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .all .pillbox {
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 2.1875rem 2.1875rem;
  overflow: hidden;
  height: 4.375rem;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .all .pillbox::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #000;
  transition: opacity 0.25s, background-color 0.25s;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .all .pillbox .name {
  color: #fff;
  position: relative;
  z-index: 1;
  padding: 0 1.25rem;
  transition: color 0.25s;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .all .pillbox:hover::before {
  background-color: #fff;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .team-selector .all .pillbox:hover .name {
  color: #000;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions {
  margin: 0;
  padding-bottom: 1.25rem;
  padding-right: 6.25rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1.875rem 1.875rem;
  padding-top: 1.875rem;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 2;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button {
  width: 20%;
  padding: 0;
  position: relative;
  color: #fff;
  height: auto;
  background: transparent;
  text-transform: none;
  transition: opacity 0.25s;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button:nth-child(2), #app section[data-section-type=thoughts] .phase.questionform .frame form .questions button:nth-child(7) {
  width: 20rem;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--hidden {
  display: none;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button::before, #app section[data-section-type=thoughts] .phase.questionform .frame form .questions button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3.4375rem;
  height: 3.4375rem;
  background: url("../svg/icon-correct-color.svg") no-repeat 50% 50%;
  background-size: contain;
  transform: translate(-50%, -50%);
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button::after {
  background: url("../svg/icon-incorrect-color.svg") no-repeat 50% 50%;
  background-size: contain;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button span {
  position: relative;
  font-size: 1.375rem;
  line-height: 1.5rem;
  font-weight: 800;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone;
  background-color: #000;
  color: #fff;
  padding: 0.625rem 1.25rem;
  border-radius: 1.875rem;
  transition: color 0.25s, background-color 0.25s;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button span em {
  font-style: normal;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button:not(.--locked):hover span {
  background-color: #ddd;
  color: #444;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--selected span {
  background-color: #fff !important;
  color: #000 !important;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered {
  pointer-events: none;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--locked {
  pointer-events: none;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--locked span {
  color: #000;
  background-color: var(--color-team-highlight);
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--correct {
  pointer-events: none;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--correct::before {
  opacity: 1;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--correct span {
  color: #55D48F;
  background-color: #77DDA5;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--incorrect {
  pointer-events: none;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--incorrect::after {
  opacity: 1;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--incorrect span {
  color: #144B5B;
  background-color: #2B5D6B;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--disabled {
  opacity: 0.5;
  pointer-events: none;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--disabled::before {
  transition: none;
  opacity: 0;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form .questions button.--answered.--disabled span {
  color: transparent;
  transition: none;
  background-color: #fff;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form[data-disabled=true] .team-selector {
  pointer-events: none;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form[data-disabled=true] .team-selector .answerbutton {
  cursor: default;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form[data-disabled=true] .team-selector .team .pillbox::before {
  transform: translateX(-100%) translateX(4.375rem);
}
#app section[data-section-type=thoughts] .phase.questionform .frame form[data-disabled=true] .team-selector .all .pillbox .name {
  color: #000;
}
#app section[data-section-type=thoughts] .phase.questionform .frame form[data-disabled=true] .team-selector .all .pillbox::before {
  opacity: 0;
}
#app section[data-section-type=thoughts] .phase.questionform .character-container {
  pointer-events: none;
  position: absolute;
  right: -1.25rem;
  top: 2.5rem;
  width: 25rem;
  height: 37.5rem;
}
#app section[data-section-type=thoughts] .phase.questionform .character-container .character-faces {
  position: absolute;
  top: 0;
  left: 0;
  --width: 35rem;
  --height: 75rem;
}

#app section[data-section-type=negotiations] .phase {
  height: 100vh;
  align-items: stretch;
  padding: 2.5rem;
  padding-top: 3.5rem;
  padding-left: 9.375rem;
}
#app section[data-section-type=negotiations] .phase.--active {
  display: flex;
}
#app section[data-section-type=negotiations] .phase .placeholder {
  position: absolute;
  top: 1.25rem;
  left: 1.25rem;
  right: 1.25rem;
  bottom: 1.25rem;
  overflow: hidden;
  z-index: 10;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 1;
  pointer-events: all;
  max-height: 100%;
  transition: opacity 0.25s 0s, max-height 0s 0.3s;
}
#app section[data-section-type=negotiations] .phase .placeholder button {
  opacity: 0;
  pointer-events: none;
}
#app section[data-section-type=negotiations] .phase .placeholder button.--visible {
  pointer-events: auto;
  transition: opacity 0.25s;
  opacity: 1;
}
#app section[data-section-type=negotiations] .phase .placeholder > .background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
#app section[data-section-type=negotiations] .phase .placeholder > .background > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#app section[data-section-type=negotiations] .phase .center {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
#app section[data-section-type=negotiations] .phase.--hide-placeholder .placeholder {
  opacity: 0;
  max-height: 0;
  pointer-events: none;
}
#app section[data-section-type=negotiations] .phase .frame {
  position: relative;
  width: 100%;
  border: 0.125rem solid #144B5B;
  padding: 2.5rem;
  min-height: 38.75rem;
  display: flex;
  flex-direction: column;
  padding-top: 8.4375rem;
  transition: padding 0.5s;
  will-change: padding-top;
}
#app section[data-section-type=negotiations] .phase .frame .round-info {
  position: absolute;
  top: 8.4375rem;
  left: 2.5rem;
  right: 2.5rem;
  flex-grow: 0;
  text-align: center;
  padding-bottom: 0.9375rem;
  font-size: 1.5rem;
  line-height: 1.25rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  border-bottom: 0.125rem solid #144B5B;
  transition: opacity 0.25s;
  opacity: 0;
}
#app section[data-section-type=negotiations] .phase.questions .question-container {
  border-left: 0.125rem solid transparent;
  transition: border 0.25s;
  position: relative;
  z-index: 10;
  display: flex;
  height: 100%;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: calc(100% + 1.25rem);
  width: 18.125rem;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team {
  padding: 3.125rem 1.5625rem;
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team:first-child {
  border-bottom: 0.125rem solid #144B5B;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team .icon {
  position: relative;
  width: 7.5rem;
  height: 7.5rem;
  flex-shrink: 0;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team .text {
  text-transform: uppercase;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team .text .name {
  font-weight: 900;
  font-style: italic;
  font-size: 1.875rem;
  line-height: 1.875rem;
  margin-bottom: 0.3125rem;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team .text .points-container {
  font-style: italic;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team .text .points-container .points {
  display: flex;
  align-items: flex-end;
  font-weight: 800;
  font-size: 1.125rem;
  line-height: 1.25rem;
}
#app section[data-section-type=negotiations] .phase.questions .team-stats-container .team .text .points-container .points .current-points {
  font-weight: 900;
  font-size: 2.8125rem;
  line-height: 2.875rem;
  transform: translateY(0.1875rem);
}
#app section[data-section-type=negotiations] .phase.questions .words-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 3.125rem 0;
}
#app section[data-section-type=negotiations] .phase.questions .words-container h3 {
  transition: opacity 0.25s;
  color: #000;
  text-align: center;
  font-size: 1.875rem;
  line-height: 2.1875rem;
  font-weight: 800;
  margin-bottom: 1.6875rem;
}
#app section[data-section-type=negotiations] .phase.questions .words-container .words {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 41.25rem;
  gap: 0.625rem;
  padding-right: 0.625rem;
  transform: translateX(-0.625rem);
}
#app section[data-section-type=negotiations] .phase.questions .words-container .words.--blur {
  filter: blur(0.625rem);
}
#app section[data-section-type=negotiations] .phase.questions .words-container .words .word {
  cursor: pointer;
  background-color: #000;
  color: #fff;
  font-size: 1.6875rem;
  font-weight: 800;
  text-align: center;
  line-height: 1.75rem;
  padding: 0.5rem 1.25rem;
  border-radius: 1.375rem;
  transition: color 0.24s, background-color 0.24s;
}
#app section[data-section-type=negotiations] .phase.questions .words-container .words .word:hover {
  background-color: #fff;
  color: #000;
}
#app section[data-section-type=negotiations] .phase.questions .words-container .words .buttons {
  opacity: 0;
  pointer-events: none;
}
#app section[data-section-type=negotiations] .phase.questions .timer-container {
  width: 31.875rem;
  flex-shrink: 0;
  border-left: 0.125rem solid #144B5B;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
#app section[data-section-type=negotiations] .phase.questions .timer-container .round-timer {
  position: relative;
  width: 23.75rem;
  height: 23.75rem;
}
#app section[data-section-type=negotiations] .phase.questions .timer-container .round-timer .progress {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: conic-gradient(var(--color-highlight) var(--progress, 0%), 0, transparent);
  border-radius: 50% 50%;
  -webkit-mask: radial-gradient(9.375rem, rgba(0, 0, 0, 0) 99%, #000);
          mask: radial-gradient(9.375rem, rgba(0, 0, 0, 0) 99%, #000);
}
#app section[data-section-type=negotiations] .phase.questions .timer-container .round-timer .time {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translateY(-50%);
  font-size: 7.5rem;
  line-height: 7.5rem;
  font-weight: 900;
  font-style: italic;
}
#app section[data-section-type=negotiations] .phase.questions .timer-container .round-timer button.pause {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-color: rgba(20, 75, 91, 0.3019607843);
  color: #144B5B;
  padding: 0.5rem 0.875rem;
  padding-left: 2.0625rem;
  font-size: 1rem;
  line-height: 1.375rem;
  font-weight: 900;
  text-transform: uppercase;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, 5rem);
  border: none;
}
#app section[data-section-type=negotiations] .phase.questions .timer-container .round-timer button.pause::before {
  content: "";
  position: absolute;
  background-color: #144B5B;
  top: 50%;
  left: 0.625rem;
  width: 1rem;
  height: 1rem;
  -webkit-mask: var(--pause-icon) no-repeat 50% 50%;
          mask: var(--pause-icon) no-repeat 50% 50%;
  -webkit-mask-size: contain;
          mask-size: contain;
  transform: translateY(-50%);
}
#app section[data-section-type=negotiations] .phase.questions:not(.--choosing-phase) .words-container, #app section[data-section-type=negotiations] .phase.questions[data-active-team-index=""] .words-container {
  pointer-events: none;
  transform: translateY(2.5rem);
}
#app section[data-section-type=negotiations] .phase.questions:not(.--choosing-phase) .words-container .words .word, #app section[data-section-type=negotiations] .phase.questions[data-active-team-index=""] .words-container .words .word {
  background-color: #144B5B;
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase .frame {
  padding-top: 11.875rem;
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase .question-container {
  border-left: 0.125rem solid #144B5B;
  transform: translateX(18.125rem);
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase .round-info {
  opacity: 1;
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase .team-stats-container {
  opacity: 1;
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase .words-container {
  transform: translateX(4.375rem) translateY(2.5rem);
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase .words-container h3 {
  opacity: 0;
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase .timer-container {
  opacity: 0;
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase[data-active-team-index="0"] .words-container .words .word.--answered-team-1 {
  pointer-events: none;
  background-color: var(--color-highlight-light);
  color: var(--color-highlight-dark);
}
#app section[data-section-type=negotiations] .phase.questions.--choosing-phase[data-active-team-index="1"] .words-container .words .word.--answered-team-2 {
  pointer-events: none;
  background-color: var(--color-highlight-light);
  color: var(--color-highlight-dark);
}
#app section[data-section-type=negotiations] .phase.questions.--final-phase .team-stats-container {
  opacity: 0;
}
#app section[data-section-type=negotiations] .phase.questions.--final-phase .question-container {
  border-left: 0.125rem solid transparent;
  transform: translateX(15rem) translateY(-2.5rem);
}
#app section[data-section-type=negotiations] .phase.questions.--final-phase .round-info {
  opacity: 0;
}
#app section[data-section-type=negotiations] .phase.questions.--final-phase .words-container {
  transform: translateY(0);
}
#app section[data-section-type=negotiations] .phase.questions.--final-phase .words-container .words .word {
  background-color: #E7EDEF;
  color: #B8C9CE;
}
#app section[data-section-type=negotiations] .phase.questions.--final-phase .words-container .words .word.--answered-team-1.--answered-team-2 {
  color: #fff;
  background-color: var(--color-highlight);
}
#app section[data-section-type=negotiations] .phase.questions.--button-visible .words-container .words .buttons {
  transition: opacity 0.25s 0.5s;
  opacity: 1;
  pointer-events: auto;
}
#app section[data-section-type=negotiations] .phase.bars:not(.--end-phase) .frame {
  padding-top: 12.625rem;
}
#app section[data-section-type=negotiations] .phase.bars:not(.--end-phase) .round-info {
  opacity: 1;
}
#app section[data-section-type=negotiations] .phase.bars .question-container {
  position: relative;
  display: flex;
  height: 100%;
  align-items: stretch;
  z-index: 10;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container {
  position: relative;
  width: 100%;
  margin-right: 1.25rem;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .result {
  opacity: 0;
  transition: opacity 0.3s 0s;
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-style: italic;
  font-weight: 900;
  text-transform: uppercase;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .result.--active {
  opacity: 1;
  pointer-events: auto;
  transition: opacity 0.3s 0.3s;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .accept {
  opacity: 0;
  transition: opacity 0.3s 0s;
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .accept h3 {
  color: #000;
  font-size: 1.875rem;
  line-height: 2.1875rem;
  margin-bottom: 3.75rem;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .accept .buttons {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
  align-items: center;
  justify-content: center;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .accept.--active {
  opacity: 1;
  pointer-events: auto;
  transition: opacity 0.3s 0.3s;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds {
  width: 28.75rem;
  position: relative;
  height: 100%;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round {
  opacity: 0;
  transition: opacity 0.3s 0s;
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round.--active {
  opacity: 1;
  pointer-events: auto;
  transition: opacity 0.3s 0.3s;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round.--answered {
  pointer-events: none;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round .choice {
  min-height: 8.75rem;
  padding: 1.25rem;
  padding-left: 6rem;
  padding-right: 1.625rem;
  border-top: 0.125rem solid #144B5B;
  color: #000;
  font-size: 1.25rem;
  line-height: 1.5rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  cursor: pointer;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round .choice:first-child {
  border: none;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round .choice > div {
  position: relative;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round .choice > div::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -5.1875rem;
  width: 3.5rem;
  height: 3.5rem;
  background-color: #000;
  border-radius: 1.75rem;
  transition: background-color 0.25s;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round .choice > div::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -5.1875rem;
  width: 3.5rem;
  height: 3.5rem;
  background-color: var(--color);
  -webkit-mask: url("../svg/caret-right.svg") no-repeat 58% 50%;
          mask: url("../svg/caret-right.svg") no-repeat 58% 50%;
  -webkit-mask-size: 1.75rem auto;
          mask-size: 1.75rem auto;
  transition: background-color 0.25s;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round .choice:hover > div::before {
  background-color: var(--color);
}
#app section[data-section-type=negotiations] .phase.bars .question-container .answers-container .rounds .round .choice:hover > div::after {
  background-color: #000;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container {
  border-left: 0.125rem solid #144B5B;
  width: 42.5rem;
  flex-shrink: 0;
  padding-left: 2.5rem;
  padding-top: 1.25rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team {
  width: 25.9375rem;
  display: flex;
  justify-content: space-between;
  gap: 1.25rem;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .avatar {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .avatar .icon {
  width: 5rem;
  height: 5rem;
  position: relative;
  margin-bottom: 0.9375rem;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .avatar .icon > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .avatar .name {
  font-weight: 900;
  font-style: italic;
  font-size: 1.875rem;
  line-height: 1.875rem;
  text-transform: uppercase;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .bars-container {
  width: 18.75rem;
  --cutoff: 1.5;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .bars-container .bars {
  position: relative;
  height: 0.625rem;
  border-radius: 0.3125rem;
  background-color: rgba(255, 255, 255, 0.5);
  overflow: hidden;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .bars-container .bars .bar-container {
  position: absolute;
  height: 0.625rem;
  top: 0;
  left: 0;
  right: 0;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .bars-container .bars .bar-container .bar {
  position: absolute;
  top: 0;
  left: 0;
  height: 0.625rem;
  border-radius: 0.3125rem;
  width: calc((var(--value) + 4) / 7 * 100%);
  transition: width 0.5s;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .bars-container .bars .bar-container.--background .bar {
  background-color: var(--color);
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .bars-container .bars .bar-container.--foreground {
  clip-path: inset(-1px calc((3 - var(--cutoff)) / 7 * 100%) -1px 0);
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .bars-container .bars .bar-container.--foreground .bar {
  background-color: #000;
  background: #000 linear-gradient(90deg, rgb(235, 0, 0) 0%, rgb(0, 0, 0) 100%);
  background-size: 11.25rem;
  background-repeat: no-repeat;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .team .bars-container .label {
  margin-top: 0.1875rem;
  margin-bottom: 0.375rem;
  font-size: 0.75rem;
  line-height: 1rem;
  text-transform: uppercase;
  font-style: italic;
  font-weight: 500;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .compromise {
  width: 25.9375rem;
  height: 4.625rem;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .compromise .spacer {
  display: flex;
  width: 18.75rem;
  margin-left: auto;
  position: relative;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .compromise .spacer .offset {
  position: relative;
  top: 1.125rem;
  position: absolute;
  --cutoff: 1.5;
  left: calc((var(--cutoff) + 4) / 7 * 100%);
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .compromise .spacer .offset::before {
  position: absolute;
  bottom: calc(100% + 0.3125rem);
  content: "";
  left: -0.0625rem;
  width: 0.125rem;
  background-color: #144B5B;
  height: 1.5625rem;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .compromise .spacer .offset::after {
  position: absolute;
  top: calc(100% + 0.3125rem);
  content: "";
  left: -0.0625rem;
  width: 0.125rem;
  background-color: #144B5B;
  height: 1.5625rem;
}
#app section[data-section-type=negotiations] .phase.bars .question-container .team-bars-container .container .compromise .spacer .offset .text {
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 800;
  font-style: italic;
  text-transform: uppercase;
  position: relative;
  transform: translateX(-50%);
}
#app section[data-section-type=negotiations] .phase.bars.--end-phase .question-container .rounds {
  transition: opacity 0.5s;
  opacity: 0;
}
#app section[data-section-type=negotiations] .phase.bars.--end-phase .question-container .team-bars-container {
  transition: width 0.5s;
  width: 50%;
}
#app section[data-section-type=negotiations] .phase.bars.--end-phase .question-container .team-bars-container .container {
  transform: translateX(3.125rem);
  transition: transform 0.5s;
}
#app section[data-section-type=negotiations] .phase.end-video {
  position: static;
}
#app section[data-section-type=negotiations] .phase.end-video.--animate-in .video-container {
  opacity: 1;
}
#app section[data-section-type=negotiations] .phase.end-video.--animate-in .video-container .container {
  transform: translateY(0);
}
#app section[data-section-type=negotiations] .phase.end-video.--animate-out {
  transition: opacity 0.25s;
}
#app section[data-section-type=negotiations] .phase.end-video.--animate-out .video-container {
  opacity: 0;
}
#app section[data-section-type=negotiations] .phase.end-video.--animate-out .video-container .container {
  transform: translateY(-2.5rem);
}
#app section[data-section-type=negotiations] .character-container {
  pointer-events: none;
  position: absolute;
  right: -1.25rem;
  top: 50%;
  transform: translateY(-50%) translateY(-3.125rem);
  width: 25rem;
  height: 37.5rem;
}
#app section[data-section-type=negotiations] .character-container .character-faces {
  position: absolute;
  top: 0;
  left: 0;
  --width: 35rem;
  --height: 75rem;
}
#app section[data-section-type=negotiations] .video-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(20, 75, 91, 0.6980392157);
  -webkit-backdrop-filter: blur(0.9375rem);
          backdrop-filter: blur(0.9375rem);
  z-index: 800;
  display: flex;
  opacity: 0;
  justify-content: center;
  align-items: center;
  transition: opacity 0.25s;
}
#app section[data-section-type=negotiations] .video-container .container {
  position: relative;
  overflow: hidden;
  border-radius: 0.375rem;
  background-color: #144B5B;
  box-shadow: 0 0 1.25rem rgba(20, 75, 91, 0.2);
  transform: translateY(2.5rem);
  transition: transform 0.25s;
}
#app section[data-section-type=negotiations] .video-container .container video {
  display: block;
  background-color: #000;
  height: 41.25rem;
  width: 73.3125rem;
}
#app section[data-section-type=negotiations] .video-container .container .after-complete {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  background-color: rgba(255, 255, 255, 0.8);
}
#app section[data-section-type=negotiations] .video-container .container .after-complete .buttons {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  position: relative;
  z-index: 1;
}
#app section[data-section-type=negotiations] .video-container .container .after-complete.--visible {
  opacity: 1;
  pointer-events: auto;
}
#app section[data-section-type=negotiations] .round-dialog {
  display: flex;
  opacity: 0;
  pointer-events: none;
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 900;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding-top: 11.5625rem;
  padding-bottom: 10.9375rem;
}
#app section[data-section-type=negotiations] .round-dialog .dialog {
  opacity: 0;
  transition: opacity 0.25s, transform 0.25s;
  width: 37.5rem;
}
#app section[data-section-type=negotiations] .round-dialog .dialog .container .content-container h3 {
  font-size: 2.8125rem;
  line-height: 2.875rem;
  font-weight: 900;
}
#app section[data-section-type=negotiations] .round-dialog .dialog .container .content-container .cta:empty {
  display: none;
}
#app section[data-section-type=negotiations] .round-dialog .dialog .container .content-container .cta .buttons {
  margin-top: 1.875rem;
}
#app section[data-section-type=negotiations] .round-dialog.--active {
  opacity: 1;
  pointer-events: all;
}
#app section[data-section-type=negotiations] .round-dialog.--active .dialog {
  transform: translateY(0);
  opacity: 1;
}

@media screen and (max-width: 900px) {
  :root {
    font-size: 4.1025641026vw;
  }
  body {
    overflow: initial;
  }
  main {
    overflow: hidden;
  }
  header {
    display: none;
  }
  .frontpage-content {
    font-size: 1.25rem;
    height: auto;
    position: relative;
    overflow: initial;
  }
  .frontpage-content .background {
    overflow: hidden;
    position: relative;
    bottom: auto;
    height: 39.375rem;
    margin-bottom: -3.125rem;
  }
  .frontpage-content .background > img {
    top: auto;
    bottom: 3.125rem;
    left: 50%;
    transform: translateX(-50%);
    width: 120%;
    height: auto;
    -o-object-fit: initial;
       object-fit: initial;
  }
  .frontpage-content p {
    margin-bottom: 0.375rem;
  }
  .frontpage-content p:last-child {
    margin-bottom: 0;
  }
  .frontpage-content .intro {
    position: relative;
    z-index: 10;
    padding: 1.875rem;
    padding-bottom: 0;
    padding-left: 0;
    margin-left: 3.75rem;
    margin-bottom: 3.75rem;
    padding-top: 0;
    width: auto;
  }
  .frontpage-content .intro .content .prop {
    display: block;
  }
  .frontpage-content .cmi-logo {
    top: 0.3125rem;
    left: 50%;
    transform: translateX(-50%);
  }
  .frontpage-content .cmi-logo img {
    width: 9.375rem;
  }
  .frontpage-content .logo {
    top: 3.75rem;
    bottom: auto;
    padding: 2.5rem 0;
    transform: translateX(-50%);
    width: 21.25rem;
    text-align: center;
  }
  .frontpage-content .logo .selected-team {
    display: none;
  }
  .frontpage-content .logo h1 {
    width: 12.5rem;
  }
  .frontpage-content .logo h2 {
    margin-top: 0;
    margin-bottom: 1.5625rem;
    font-size: 0.625rem;
  }
  .frontpage-content .logo .disclaimer {
    margin-top: 0;
    margin-bottom: 0.9375rem;
    margin-left: 0;
    margin-right: 0;
    font-size: 0.875rem;
  }
  .frontpage-content .logo .disclaimer:empty {
    display: none;
  }
  .frontpage-content .guide {
    display: none;
  }
  .frontpage-content .background {
    background-color: #EDE9D9;
    transition: background-color var(--animation-time-2) var(--animation-delay-2);
  }
  .frontpage-content .background > img {
    transform: translateX(-50%) translateY(0) translateZ(0);
  }
  .frontpage-content .intro {
    transform: translateY(0) translateZ(0);
    transition: transform var(--animation-time) var(--animation-delay);
  }
  .frontpage-content .logo {
    transform: translateX(-50%) translateY(0) translateZ(0);
    transition: transform var(--animation-time) var(--animation-delay);
  }
  body.--loading .frontpage-content .background {
    background-color: #fff;
  }
  body.--loading .frontpage-content .background > img {
    opacity: 0;
    transform: translateX(-50%) translateY(10%) translateZ(0);
  }
  body.--loading .frontpage-content .intro {
    transform: translateY(50vh) translateZ(0);
  }
  body.--loading .frontpage-content .logo {
    transform: translateX(-50%) translateY(calc(-80vh + 50%)) translateZ(0);
  }
  .popup-dialog {
    display: none !important;
  }
  .mobile-content {
    display: block;
  }
  .mobile-content.short {
    font-size: 0.75rem;
    line-height: 1.33em;
  }
  .mobile-content.short strong {
    text-transform: uppercase;
    font-style: italic;
  }
  .mobile-content.short .button {
    margin-top: 1.875rem;
    font-size: 1rem;
  }
  .mobile-content.long {
    padding-bottom: 1.875rem;
  }
  .mobile-content.long .content {
    padding: 0 1.875rem;
  }
  .mobile-content.long .content h4 {
    margin-bottom: 0.625rem;
    margin-top: 1.25rem;
  }
  .mobile-content.long .content p {
    margin-bottom: 1.875rem;
  }
  .mobile-content.long .content p:last-child {
    margin-bottom: 0;
  }
  .mobile-content.long .content ul, .mobile-content.long .content ol {
    margin-left: 1em;
    margin-bottom: 1.875rem;
  }
  .mobile-content.long .content ul:last-child, .mobile-content.long .content ol:last-child {
    margin-bottom: 0;
  }
  .mobile-content.long .logos {
    border-top: 0.125rem solid #144B5B;
    margin: 0 0.9375rem;
    margin-top: 3.75rem;
    text-align: center;
  }
  .mobile-content.long .logos > img {
    width: 20.3125rem;
    height: auto;
  }
}
/*# sourceMappingURL=main.css.map */
