@charset "UTF-8";
html {
  font-size: 10px; }

.logo_link {
  display: block;
  padding: 20px 10px;
  text-align: center; }

.logo_link svg {
  width: 100%;
  height: 85px;
  max-width: 500px; }

.global-layout {
  display: flex;
  min-height: 100vh; }
  .global-layout .content {
    flex: 1 0 auto;
    margin: 0 20px; }
  .global-layout .centered {
    margin: 0 auto; }
  .global-layout .inner {
    max-width: 100%;
    padding-bottom: 8rem; }
    @media all and (max-width: 900px) {
      .global-layout .inner {
        padding: 2rem 2rem 8rem 2rem; } }
  .global-layout .mw1300 {
    max-width: 1300px; }
  .global-layout .mw870 {
    max-width: 870px;
    margin: 0 auto; }

@media (max-width: 767px) {
  .global-layout {
    margin: 0;
    overflow: hidden; }
    .global-layout .content {
      margin: 0; }
    .global-layout .inner {
      margin: 0;
      max-width: 100vw; } }

html {
  box-sizing: border-box; }

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

img {
  max-width: 100%; }

/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Correct the line height in all browsers.
 * 3. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */
/* Document
   ========================================================================== */
html {
  font-family: 'Merriweather', serif;
  /* 1 */
  line-height: 1.15;
  /* 2 */
  -ms-text-size-adjust: 100%;
  /* 3 */
  -webkit-text-size-adjust: 100%;
  /* 3 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0; }

/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */
figcaption,
figure,
main {
  /* 1 */
  display: block; }

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px; }

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */ }

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active,
a:hover {
  outline-width: 0; }

/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */ }

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit; }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic; }

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000; }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block; }

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none; }

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: 'Merriweather', serif;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* 2 */ }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */ }

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */
details,
menu {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Scripting
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block; }

/**
 * Add the correct display in IE.
 */
template {
  display: none; }

/* Hidden
   ========================================================================== */
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none; }

html {
  font-size: 10px; }

body {
  font-size: 1.5rem;
  color: #303030; }

h1, h2, h3, h4, h5, h6 {
  font-size: 5rem;
  font-weight: 600;
  letter-spacing: -1px; }

h2 {
  font-size: 4rem; }

h3 {
  font-size: 3rem; }

h4 {
  font-size: 3rem; }

h5 {
  font-size: 2rem; }

h6 {
  font-size: 1rem; }

a {
  text-decoration: none;
  color: #303030; }

p a {
  border-bottom: 2px solid #3e0eff; }

p {
  line-height: 2;
  font-size: 1.8rem; }

.title {
  word-wrap: break-word;
  position: relative;
  z-index: 2;
  margin: 0;
  font-size: 40px;
  z-index: 2;
  line-height: 1.1;
  transform: skew(0, -3deg);
  line-height: 1.1; }
  .title--long {
    font-size: 30px; }
  .title:before {
    content: '';
    width: 50px;
    left: 0;
    top: 0;
    height: 100%;
    display: block;
    position: absolute;
    z-index: -1;
    transform: skew(-5deg); }
  .title a {
    border-bottom: 0;
    background-image: linear-gradient(to right, rgba(255, 196, 14, 0.8) 100%, rgba(255, 196, 14, 0.8) 50%); }

.title--single {
  max-width: 600px;
  margin-top: -9rem;
  font-size: 10rem;
  text-align: center; }

input, textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid #e6e6e6; }
  input.input--error, textarea.input--error {
    border-color: red; }

form .col-1-of-2 {
  display: flex;
  flex-flow: column;
  justify-content: flex-end; }
  @media (max-width: 576px) {
    form .col-1-of-2 {
      flex: 1 0 100%; } }

.button {
  padding: 10px;
  text-align: center;
  margin: 0 10px 10px; }

.buttons {
  display: flex; }
  .buttons a.button {
    white-space: nowrap; }
  @media (max-width: 576px) {
    .buttons {
      display: block;
      padding-right: 10px;
      margin-left: -10px; }
      .buttons .button {
        display: block;
        width: 100%; } }

label {
  padding: 10px 0;
  display: block; }

.required {
  color: #B00; }

abbr.required {
  margin-left: 3px;
  font-size: 10px;
  vertical-align: top; }

.name-input {
  margin-right: 10px;
  width: auto;
  padding: 3px 5px;
  border-radius: 5px; }

.form {
  background: white;
  padding: 2rem;
  box-shadow: linear-gradient(90deg, #48ded4 0%, #a026bf 20%, #e82c75 60%, #FFC40E 85%, #48ded4 95%); }
  .form + .form {
    margin-top: 4rem; }
  .form h2 {
    margin: 0;
    font-size: 2rem;
    padding-bottom: 2rem;
    margin-bottom: 2rem;
    border-bottom: 1px solid #e6e6e6; }

.search {
  position: relative;
  width: 100%;
  display: flex; }
  .search__results {
    background: white;
    position: absolute;
    width: 100%;
    top: 100%;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    z-index: 5; }
  .search__input {
    font-size: 30px;
    background: none;
    color: white;
    outline: 0;
    border: 0; }
  .search__result {
    padding: 10px;
    display: block;
    border-bottom: 1px solid #ececec; }
    .search__result--active {
      background: #f1f1f1; }

@keyframes slideIn {
  0% {
    transform: translateX(-10px); }
  50% {
    transform: translateX(10px); }
  100% {
    transform: translateX(0px); } }

.flash-messages {
  position: fixed;
  right: 20px;
  bottom: 0; }

.flash {
  background: white;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
  margin-bottom: 2rem;
  padding: 2rem;
  position: relative;
  z-index: 1;
  border-radius: 3px;
  display: flex;
  animation: slideIn forwards .1s ease-in-out 2;
  animation-timing-function: cubic-bezier(0.01, 1.68, 0.58, 1); }
  .flash + .flash {
    animation-delay: 0.55s; }
    .flash + .flash + .flash {
      animation-delay: 0.6s; }
  .flash__text {
    flex: 1; }
  .flash__remove {
    background: none;
    border: 0;
    position: absolute;
    right: 0;
    top: 0;
    color: #fff;
    font-size: 24px;
    cursor: pointer; }
    .flash__remove:hover {
      color: #303030; }
  .flash--success {
    background: linear-gradient(135deg, #d2ff52 0%, #91e842 100%); }
  .flash--error {
    background: linear-gradient(20deg, red 0%, #c80000 100%);
    color: #fff; }
  .flash--info {
    background: linear-gradient(35deg, #f1e767 0%, #feb645 100%); }
  .flash p {
    margin: 0; }

.nav {
  display: flex;
  flex-flow: column;
  list-style: none;
  z-index: 1;
  margin: 0;
  padding: 20px 0 0;
  background: #2c3e50;
  align-items: center;
  position: relative; }
  .nav .hamburger-button, .nav .backdrop {
    display: none; }
  .nav-list {
    position: sticky;
    top: 20px;
    display: flex;
    flex-flow: column;
    align-items: center; }
  .nav__section {
    display: flex;
    min-height: 95px; }
    .nav__section--search {
      flex: 1 1 auto; }
  .nav__item {
    display: flex;
    width: 100%; }
  .nav__link {
    color: white;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
    text-transform: uppercase;
    padding: 1.2rem 2rem 1rem 2rem;
    display: block;
    display: flex;
    flex: 1 0 auto;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s;
    border-bottom: 5px solid transparent; }
    .nav__link svg {
      width: 40px;
      transition: all 0.2s;
      fill: white;
      margin-bottom: 1rem; }
    .nav__link:hover svg, .nav__link--active svg {
      transform: scale(1.2); }
    .nav__link--logo:hover svg {
      transform: none; }
    .nav__link--logo svg {
      width: 300px;
      margin: 0; }

@media (max-width: 767px) {
  .logo_link {
    width: 250px;
    margin: 0 auto;
    height: 40px;
    padding: 10px 0; }
    .logo_link svg {
      width: inherit;
      height: inherit; }
  .nav {
    position: absolute;
    z-index: 1;
    height: 100vh;
    transform: translateX(-100%);
    top: 0; }
    .nav.opened {
      transition: transform 0.08s ease;
      transform: translateX(0); }
      .nav.opened .hamburger-button {
        display: none; }
      .nav.opened .backdrop {
        display: block; }
    .nav .backdrop {
      z-index: 0;
      position: fixed;
      left: 0;
      top: 0;
      width: 100vw;
      height: 100vh; }
    .nav .nav-list {
      z-index: 1; }
    .nav .hamburger-button {
      display: block;
      position: fixed;
      left: 0;
      top: 0px;
      width: 55px;
      height: 55px;
      cursor: pointer;
      background-color: #2c3e50;
      transform: translateX(117px); }
    .nav .hamburger {
      width: 30px;
      height: 3px;
      position: absolute;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
      background-color: #fff; }
      .nav .hamburger:before, .nav .hamburger:after {
        content: '';
        display: block;
        width: 30px;
        height: 3px;
        background-color: #fff; }
      .nav .hamburger:before {
        transform: translateY(-9px); }
      .nav .hamburger:after {
        transform: translateY(6px); } }

.table {
  width: 100%; }
  .table td {
    padding: 5px; }
  .table tr:nth-child(even) {
    background: white; }
  .table tr:nth-child(odd):not(:first-child) {
    background: #f7f7f7; }
  .table thead tr {
    background: #303030;
    color: white; }

.stores {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }

.store {
  background: white;
  margin: 10px 0;
  width: 30%;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1), 0 5px 10px rgba(0, 0, 0, 0.05); }
  .store--wide {
    width: 100%; }
  .store__details {
    padding: 2rem; }
    .store__details p {
      line-height: 1.2;
      margin-bottom: 0; }
  @media all and (max-width: 850px) {
    .store {
      width: 48%; } }
  @media all and (max-width: 550px) {
    .store {
      width: 100%; } }

.store__actions {
  position: relative;
  z-index: 2;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.2), 0 1px 0 rgba(255, 255, 255, 0.2);
  margin-bottom: 50px;
  padding-top: 10px;
  padding-bottom: 20px;
  display: flex;
  color: white;
  align-items: center;
  justify-content: space-around; }

.store__action {
  font-size: 10px; }
  .store__action svg {
    width: 25px;
    fill: white; }
  .store__action--edit a {
    border-bottom: 0; }

.store__hero {
  position: relative;
  padding: 0 10px 0 10px;
  text-align: right; }
  .store__hero:before {
    display: block;
    content: '';
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    right: 0;
    background: linear-gradient(45deg, #05b3d6 0%, rgba(5, 179, 214, 0) 70%), linear-gradient(135deg, #0958ec 10%, rgba(9, 88, 236, 0) 80%), linear-gradient(225deg, #d209ec 10%, rgba(210, 9, 236, 0) 80%), linear-gradient(315deg, #05e129 100%, rgba(5, 225, 41, 0) 70%);
    opacity: 0.6;
    z-index: 1;
    clip-path: polygon(0 0, 100% 0, 100% 90%, 0% 100%); }
  .store__hero img {
    height: 100%;
    width: 100%;
    top: 0;
    right: 0;
    position: absolute;
    left: 0;
    object-fit: cover;
    clip-path: polygon(0 0, 100% 0, 100% 90%, 0% 100%); }

.tags {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  margin-bottom: 2rem;
  flex-wrap: wrap; }

.tag {
  display: block;
  margin-right: 1rem; }
  .tag__choice {
    display: flex;
    justify-content: center;
    align-items: center; }
    .tag__choice input {
      width: auto;
      right: -1.5rem;
      margin-right: -1rem;
      position: relative;
      z-index: 2; }
      .tag__choice input + label {
        background: #e6e6e6;
        padding: 1rem 1rem 1rem 4rem; }
      .tag__choice input:checked + label {
        background: #FFC40E; }
  .tag__link {
    background: #FFC40E;
    color: #303030;
    display: flex;
    padding-left: 10px;
    clip-path: polygon(10px 0%, 100% 1%, 100% 100%, 10px 100%, 0% 50%); }
    .tag__link--active {
      background: #827cd2; }
      .tag__link--active .tag__text {
        color: white; }
  .tag__text {
    padding: 1rem 1rem;
    display: block; }
  .tag__count {
    padding: 1rem 1rem;
    background: white;
    border-left: 3px solid rgba(0, 0, 0, 0.1);
    margin-right: -1px;
    /* ugh */
    background-clip: padding-box; }

.single__hero {
  height: 500px;
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2vw), 0% 100%); }
  .single__hero:before {
    display: block;
    content: '';
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    right: 0;
    background: linear-gradient(45deg, #05b3d6 0%, rgba(5, 179, 214, 0) 70%), linear-gradient(135deg, #0958ec 10%, rgba(9, 88, 236, 0) 80%), linear-gradient(225deg, #d209ec 10%, rgba(210, 9, 236, 0) 80%), linear-gradient(315deg, #05e129 100%, rgba(5, 225, 41, 0) 70%);
    opacity: 0.6;
    z-index: 1;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2vw), 0% 100%); }

.single__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute; }

.single__details {
  background: white;
  position: relative;
  padding: 3rem;
  margin-top: -10rem;
  box-shadow: 0 0 10px 2px rgba(0, 0, 0, 0.15); }

.single__map {
  width: calc(100% + 6rem);
  max-width: none;
  margin-top: -3rem;
  margin-left: -3rem; }

.single__location {
  margin: 0;
  margin-top: -3rem;
  margin-right: -5rem;
  background: #303030;
  color: white;
  display: inline-block;
  float: right;
  position: relative;
  padding: 1rem; }
  @media all and (max-width: 850px) {
    .single__location {
      margin-right: 0; } }

.heart__button {
  background: none;
  border: 0;
  outline: 0;
  position: relative; }
  .heart__button:after {
    content: '♥️';
    font-size: 20px;
    position: absolute;
    opacity: 0;
    top: 0; }
  .heart__button svg {
    width: 25px;
    fill: white; }
  .heart__button--hearted svg {
    fill: red; }
  .heart__button--float:after {
    animation: fly 2.5s 1 ease-out; }

@keyframes fly {
  0% {
    transform: translateY(0);
    left: 0;
    opacity: 1; }
  20% {
    left: 20px; }
  40% {
    left: -20px; }
  60% {
    left: 20px; }
  80% {
    left: -20px; }
  100% {
    transform: translateY(-400px);
    opacity: 0;
    left: 20px; } }

.review {
  background: white;
  border: 1px solid #e6e6e6;
  border-bottom: 0;
  border-bottom: 1px solid #e6e6e6;
  margin-bottom: 2rem;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  position: relative;
  padding-left: 5px; }
  .review:before {
    width: 5px;
    left: 0;
    content: '';
    display: block;
    background: linear-gradient(0, #48ded4 0%, #a026bf 20%, #e82c75 60%, #FFC40E 85%, #48ded4 95%);
    position: absolute;
    height: 100%;
    background-attachment: fixed; }
  .review__header {
    border-bottom: 1px solid #e6e6e6;
    display: flex; }
    .review__header > * {
      border-right: 1px solid #e6e6e6;
      padding: 0.2rem;
      display: flex;
      align-items: center;
      flex: 1;
      justify-content: center; }
      .review__header > *:last-child {
        border-right: 0; }
  .review__author {
    justify-content: flex-start;
    padding-left: 2rem;
    display: flex; }
    .review__author .avatar {
      margin-right: 2rem; }
  .review__time {
    font-size: 1.2rem;
    color: #999999; }
  .review__stars {
    color: #FFC40E; }
  .review__body {
    padding: 2rem; }
  .review p {
    white-space: pre-wrap; }

/*
  Reviewer Form
 */
.reviewer {
  position: relative;
  box-shadow: 0 0px 10px rgba(0, 0, 0, 0.2);
  margin-bottom: 2rem; }
  .reviewer__stars {
    display: flex;
    justify-content: center; }
    .reviewer__stars input {
      display: none; }
      .reviewer__stars input:checked ~ label {
        color: #FFC40E; }
      .reviewer__stars input + label {
        font-size: 0;
        /* These are in the opposite DOM order
           re-order them to be visually in normal order
           This is fine for accessibility because our labels have for()
         */ }
        .reviewer__stars input + label:before {
          content: '★';
          font-size: 2rem; }
        .reviewer__stars input + label[for="star5"] {
          order: 5; }
        .reviewer__stars input + label[for="star4"] {
          order: 4; }
        .reviewer__stars input + label[for="star3"] {
          order: 3; }
        .reviewer__stars input + label[for="star2"] {
          order: 2; }
        .reviewer__stars input + label[for="star1"] {
          order: 1; }
        .reviewer__stars input + label:hover, .reviewer__stars input + label:hover ~ label {
          color: #ffdd74; }
  .reviewer textarea {
    border: 0;
    outline: 0;
    font-size: 2rem;
    padding: 2rem;
    height: 200px; }
  .reviewer__meta {
    display: flex;
    justify-content: center;
    align-items: center;
    border-top: 1px solid #e6e6e6; }
    .reviewer__meta > * {
      flex: 1; }

.pagination {
  display: flex;
  align-items: center;
  background: white;
  margin-top: 2rem;
  margin-bottom: 2rem;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1), 0 5px 10px rgba(0, 0, 0, 0.05); }
  .pagination__next {
    flex: 0 0 auto;
    padding: 1rem 3rem 1rem 1rem; }
    .pagination__next a:after {
      margin-left: 1rem;
      content: '→'; }
  .pagination__prev {
    flex: 0 0 auto;
    padding: 1rem 1rem 1rem 3rem; }
    .pagination__prev a:before {
      margin-right: 1rem;
      content: '←'; }
  .pagination__text {
    flex: 3 0 auto;
    padding: 1rem;
    text-align: center; }

.map {
  padding: 20px;
  background: white;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1), 0 5px 10px rgba(0, 0, 0, 0.05); }

#map {
  height: 500px; }

.popup {
  width: 300px; }
  .popup img {
    width: 100%; }

.hide {
  text-indent: -999999px;
  font-size: 0; }

.button {
  border: 0;
  background: #FFC40E;
  color: #303030;
  font-weight: 600;
  cursor: pointer; }
  .button:hover {
    background: #f4b800; }

.avatar {
  min-width: 50px;
  height: 50px;
  border-radius: 50%;
  align-self: center; }

.card {
  background: white;
  padding: 5rem;
  box-shadow: 0 1px 10px rgba(0, 0, 0, 0.15); }

pre.error {
  padding: 5rem;
  background: white;
  line-height: 3;
  white-space: pre-line; }

.grid {
  display: flex;
  flex-wrap: wrap; }

.col-1-of-2 {
  flex: 1 0 50%;
  min-width: 50%; }

.col {
  flex: 1 0 100%;
  min-width: 100%; }

.hidden {
  display: none; }

.form-element {
  margin-bottom: 20px;
  padding: 0 10px; }

.courses-list {
  max-width: 600px;
  margin: 0 auto; }
  .courses-list a {
    display: block;
    color: #2c3e50;
    font-size: 26px; }

.course-module {
  display: inline-block;
  padding: 20px;
  border: 1px solid rebeccapurple;
  border-radius: 3px;
  font-size: 2.5rem;
  color: #2c3e50;
  width: 100%;
  margin-bottom: 30px;
  cursor: pointer; }
  .course-module:hover {
    background-color: rgba(102, 51, 153, 0.1); }

.course-card {
  border: 1px solid rebeccapurple;
  font-size: 2.5rem;
  border-radius: 8px;
  color: #2c3e50;
  padding: 20px;
  margin-bottom: 20px;
  cursor: pointer; }
  .course-card:hover {
    background-color: rgba(102, 51, 153, 0.1); }

.lesson-list {
  margin: 20px 0; }

.course-navigation {
  display: flex;
  align-items: center;
  justify-content: space-between; }
  .course-navigation > * {
    flex: 1 0 25%;
    padding: 0 10px;
    align-self: stretch;
    min-height: 40px; }
  .course-navigation .lesson-name {
    text-align: center;
    font-size: 2rem;
    flex: 1 0 50%;
    font-weight: 700; }
  .course-navigation > *:last-child {
    text-align: right; }

.course-navigation {
  flex-wrap: wrap; }
  .course-navigation * {
    order: 0;
    flex: 1 0 50%; }
  .course-navigation .lesson-name {
    order: 1;
    flex: 1 0 100%;
    font-weight: 700; }

.course-nav-link {
  cursor: pointer;
  color: #005fb2; }
  .course-nav-link:hover {
    text-decoration: underline; }

.course-breadcrumbs {
  margin-bottom: 50px; }
  .course-breadcrumbs .current,
  .course-breadcrumbs .course-nav-link {
    padding: 0 5px; }

.hw-img-list {
  display: flex;
  flex-flow: wrap; }
  .hw-img-list img {
    max-width: 50%;
    min-width: 50%;
    padding: 15px;
    display: block;
    box-sizing: border-box; }
    @media (max-width: 768px) {
      .hw-img-list img {
        max-width: 100%;
        min-width: 100%; } }

.video-block,
.audio-block {
  width: 100%;
  position: relative;
  max-width: 650px;
  margin: 30px auto; }
  .video-block .video-js,
  .audio-block .video-js {
    min-height: 300px;
    height: 100%;
    width: 100%; }
    .video-block .video-js video.vjs-tech,
    .audio-block .video-js video.vjs-tech {
      padding: 0 !important;
      height: 100% !important;
      background: #000; }
  .video-block .vjs-poster img,
  .audio-block .vjs-poster img {
    object-fit: cover; }
  .video-block video,
  .audio-block video {
    background-image: url("/images/poster.png"); }

.user-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end; }
  .user-actions p:not(:last-child) {
    margin-right: 15px; }

.user-table {
  width: 100%;
  border-collapse: collapse;
  border-left: 2px solid #ddd;
  border-right: 2px solid #ddd;
  border-top: 2px solid #ddd; }
  .user-table thead td {
    font-size: 2rem;
    font-weight: 600; }
  .user-table td {
    padding: 3px 10px;
    border: 1px solid #ddd; }
    .user-table td.active {
      background-color: #0DE55A; }
    .user-table td.not-active {
      background-color: #B00; }
    .user-table td.active, .user-table td.not-active {
      position: relative;
      padding: 0; }
      .user-table td.active label, .user-table td.not-active label {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        padding: 0;
        cursor: pointer; }
  .user-table input[type="checkbox"] {
    transform: scale(2);
    width: 13px; }
  .user-table .first td {
    border-top: 2px solid #ddd; }
  .user-table .first td:last-child,
  .user-table .last td {
    border-bottom: 2px solid #ddd; }
  .user-table input:not([type="submit"]),
  .user-table textarea {
    background: transparent; }

.user .form {
  display: flex;
  background-color: transparent;
  padding: 0; }
  @media (max-width: 1400px) {
    .user .form {
      display: block; } }

.user-info {
  display: flex;
  flex: 1 0 auto;
  flex-flow: column; }

.user-name,
.user-date {
  flex: 1 0; }

.user-date input {
  margin-bottom: 3px; }

.user-name p {
  margin: 0 0 3px 0;
  font-size: 16px;
  line-height: 25px; }

@media (max-width: 900px) {
  .actions {
    max-width: 80vw; } }

.actions .button {
  margin: 0 10px 0 0; }

@media (max-width: 767px) {
  .user-name, .user-date {
    flex: 1 0 100%; }
  .user-name p {
    line-height: 27px; }
  .user .form {
    display: block; }
  .user-actions {
    display: flex;
    width: 100%;
    justify-content: center; }
    .user-actions p {
      margin: 0 10px 3px; } }

.inner.lesson .main-content p {
  text-align: justify; }

.content-block {
  margin-bottom: 15px; }

.text-center {
  text-align: center; }

.telegram-button {
  display: inline-flex;
  border: none;
  color: #fff;
  background-color: #2481cc;
  padding: 3px 20px;
  border-radius: 25px; }
  .telegram-button svg {
    transform: translateX(-5px); }
  .telegram-button:hover {
    background-color: #2f8eda; }

.form.hidden {
  display: none; }

.update-all-block {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 20px;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 0; }

.update-all {
  padding: 10px; }

.user-message {
  border: 1px solid #14e760;
  background-color: rgba(20, 231, 96, 0.38);
  border-radius: 5px;
  padding: 20px;
  margin-bottom: 30px; }
  .user-message p {
    display: flex;
    line-height: 1;
    padding: 0;
    margin: 0; }

.agreed {
  background-color: rgba(13, 229, 90, 0.07); }

.deleted {
  background-color: rgba(229, 50, 13, 0.07); }

.inner.hide-deleted .deleted,
.inner.hide-inactive .inactive {
  display: none; }

.inner.February_2023 .user:not(.February_2023),
.inner.September_2022 .user:not(.September_2022),
.inner.show-deleted .user:not(.deleted) {
  display: none; }

.inner.users {
  overflow-x: auto; }
  .inner.users .user {
    border: 1px solid #999;
    border-radius: 3px;
    margin-bottom: 10px;
    padding: 15px; }
    .inner.users .user.inactive {
      opacity: 0.3; }
  .inner.users .actions {
    margin: 20px 0;
    padding: 20px;
    border: 1px solid #999;
    border-radius: 5px; }
  .inner.users .button {
    padding: 10px; }

.delete-button {
  width: 100%;
  padding: 1rem;
  background: #ff5757; }
  .delete-button:hover {
    background: #ff3e3e; }

.user-message-input {
  display: inline-block;
  margin-right: 15px; }
  .user-message-input input {
    transform: scale(2); }
  .user-message-input + label {
    padding: 0; }

.download-link {
  text-decoration: underline;
  color: #0909b3;
  text-decoration-style: dotted; }
  .download-link:hover {
    text-decoration-style: solid; }

.quizlet-button {
  display: inline-block;
  background: #edefff;
  border-bottom: 0.25rem solid transparent;
  border-radius: 0.5rem;
  box-shadow: 0 0.25rem 1rem 0 rgba(48, 53, 69, 0.08);
  margin-top: 20px;
  cursor: pointer;
  padding: 1rem 1rem 0.5rem; }
  .quizlet-button:hover {
    border-bottom-color: #dbdfff;
    box-shadow: 0 0.25rem 1rem 0 rgba(48, 53, 69, 0.08); }

.audio-block p {
  line-height: 1.5;
  font-size: 140%;
  margin-bottom: 10px;
  display: flex;
  flex-flow: column; }

.audio-block .description {
  margin-top: 70px; }

.audio-block .name {
  margin-top: 50px; }
  .audio-block .name:empty {
    margin-top: 0; }

.audio-block .description + .name {
  margin-top: 0; }

.audio-block span {
  font-size: 85%; }

.audio-block .eng {
  font-size: 100%;
  display: inline-block;
  margin-bottom: 10px;
  font-weight: 700; }

.audio-block .small {
  display: inline-block;
  margin-top: 5px;
  margin-bottom: 5px;
  font-size: 75%; }

.home-work {
  border: 1px solid rebeccapurple;
  background-color: rgba(102, 51, 153, 0.08);
  border-radius: 8px;
  padding: 2rem;
  margin-top: 50px; }

.hw-title {
  font-size: 150%;
  margin-top: 0; }

.lesson-buttons {
  text-align: center !important;
  margin-bottom: 50px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center; }
  .lesson-buttons a.lesson-button {
    border: 2px solid #FFC40E;
    padding: 10px;
    border-radius: 3px;
    background: rgba(255, 196, 14, 0.25);
    margin: 0 10px 20px; }
    .lesson-buttons a.lesson-button:hover {
      background: rgba(255, 196, 14, 0.5); }
    .lesson-buttons a.lesson-button:first-child:last-of-type {
      margin-bottom: 0; }
    .lesson-buttons a.lesson-button + span {
      display: inline-block;
      max-width: 75%;
      text-align: left;
      padding: 10px; }

.home-work-list {
  counter-reset: item; }
  .home-work-list > li {
    list-style-type: none;
    margin: 0;
    font-size: 120%;
    text-align: justify;
    line-height: 2; }
    .home-work-list > li:before {
      content: counter(item) ") ";
      counter-increment: item;
      position: absolute;
      transform: translateX(-130%);
      line-height: 2; }

[data-tooltip] {
  position: relative; }
  [data-tooltip]:after {
    content: '?';
    font-size: 10px;
    vertical-align: top;
    display: inline-block;
    padding: 0 3px; }
  [data-tooltip]::before {
    content: attr(data-tooltip);
    /* Выводим текст */
    position: absolute;
    max-width: 300px;
    min-width: 240px;
    width: 100%;
    left: -50%;
    transform: translateX(-50%) translateY(0);
    background: rebeccapurple;
    color: #fff;
    padding: 0.5em;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
    pointer-events: none;
    opacity: 0;
    transition: 0.3s; }
  [data-tooltip]:hover::before {
    opacity: 1;
    transform: translateX(-50%) translateY(1em); }

.limerik-wrap {
  max-width: 600px;
  margin: 0 auto; }

.limerik {
  margin-bottom: 30px;
  padding: 15px;
  border: 1px solid rebeccapurple;
  border-radius: 8px;
  display: inline-block;
  position: relative; }
  .limerik span.info {
    position: absolute;
    background-color: #fff;
    display: inline-block;
    padding: 3px;
    right: 10px;
    top: -13px; }
  .limerik p {
    margin: 0;
    line-height: 1.3; }
  .limerik.limerik-second {
    margin-left: 50px; }
  .limerik .author {
    font-style: italic;
    text-align: right !important; }

.song-table {
  margin: 0 auto;
  border-collapse: collapse; }
  @media (max-width: 600px) {
    .song-table {
      display: block; }
      .song-table td, .song-table td {
        display: block; } }

.song {
  padding: 5px 10px;
  vertical-align: top; }
  .song p {
    margin: 0;
    line-height: 1.4; }
  .song .song-title {
    font-size: 120%;
    font-weight: 700;
    margin-bottom: 10px; }
  .song .song-last-row {
    margin-bottom: 20px; }
  .song.song-translation {
    background-color: #D4E0E8; }

.remarks {
  display: inline-block;
  border-top: 1px solid #000;
  padding-right: 30px;
  margin-top: 20px; }
  .remarks p {
    line-height: 1.4;
    margin: 0 0 5px 0; }

.user-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end; }
  .user-actions p:not(:last-child) {
    margin-right: 15px; }
  .user-actions .button {
    appearance: none;
    border: 2px solid #e6e6e6;
    border-radius: 4px;
    box-sizing: border-box;
    width: 50px;
    height: 50px;
    padding: 0 !important;
    display: flex;
    justify-content: center;
    align-items: center; }
    .user-actions .button svg {
      max-width: 30px;
      max-height: 30px; }

.user-table {
  width: 100%;
  border-collapse: collapse;
  border-left: 2px solid #ddd;
  border-right: 2px solid #ddd;
  border-top: 2px solid #ddd; }
  .user-table thead td {
    font-size: 2rem;
    font-weight: 600; }
  .user-table td {
    padding: 3px 10px;
    border: 1px solid #ddd; }
    .user-table td.active {
      background-color: #0DE55A; }
    .user-table td.not-active {
      background-color: #B00; }
    .user-table td.active, .user-table td.not-active {
      position: relative;
      padding: 0; }
      .user-table td.active label, .user-table td.not-active label {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        padding: 0;
        cursor: pointer; }
  .user-table input[type="checkbox"] {
    transform: scale(2);
    width: 13px; }
  .user-table .first td {
    border-top: 2px solid #ddd; }
  .user-table .first td:last-child,
  .user-table .last td {
    border-bottom: 2px solid #ddd; }
  .user-table input:not([type="submit"]),
  .user-table textarea {
    background: transparent; }

.user-grid {
  display: flex;
  flex-wrap: wrap;
  max-width: calc(100vw - 171px);
  margin: 0 -10px; }
  @media (max-width: 768px) {
    .user-grid {
      max-width: calc(100vw - 20px); } }
  .user-grid .user {
    flex: 1 1 calc(33% - 20px);
    width: calc(33% - 20px);
    margin: 0 10px; }
    @media (max-width: 1200px) {
      .user-grid .user {
        flex: 1 1 calc(50% - 20px);
        width: calc(50% - 20px); } }
    @media (max-width: 768px) {
      .user-grid .user {
        flex: 1 1 100%;
        width: 100%; } }

.user .form {
  display: flex;
  background-color: transparent;
  padding: 0; }
  @media (max-width: 1400px) {
    .user .form {
      display: block; } }

.user-info {
  display: flex;
  flex: 1 0 auto; }
  @media (max-width: 1050px) {
    .user-info {
      display: block; } }

.user-name,
.user-date {
  flex: 1 0 50%;
  max-width: 50%; }

.user-date input {
  margin-bottom: 3px; }

.user-name p {
  margin: 0 0 3px 0;
  font-size: 16px;
  line-height: 25px;
  overflow: hidden;
  text-overflow: ellipsis; }

.user-name input {
  width: 250px;
  line-height: 1;
  padding: 3px 5px; }

.user-access {
  margin-top: 10px;
  flex: 1 0 auto;
  max-width: 1200px; }
  .user-access .modules-access-label {
    font-size: 18px;
    text-align: center; }
  .user-access .modules-access {
    display: flex;
    padding-top: 10px; }
  .user-access .input-block {
    display: inline-flex;
    align-items: center;
    line-height: 2;
    cursor: pointer;
    width: 35px;
    height: 35px;
    border: 1px solid transparent;
    border-radius: 5px;
    margin-right: 15px;
    margin-bottom: 10px;
    padding: 0 0 3px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 22px;
    line-height: 0; }
    .user-access .input-block.active {
      border-color: #0DE55A;
      background-color: #0DE55A;
      color: #fff; }
      .user-access .input-block.active:hover {
        background-color: transparent;
        color: #B00; }
    .user-access .input-block.not-active {
      border-color: #B00;
      color: #B00; }
      .user-access .input-block.not-active:hover {
        border-color: #0DE55A;
        color: #0DE55A; }
  .user-access > p {
    flex: 0 1 auto;
    padding: 5px 15px 5px 10px;
    border: 1px solid #d6d7d8;
    border-radius: 5px;
    margin: 5px;
    line-height: 0.5; }

.user-actions {
  padding: 0;
  display: flex;
  flex-flow: column;
  flex: 0 1 70px; }
  .user-actions p {
    margin: 0 0 6px; }

@media (max-width: 900px) {
  .actions {
    max-width: 80vw; } }

.actions .button {
  margin: 0 10px 0 0; }

@media (max-width: 767px) {
  .user-name, .user-date {
    flex: 1 0 100%; }
  .user-name p {
    line-height: 27px; }
  .user .form {
    display: block; }
  .user-actions {
    display: flex;
    width: 100%;
    justify-content: center; }
    .user-actions p {
      margin: 0 10px 3px; } }

.update-all-block {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 20px;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 0; }

.update-all {
  padding: 10px; }

.user-message {
  border: 1px solid #14e760;
  background-color: rgba(20, 231, 96, 0.38);
  border-radius: 5px;
  padding: 20px;
  margin-bottom: 30px; }
  .user-message p {
    display: flex;
    line-height: 1;
    padding: 0;
    margin: 0; }

.agreed {
  background-color: rgba(13, 229, 90, 0.07); }

.deleted {
  background-color: rgba(229, 50, 13, 0.07); }

.inner.hide-deleted .deleted,
.inner.hide-inactive .inactive {
  display: none; }

.inner.users {
  overflow-x: auto;
  padding: 0 20px; }
  .inner.users .user {
    border: 1px solid #999;
    border-radius: 3px;
    margin-bottom: 10px;
    padding: 15px;
    display: flex;
    align-items: stretch; }
    .inner.users .user.inactive {
      opacity: 0.3; }
  .inner.users .actions {
    margin: 20px 0;
    padding: 20px;
    border: 1px solid #999;
    border-radius: 5px; }
  .inner.users .button {
    padding: 10px; }

.warning-button {
  width: 100%;
  padding: 1rem;
  background: #ffc457; }
  .warning-button:hover {
    background: #ffbb3e; }

.delete-button {
  width: 100%;
  padding: 1rem;
  background: #ff5757; }
  .delete-button:hover {
    background: #ff3e3e; }

.user-message-input {
  display: inline-block;
  margin-right: 15px; }
  .user-message-input input {
    transform: scale(2); }
  .user-message-input + label {
    padding: 0; }

.horizontal-slider {
  position: relative;
  width: 100%;
  height: 50px;
  border: 1px solid grey; }
  .horizontal-slider .track {
    top: 20px;
    height: 10px;
    background: red; }
    .horizontal-slider .track.track-1 {
      background-color: #fff; }
  .horizontal-slider .thumb {
    font-size: 0.9em;
    text-align: center;
    background-color: black;
    color: white;
    cursor: pointer;
    border: 5px solid gray;
    box-sizing: border-box;
    top: 1px;
    width: 50px;
    height: 48px;
    line-height: 38px; }
    .horizontal-slider .thumb.active {
      background-color: grey; }
  .horizontal-slider .mark {
    width: 8px;
    height: 8px;
    border: 2px solid black;
    background-color: white;
    cursor: pointer;
    border-radius: 50%;
    vertical-align: middle;
    margin: 0px calc(19px);
    bottom: calc(50% - 6px); }

.wrapper {
  position: relative;
  display: flex;
  align-items: center;
  margin: 40px calc(16px / 2);
  padding-top: 1.6rem;
  height: calc(16px + 1.6rem); }

.input-wrapper {
  width: calc(100% + 16px);
  margin: 0 calc(16px / -2);
  position: absolute;
  height: 16px; }

.control-wrapper {
  width: 100%;
  position: absolute;
  height: 16px; }

.input {
  position: absolute;
  width: 100%;
  pointer-events: none;
  appearance: none;
  height: 100%;
  opacity: 0;
  z-index: 3;
  padding: 0; }
  .input::-ms-track {
    appearance: none;
    background: transparent;
    border: transparent; }
  .input::-moz-range-track {
    appearance: none;
    background: transparent;
    border: transparent; }
  .input:focus::-webkit-slider-runnable-track {
    appearance: none;
    background: transparent;
    border: transparent; }
  .input::-ms-thumb {
    appearance: none;
    pointer-events: all;
    width: 16px;
    height: 16px;
    border-radius: 0px;
    border: 0 none;
    cursor: grab;
    background-color: red; }
    .input::-ms-thumb:active {
      cursor: grabbing; }
  .input::-moz-range-thumb {
    appearance: none;
    pointer-events: all;
    width: 16px;
    height: 16px;
    border-radius: 0px;
    border: 0 none;
    cursor: grab;
    background-color: red; }
    .input::-moz-range-thumb:active {
      cursor: grabbing; }
  .input::-webkit-slider-thumb {
    appearance: none;
    pointer-events: all;
    width: 16px;
    height: 16px;
    border-radius: 0px;
    border: 0 none;
    cursor: grab;
    background-color: red; }
    .input::-webkit-slider-thumb:active {
      cursor: grabbing; }

.range {
  padding: 0 4px;
  border-radius: 4px; }

.rail {
  position: absolute;
  width: 100%;
  top: 50%;
  transform: translateY(-50%);
  height: 6px;
  border-radius: 3px;
  background: lightgrey; }

.inner-rail {
  position: absolute;
  height: 100%;
  background: hotpink;
  opacity: 0.5; }

.control {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  position: absolute;
  background: hotpink;
  top: 50%;
  margin-left: calc(16px / -2);
  transform: translate3d(0, -50%, 0);
  z-index: 2; }

.range [role="slider"] {
  display: none; }
  .range [role="slider"] + [role="slider"] {
    display: flex; }

a.link {
  color: #1438e9; }

.audio-block,
.video-block {
  border: 1px solid transparent;
  border-radius: 3px;
  padding: 10px;
  margin-bottom: 40px; }
  .audio-block:has(.video-script.open),
  .video-block:has(.video-script.open) {
    border-color: rebeccapurple; }
  .audio-block h5,
  .video-block h5 {
    margin: 0 0 10px; }

.script-toggler {
  cursor: pointer;
  color: #1438e9;
  text-decoration: underline;
  text-decoration-style: dotted; }

.audio-script:not(.open) .script-content,
.video-script:not(.open) .script-content {
  display: none; }

.script-content p {
  margin: 0;
  line-height: 1.42; }

ol {
  padding-left: 10px; }
