.kirk {
  font-weight: 700;
}

.minion {
  font-size: var(--minion);
}

.brevier {
  font-size: var(--brevier);
}

.primer {
  font-size: var(--primer);
}

.long-primer {
  font-size: var(--long-primer);
  line-height: 1.3;
}

.pica {
  font-size: var(--pica);
  font-weight: 800;
  line-height: 1.2;
}

.paragon {
  font-size: var(--paragon);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  min-height: 0vh;
}

.canon {
  font-size: var(--canon);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.2;
  min-height: 0vh;
}

/* Gradient text */
.type--hero,
.type--hero > * {
  background-image: linear-gradient(105deg, hsl(187, 98%, 42%), hsl(291, 64%, 42%));
  background-size: 100%;
  background-repeat: repeat;
  font-weight: bold;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  -moz-background-clip: text;
  -moz-text-fill-color: transparent;
}
@media screen and (min-width: 1024px) {
  .type--hero,
  .type--hero > * {
    width: -moz-max-content;
    width: max-content;
  }
}
.type--hero.has-text-wrap,
.type--hero > *.has-text-wrap {
  width: initial;
}

/*  Force line breaks
    Useful in combination with gradient text to combine 
    single gradient across multi lines and type styles.
*/
.type--forced-lines {
  line-height: 1.2;
}
.type--forced-lines > .is-line {
  display: block;
}

.type--inline-title {
  font-size: var(--brevier);
  align-items: center;
  display: flex;
  gap: 0.5rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.type--inline-title::before {
  color: hsl(187, 98%, 42%);
  content: "/";
  display: block;
}

.type--uppercase {
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

* {
  box-sizing: border-box;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  list-style: none;
  margin: 0;
  outline: none;
  text-align: inherit;
  text-decoration: none;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body,
html {
  font-size: var(--primer);
  color: hsl(216, 10%, 10%);
  font-family: "IBM Plex Sans", sans-serif;
  font-weight: 400;
  height: 100%;
  line-height: 1.5;
}

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

body {
  background-image: repeating-linear-gradient(90deg, rgba(12, 62, 86, 0.07) 0px, rgba(12, 62, 86, 0.07) 1px, transparent 1px, transparent 104px), repeating-linear-gradient(0deg, rgba(12, 62, 86, 0.07) 0px, rgba(12, 62, 86, 0.07) 1px, transparent 1px, transparent 104px), repeating-linear-gradient(0deg, rgba(12, 62, 86, 0.04) 0px, rgba(12, 62, 86, 0.04) 1px, transparent 1px, transparent 13px), repeating-linear-gradient(90deg, rgba(12, 62, 86, 0.04) 0px, rgba(12, 62, 86, 0.04) 1px, transparent 1px, transparent 13px), linear-gradient(45deg, hsl(35, 33%, 93%), hsl(35, 33%, 93%));
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
li {
  font-size: 100%;
  line-height: inherit;
}

p {
  line-height: 1.5;
  margin-bottom: 1rem;
}

b,
.kirk,
strong,
b {
  font-weight: bold;
}

p > a {
  background: linear-gradient(to bottom, hsl(214, 100%, 52%) 0%, hsl(214, 100%, 52%) 100%);
  background-position: 0 100%;
  background-repeat: repeat-x;
  background-size: 4px 4px;
  color: hsl(216, 10%, 10%);
  text-decoration: none;
  transition: all 0.2s;
}
p > a:hover {
  background-size: 4px 50px;
  color: hsl(0, 100%, 100%);
}

.o-blockquote {
  border-left: 2px solid hsl(214, 100%, 52%);
  margin-bottom: 1rem;
  padding-inline-start: 1rem;
}
@media screen and (min-width: 768px) {
  .o-blockquote {
    margin-bottom: 2rem;
  }
}
.o-blockquote > p {
  font-size: var(--long-primer);
  line-height: 1.3;
}
.o-blockquote:last-child {
  margin-bottom: 0;
}
.o-blockquote--feature {
  margin-inline: auto;
}
.o-blockquote--feature > .is-main {
  font-weight: bold;
  max-width: 80ch;
}
.o-blockquote--feature:before {
  color: hsl(187, 98%, 42%);
  content: url("data:image/svg+xml,%3Csvg width='34' height='26' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cpath d='M55 17H31v24h24z'/%3E%3Cpath d='M31.639 25.5h-7.083l-4.723-10.2V0H34v15.3h-7.083l4.722 10.2Zm-19.833 0H4.722L0 15.3V0h14.167v15.3H7.083l4.723 10.2Z' fill='%2300BAD3' fill-rule='nonzero'/%3E%3C/g%3E%3C/svg%3E");
  display: block;
  height: 32px;
  width: 32px;
}

.o-cite {
  font-size: var(--brevier);
  align-items: center;
  display: grid;
  font-style: normal;
  grid-template-areas: "name role" "business business";
  grid-template-columns: max-content max-content;
}
.o-cite > .is-name {
  display: flex;
  font-weight: bold;
  grid-area: name;
  width: max-width;
}
.o-cite > .is-name:after {
  color: hsl(214, 100%, 52%);
  content: "/";
  display: block;
  font-weight: bold;
  margin-inline: 0.25rem;
}
.o-blockquote--feature .o-cite > .is-name:after {
  color: hsl(187, 98%, 42%);
}
.o-cite > .is-role {
  grid-area: role;
  width: -moz-max-content;
  width: max-content;
}
.o-cite > .is-business {
  display: flex;
  flex: 1;
  grid-area: business;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  width: 100%;
}
.o-blockquote--feature .o-cite > .is-business {
  color: hsl(187, 98%, 42%);
  font-weight: bold;
}

.main-nav {
  align-items: center;
  background-color: hsl(52, 100%, 50%);
  display: flex;
  font-size: var(--brevier);
  height: 60px;
  padding-inline: 1rem;
}
.main-nav__item {
  display: none;
  visibility: hidden;
}
@media screen and (min-width: 1024px) {
  .main-nav__item {
    display: block;
    visibility: visible;
  }
}
.main-nav__item:first-of-type {
  margin-left: auto;
}
.main-nav__burger {
  margin-left: auto;
}
@media screen and (min-width: 1024px) {
  .main-nav__burger {
    display: none;
    visibility: hidden;
  }
}
.main-nav__industry-group {
  display: flex;
  margin-left: auto;
}
.main-nav__link {
  background-color: transparent;
  border-radius: 3px;
  color: hsl(216, 10%, 10%);
  cursor: pointer;
  padding: 0.5rem;
  text-decoration: none;
  text-transform: uppercase;
  transition: all 0.4s;
}
.main-nav__link:hover {
  background-color: hsl(216, 10%, 10%);
  color: hsl(0, 100%, 100%);
}
.main-nav__industry-group {
  align-items: center;
  display: none;
}
@media screen and (min-width: 1024px) {
  .main-nav__industry-group {
    display: flex;
  }
}
.main-nav__industry-group::after {
  color: hsl(216, 10%, 80%);
  content: "|";
  display: block;
  margin-inline: 1rem;
}
.main-nav__item {
  align-items: center;
  display: none;
}
.main-nav__item.is-menu {
  display: flex;
}
@media screen and (min-width: 1024px) {
  .main-nav__item {
    display: flex;
  }
}
.main-nav__item::before {
  color: hsl(216, 10%, 80%);
  content: "|";
  display: block;
  margin-inline: 1rem;
}
.main-nav__item:first-of-type::before {
  content: initial;
}
.main-nav__item.is-menu {
  border-radius: 50%;
  overflow: hidden;
  margin-left: auto;
}
@media screen and (min-width: 1024px) {
  .main-nav__item.is-menu {
    margin-left: initial;
  }
}
.main-nav__item.is-retail {
  align-items: center;
  display: flex;
}
.main-nav__item.is-retail::after {
  content: "/";
  display: block;
  color: hsl(214, 100%, 52%);
  font-weight: bold;
}
.main-nav__item.is-venues {
  align-items: center;
  display: none;
}
@media screen and (min-width: 1024px) {
  .main-nav__item.is-venues {
    display: flex;
  }
}

@media screen and (max-width: 1023px) {
  .offcanvas__menu {
    box-shadow: 0 0 100px rgb(0, 0, 0);
    overflow: hidden;
    background-color: hsl(0, 100%, 100%);
    position: absolute;
    height: 96vh;
    width: 96vw;
    border-radius: 3px;
    padding: 1rem;
    margin-top: 1rem;
    top: 0;
    left: 2vw;
    right: 2vw;
    z-index: 9;
  }
}
.offcanvas__body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.offcanvas__list-item > .is-link {
  color: hsl(216, 10%, 10%);
  display: block;
  padding: 0.5rem;
  transition: color 0.4s;
}
.offcanvas__list-item > .is-link:hover {
  color: hsl(214, 100%, 52%);
}

.js-offcanvas-links {
  display: none;
}

.menu-icon__open, .menu-icon__close {
  color: hsl(216, 10%, 10%);
  cursor: pointer;
  transition: color 0.4s;
}
.menu-icon__close {
  margin-left: auto;
}

/*  standard button
 */
[class*=button] {
  align-items: center;
  background-color: hsl(187, 98%, 42%);
  border: 1px solid hsl(187, 98%, 42%);
  border-radius: 20px;
  color: hsl(0, 100%, 100%);
  cursor: pointer;
  display: flex;
  font-size: var(--brevier);
  font-weight: normal;
  height: 40px;
  letter-spacing: 0.05em;
  padding-inline: 1rem;
  text-transform: uppercase;
  transition: all 0.4s;
  width: -moz-max-content;
  width: max-content;
}
[class*=button]:hover {
  background-color: hsl(0, 100%, 100%);
  color: hsl(187, 98%, 42%);
}

.button.is-white {
  background-color: hsl(0, 100%, 100%);
  color: hsl(187, 98%, 42%);
}
.button.is-white:hover {
  background-color: hsl(187, 98%, 42%);
  border-color: hsl(0, 100%, 100%);
  color: hsl(0, 100%, 100%);
}
.button--outline {
  background-color: transparent;
  border-color: hsl(187, 98%, 42%);
  color: hsl(187, 98%, 42%);
}
.button--outline:hover {
  background-color: hsl(187, 98%, 42%);
  color: hsl(0, 100%, 100%);
}
.button--outline.is-white {
  border-color: hsl(0, 100%, 100%);
  color: hsl(0, 100%, 100%);
}
.button--outline.is-white:hover {
  background-color: hsl(0, 100%, 100%);
  color: hsl(187, 98%, 42%);
}

/*  Button with icon on the right
    Good for 'Next' with a forward arrow.
 */
.button--icon-right {
  background-color: transparent;
  border: initial;
  color: hsl(187, 98%, 42%);
  gap: 1rem;
}
.button--icon-right:hover {
  background-color: hsl(187, 98%, 42%);
  color: hsl(0, 100%, 100%);
}

/*  
  This seems quite heavy for a single button!
  Achieves a gradient outline and label text with the gradinet on each
  switching direction on hover.
  Use as:
   <a href="" class="button-feature is-small">
      <span class="has-gradient">Button text</span>
    </a>
*/
.button-feature {
  background-color: hsl(0, 100%, 100%);
  font-size: var(--primer);
  border: 1px solid;
  border-image-slice: 1;
  border-width: 1px;
  border: double 1px transparent;
  background-image: linear-gradient(hsl(0, 100%, 100%), hsl(0, 100%, 100%)), radial-gradient(circle at top left, hsl(187, 98%, 42%), hsl(291, 64%, 42%));
  background-origin: border-box;
  background-clip: padding-box, border-box;
  transition: all 0.4s;
  box-shadow: none;
}
.button-feature.is-small {
  font-size: var(--brevier);
  height: 36px;
}
.button-feature:hover {
  background-image: linear-gradient(hsl(0, 100%, 100%), hsl(0, 100%, 100%)), radial-gradient(circle at top left, hsl(291, 64%, 42%), hsl(187, 98%, 42%));
  box-shadow: 0 0px 6px rgba(0, 0, 0, 0.16), 0 0px 6px rgba(0, 0, 0, 0.23);
}
.button-feature:hover > .has-gradient {
  background-image: linear-gradient(105deg, hsl(187, 98%, 42%), hsl(291, 64%, 42%));
}
.button-feature > .has-gradient {
  background-image: linear-gradient(105deg, hsl(291, 64%, 42%), hsl(187, 98%, 42%));
  background-size: 100%;
  background-repeat: repeat;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  -moz-background-clip: text;
  -moz-text-fill-color: transparent;
  transition: background-image 0.4s;
}

.icon-button {
  align-items: center;
  background-color: transparent;
  border: none;
  border-radius: 50%;
  color: hsl(216, 10%, 10%);
  cursor: pointer;
  display: flex;
  height: 40px;
  justify-content: center;
  outline: none;
  transition: all 0.4s;
  width: 40px;
}
.icon-button:hover {
  background-color: hsl(0, 100%, 100%);
  color: hsl(214, 100%, 52%);
}

/*  basic content layouts for 1 or 2 columns 
    2 col layout is wider than 1 column.

    If you want 2 cols nested inside another element use .layout--inner-2
 */
.layout--1col {
  margin-inline: 2vw;
  max-width: 100%;
  padding-inline: 1vw;
  width: 96vw;
}
@media screen and (min-width: 1200px) {
  .layout--1col {
    margin-inline: auto;
    width: 1200px;
  }
}
@media screen and (min-width: 1500px) {
  .layout--1col.is-expanded {
    width: 1500px;
  }
}
.layout--2col {
  display: grid;
  gap: 4vw;
  margin-inline: auto;
  max-width: 100%;
  padding-block: 4vw;
  padding-inline: 1vw;
  width: 100%;
}
.layout--2col.has-small-gap {
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .layout--2col {
    grid-template-columns: 1fr 1fr;
    width: 1200px;
  }
}
@media screen and (min-width: 1500px) {
  .layout--2col {
    width: 1500px;
  }
}
.layout--narrow {
  margin-inline: auto;
  max-width: 100%;
  padding-inline: 1vw;
  width: 90vw;
}
@media screen and (min-width: 768px) {
  .layout--narrow {
    width: 80vw;
  }
}
@media screen and (min-width: 1024px) {
  .layout--narrow {
    width: 60vw;
  }
}
@media screen and (min-width: 1366px) {
  .layout--narrow {
    width: 40vw;
  }
}
.layout__item.has-separators::after {
  background-color: hsl(216, 10%, 80%);
  content: "";
  display: block;
  height: 3px;
  margin: 1rem auto;
  width: 25vw;
}
@media screen and (min-width: 768px) {
  .layout__item.has-separators::after {
    content: initial;
  }
}

.layout__item:last-of-type::after {
  content: initial;
}
.layout--inner-2 {
  display: grid;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .layout--inner-2 {
    gap: 1rem;
    grid-template-columns: 1fr 1fr;
  }
}
.layout--inner-2b {
  display: grid;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .layout--inner-2b {
    gap: 2rem;
    grid-template-columns: 2fr 1fr;
  }
}
@media screen and (min-width: 1366px) {
  .layout--inner-2b {
    gap: 3rem;
  }
}
@media screen and (min-width: 768px) {
  .layout--inner-2b.is-reverse {
    grid-template-columns: 1fr 2fr;
  }
}

.o-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.o-list__item-link {
  color: hsl(216, 10%, 10%);
  display: block;
  padding-block: 0.5rem;
  transition: color 0.4s;
}
.o-list__item-link:hover {
  color: hsl(214, 100%, 52%);
}
.o-list--icons.is-horizontal {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .o-list--icons.is-horizontal {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
  }
}
.o-list--icons .list__item {
  align-items: center;
  display: flex;
  gap: 1rem;
  padding-block: 0.5rem;
}
.o-list--icons .list__item > .is-icon {
  color: hsl(216, 10%, 50%);
  width: 24px;
}
.o-list--icons .list__item > .is-icon.is-turquoise {
  color: hsl(187, 98%, 42%);
}

.list-meta {
  font-size: var(--minion);
  align-items: center;
  letter-spacing: 0.05em;
  margin: 0;
  margin-bottom: 1rem;
  padding: 0;
  text-transform: uppercase;
}
@media screen and (min-width: 768px) {
  .list-meta {
    display: flex;
  }
}
.list-meta__item {
  display: flex;
}
@media screen and (min-width: 768px) {
  .list-meta__item::after {
    color: hsl(187, 98%, 42%);
    content: "/";
    display: block;
    font-weight: 800;
    margin-inline: 0.5rem;
  }
}
.list-meta__item::before {
  color: hsl(187, 98%, 42%);
  content: "/";
  display: block;
  font-weight: 800;
  margin-inline-end: 0.5rem;
}
@media screen and (min-width: 768px) {
  .list-meta__item::before {
    content: initial;
  }
}
.list-meta__item:last-of-type::after {
  content: initial;
}

.customer-list {
  align-items: center;
  background-color: hsl(0, 100%, 100%);
  display: grid;
  grid-template-columns: auto;
  grid-auto-flow: column;
  gap: 1rem;
  padding: 1rem;
}
@media screen and (min-width: 768px) {
  .customer-list {
    gap: 2rem;
    padding: 2rem;
  }
}
.customer-list--large {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 4rem;
  padding: 0;
}
.customer-list__item {
  align-items: center;
  display: flex;
  max-width: 100px;
}
@media screen and (min-width: 1024px) {
  .customer-list__item {
    max-width: 120px;
  }
}

.list__bullet > li {
  align-items: center;
  display: flex;
  margin-bottom: 0.5rem;
}
@media screen and (min-width: 768px) {
  .list__bullet > li {
    margin-bottom: 1rem;
  }
}
.list__bullet > li::before {
  color: hsl(214, 100%, 52%);
  content: "/";
  font-size: inherit;
  font-weight: bold;
  margin-right: 1rem;
}

.checklist {
  margin: 0;
  padding-left: 1rem;
}
.checklist.is-horizontal {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.checklist__item {
  position: relative;
  list-style-type: none;
  padding-left: 2rem;
  margin-bottom: 1rem;
}
.checklist__item::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: -2px;
  width: 5px;
  height: 11px;
  border-width: 0 2px 2px 0;
  border-style: solid;
  border-color: hsl(214, 100%, 52%);
  transform-origin: bottom left;
  transform: rotate(45deg);
}

.o-footer {
  background-color: hsl(0, 100%, 100%);
  display: grid;
  grid-template-areas: "brand" "menu" "contact" "social" "terminus";
  grid-template-columns: 1fr;
  margin: 3vw;
  row-gap: 1rem;
  padding: 3vw;
}
@media screen and (min-width: 768px) {
  .o-footer {
    grid-template-areas: " . brand" "menu contact" "terminus social";
    grid-template-columns: max-content 1fr;
    margin-top: 1vw;
    margin-inline: 2vw;
    padding: 2vw;
  }
}
@media screen and (min-width: 1024px) {
  .o-footer {
    grid-template-areas: " . brand" "menu contact" "terminus social";
    grid-template-columns: max-content 1fr;
    row-gap: 0;
  }
}
.o-footer__menu {
  display: grid;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  grid-area: menu;
  grid-template-columns: 1fr 1fr;
}
@media screen and (min-width: 768px) {
  .o-footer__menu {
    grid-template-columns: max-content max-content;
  }
}
.o-footer__menu > .is-title {
  grid-column: 1/3;
}
.o-footer__contact {
  display: grid;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  grid-area: contact;
  grid-template-columns: 1fr 1fr;
  height: -moz-min-content;
  height: min-content;
}
@media screen and (min-width: 768px) {
  .o-footer__contact {
    grid-template-columns: max-content max-content;
    margin-left: auto;
  }
}
@media screen and (min-width: 1024px) {
  .o-footer__contact {
    margin-left: 4rem;
  }
}
.o-footer__contact > .is-title {
  grid-column: 1/3;
}
.o-footer__brand {
  display: flex;
  grid-area: brand;
  margin-left: auto;
}
.o-footer__social {
  display: flex;
  gap: 1rem;
  grid-area: social;
}
@media screen and (min-width: 768px) {
  .o-footer__social {
    grid-area: contact;
    margin-left: auto;
    margin-top: auto;
  }
}
@media screen and (min-width: 1024px) {
  .o-footer__social {
    grid-area: social;
  }
}
.o-footer__terminus {
  font-size: var(--brevier);
  grid-area: terminus;
}
@media screen and (min-width: 768px) {
  .o-footer__terminus {
    margin-top: 2rem;
  }
}
.o-footer__terminus::before {
  background-color: hsl(216, 10%, 10%);
  content: "";
  display: block;
  height: 2px;
  width: 3rem;
}
.o-footer a {
  color: hsl(216, 10%, 10%);
  cursor: pointer;
  transition: color 0.4s;
}
.o-footer a:hover {
  color: hsl(214, 100%, 52%);
}

.c-product-menu::before {
  background-color: hsl(216, 10%, 10%);
  content: "";
  display: block;
  height: 2px;
  width: 2rem;
}

/*! Flickity v2.3.0
https://flickity.metafizzy.co
---------------------------------------------- */
.flickity-enabled {
  position: relative;
}
.flickity-enabled:focus {
  outline: none;
}
.flickity-enabled.is-draggable {
  -webkit-tap-highlight-color: transparent;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}
.flickity-enabled.is-draggable .flickity-viewport {
  overflow: hidden;
  position: relative;
  height: 100%;
  cursor: move;
  cursor: grab;
}
.flickity-enabled.is-draggable .flickity-viewport.is-pointer-down {
  cursor: grabbing;
}

.flickity-slider {
  position: absolute;
  width: 100%;
  height: 100%;
}

/* ---- flickity-button ---- */
.flickity-button {
  display: flex;
  position: absolute;
  background: transparent;
  border: initial;
  color: hsl(216, 10%, 10%);
  cursor: pointer;
  padding-inline: initial;
  align-items: center;
  justify-content: center;
}
.flickity-button:active {
  opacity: 0.6;
}
.flickity-button:disabled {
  opacity: 0.3;
  cursor: auto;
  /* prevent disabled button from capturing pointer up event. #716 */
  pointer-events: none;
}
.flickity-button-icon {
  background-color: transparent;
  border: initial;
  fill: currentColor;
  padding-inline: initial;
  color: hsl(216, 10%, 10%);
  height: 24px;
  width: 24px;
}

/* ---- previous/next buttons ---- */
.flickity-prev-next-button {
  top: 50%;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  /* vertically center */
  transform: translateY(-50%);
}
.flickity-prev-next-button.previous {
  left: 0;
}
.flickity-prev-next-button.next {
  right: 0;
}
.flickity-prev-next-button.flickity-button-icon {
  position: absolute;
  left: 20%;
  top: 20%;
  width: 60%;
  height: 60%;
}

/* ---- page dots ---- */
.flickity-page-dots {
  position: absolute;
  width: 100%;
  bottom: -25px;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
  line-height: 1;
}
.flickity-page-dots .dot {
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  margin: 0 0.5rem;
  background: hsl(214, 100%, 52%);
  border-radius: 50%;
  opacity: 0.25;
  cursor: pointer;
}
.flickity-page-dots .dot.is-selected {
  opacity: 1;
}

.gallery-cell__desc {
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  margin-top: 1rem;
  padding: 1rem;
}

/*  CAN DELETE  */
.spmt-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
  contain: strict;
}
.spmt-wrap.fixed {
  position: fixed;
}
.spmt-wrap.novis {
  visibility: hidden;
}

.spmt-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  will-change: opacity;
}

.spmt {
  position: absolute;
  top: 0;
  height: 100%;
  right: 0;
  background: hsl(0, 100%, 100%);
  overflow: auto;
  max-width: 92%;
  outline: 0;
  will-change: transform;
  touch-action: pan-y;
  padding: 1rem;
}
.spmt.left {
  right: auto;
  left: 0;
}

.retail__hero {
  align-items: center;
  background-color: hsl(52, 100%, 50%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  padding-block-end: 4vh;
  padding-block-start: 3vh;
  position: relative;
}
.retail__hero::before, .retail__hero::after {
  background-color: transparent;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.4'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  content: "";
  display: block;
  position: absolute;
}
.retail__hero::before {
  height: 60vw;
  left: -5vw;
  rotate: -22deg;
  top: 25%;
  width: 30vw;
  z-index: 0;
}
.retail__hero::after {
  top: 42%;
  height: 50vw;
  right: -5vw;
  rotate: -18deg;
  width: 20vw;
  z-index: 0;
}
@media screen and (min-width: 1024px) {
  .retail__hero {
    min-height: 80vh;
    flex-direction: row;
    padding-block-end: 2vh;
  }
}
.retail__hero > .is-message {
  margin-bottom: 2rem;
  margin-left: 2vw;
  width: 96vw;
  z-index: 1;
}
@media screen and (min-width: 1024px) {
  .retail__hero > .is-message {
    margin-bottom: initial;
    margin-left: 3vw;
    width: 47vw;
  }
}
.retail__hero > .is-media {
  margin-left: 2vw;
  width: 96vw;
  z-index: 1;
}
@media screen and (min-width: 1024px) {
  .retail__hero > .is-media {
    width: 50vw;
  }
}
@media screen and (min-width: 1024px) {
  .retail__hero > .is-media > .is-img {
    margin-left: 3vw;
  }
}
.retail__hero-text > .l1 {
  line-height: 0.5;
}
.retail__hero-text > .l2 {
  display: block;
}
.retail__hero-carousel {
  background-color: hsl(0, 100%, 100%);
  box-shadow: 0px 0 12px rgba(0, 0, 0, 0.24);
  border-radius: 3px;
  margin-block-end: 2rem;
  margin-block-start: -4vw;
  margin-inline: 2vw;
  max-width: 100%;
  overflow: hidden;
  position: relative;
  width: 96vw;
}
@media screen and (min-width: 1024px) {
  .retail__hero-carousel {
    display: grid;
    grid-template-areas: "title title" "summary gallery";
    grid-template-columns: 30% 70%;
    margin-block-end: 4rem;
  }
}
@media screen and (min-width: 1500px) {
  .retail__hero-carousel {
    grid-template-areas: "title gallery" "summary gallery";
    margin-inline: auto;
    width: 1500px;
  }
}
.retail__hero-carousel > .is-title {
  grid-area: title;
  padding-block-start: 1rem;
  padding-inline: 1rem;
}
@media screen and (min-width: 1024px) {
  .retail__hero-carousel > .is-title {
    border-bottom: 1px solid hsl(216, 10%, 80%);
    padding-block-start: 2rem;
    padding-inline: 2rem;
  }
}
@media screen and (min-width: 1500px) {
  .retail__hero-carousel > .is-title {
    border-bottom: initial;
  }
}
.retail__hero-carousel > .is-summary {
  grid-area: summary;
  padding: 1rem;
}
@media screen and (min-width: 1024px) {
  .retail__hero-carousel > .is-summary {
    border-right: 1px solid hsl(216, 10%, 80%);
    padding: 2rem;
  }
}
.retail__hero-carousel > .is-main {
  background-color: hsl(200, 18%, 80%);
  grid-area: gallery;
  height: auto;
  padding-block-end: 1rem;
  padding-block-start: 0.5rem;
  padding-inline: 0.5rem;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .retail__hero-carousel > .is-main {
    height: 100%;
    padding: 1rem;
  }
}
.retail__sme {
  display: grid;
  margin-bottom: 2rem;
  margin-inline: 2vw;
  max-width: 100%;
  width: 96vw;
}
@media screen and (min-width: 1024px) {
  .retail__sme {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (min-width: 1500px) {
  .retail__sme {
    margin-inline: auto;
    width: 1500px;
  }
}
.retail__sme-cover {
  background-color: hsl(52, 100%, 50%);
  padding-block: 1rem;
  padding-block-end: 3rem;
  padding-inline-start: 1rem;
}
@media screen and (min-width: 1024px) {
  .retail__sme-cover {
    padding-block: 2rem;
    padding-inline-end: 300px;
    padding-inline-start: 2rem;
  }
}
.retail__sme-media {
  align-items: center;
  display: flex;
  margin-inline: -2vw;
  margin-top: -2rem;
}
@media screen and (min-width: 768px) {
  .retail__sme-media {
    margin-inline: auto;
  }
}
.retail__sme-media > .is-media {
  overflow: hidden;
  position: relative;
  z-index: 3;
}
.retail__sme-media > .is-media img {
  margin-left: -20%;
  margin-right: -20%;
  max-width: initial;
  width: 140%;
}
@media screen and (min-width: 768px) {
  .retail__sme-media > .is-media img {
    margin-left: initial;
    margin-right: initial;
    max-width: 100%;
    width: initial;
  }
}
@media screen and (min-width: 1024px) {
  .retail__sme-media > .is-media {
    margin-left: -300px;
    width: calc(100% + 800px);
  }
}
.retail__sme-support {
  align-items: center;
  display: flex;
  padding-left: 100px;
}

.roi-slider {
  background-color: hsl(0, 100%, 100%);
}
.roi-slider__cell {
  background-color: hsl(0, 100%, 100%);
  display: grid;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .roi-slider__cell {
    grid-template-columns: 400px auto;
  }
}
.roi-slider__cell > .is-aside {
  padding: 2rem;
}
@media screen and (min-width: 1024px) {
  .roi-slider__cell > .is-aside {
    border-right: 1px solid hsl(216, 10%, 80%);
  }
}
.roi-slider__cell > .is-media {
  display: flex;
}
.roi-slider__cell > .is-media img {
  margin-top: auto;
}

.social-proof {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media screen and (min-width: 1024px) {
  .social-proof {
    flex-direction: row;
  }
}

@media screen and (min-width: 1024px) {
  .customer-list {
    width: 40%;
  }
}

@media screen and (min-width: 1024px) {
  .customer-testimonial {
    width: 60%;
  }
}

.u-flush--all {
  margin: 0 !important;
}
.u-flush--bottom {
  margin-bottom: 0 !important;
}
.u-flush--left {
  margin-left: 0 !important;
}
.u-flush--right {
  margin-right: 0 !important;
}
.u-flush--top {
  margin-top: 0 !important;
}

.u-margin--top {
  margin-top: 1rem !important;
}
.u-margin--bottom {
  margin-bottom: 1rem !important;
}
.u-margin--left {
  margin-left: 1rem !important;
}
.u-margin--right {
  margin-right: 1rem !important;
}
.u-margin--left-auto {
  margin-left: auto !important;
}
.u-margin--top-auto {
  margin-top: auto !important;
}

.u-island {
  padding: 1rem;
}
.u-island--large {
  padding: 2rem !important;
}

.u-padding--top {
  padding-top: 1rem;
}
.u-padding--right {
  padding-right: 1rem !important;
}
.u-padding--left {
  padding-left: 1rem !important;
}
.u-padding--bottom {
  padding-bottom: 1rem !important;
}

.u-hard--all {
  padding: 0 !important;
}
.u-hard--top {
  padding-top: 0 !important;
}
.u-hard--right {
  padding-right: 0 !important;
}
.u-hard--bottom {
  padding-bottom: 0 !important;
}
.u-hard--left {
  padding-left: 0 !important;
}

.u-breaker--top::before {
  background-color: hsl(216, 10%, 10%);
  content: "";
  display: block;
  height: 3px;
  margin-block-end: 1rem;
  margin-block-start: 2rem;
  width: 3rem;
}
@media screen and (min-width: 1024px) {
  .u-breaker--top::before {
    margin-block-end: 2rem;
    margin-block-start: 4rem;
  }
}
.u-breaker--top.u-breaker--center::before {
  margin-inline: auto;
}

.u-breaker--bottom::after {
  background-color: hsl(216, 10%, 10%);
  content: "";
  display: block;
  height: 3px;
  margin-block-end: 1rem;
  margin-block-start: 1rem;
  width: 3rem;
}
@media screen and (min-width: 1024px) {
  .u-breaker--bottom::after {
    margin-block-end: 2rem;
    margin-block-start: 2rem;
  }
}
.u-breaker--bottom.u-breaker--center::after {
  margin-inline: auto;
}

.u-align--center {
  align-items: center !important;
}

[class*=c-panel] {
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  padding: 1rem;
}
@media screen and (min-width: 1024px) {
  [class*=c-panel] {
    padding: 2rem;
  }
}
[class*=c-panel].is-flush {
  padding: 0 !important;
}

.c-panel--primary {
  background-color: hsl(52, 100%, 50%);
}
.c-panel--quiet {
  background-color: hsl(200, 18%, 80%);
}
.c-panel--primary-ultralight {
  background-color: hsl(214, 100%, 92%);
}

/*  CAN DELETE  */
.c-media-panel {
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  display: flex;
  overflow: hidden;
}
.c-media-panel.is-vertical {
  flex-direction: column;
}
.c-media-panel > .is-main {
  padding: 1rem;
}
.c-media-panel > .is-media {
  display: flex;
  flex: 1;
  flex-shrink: 0;
}

.card-grid {
  display: grid;
  gap: 1rem;
  margin-bottom: 2rem;
  max-width: 100%;
}
@media screen and (min-width: 768px) {
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
    margin-inline: 2vw;
  }
}
@media screen and (min-width: 1200px) {
  .card-grid {
    gap: 2rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 4rem;
    margin-inline: auto;
    width: 90vw;
  }
}
.card-grid__item {
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  display: flex;
  flex-direction: column;
  padding: 1rem;
}
@media screen and (min-width: 1024px) {
  .card-grid__item {
    padding: 2rem;
  }
}
.card-grid__item.has-link {
  padding: 0;
}
.card-grid__item > .is-link {
  background-color: hsl(0, 100%, 100%);
  display: flex;
  color: inherit;
  flex-direction: column;
  height: 100%;
  padding: 1rem;
  transition: background-color 0.4s;
}
.card-grid__item > .is-link:hover {
  background-color: hsl(214, 100%, 92%);
}
@media screen and (min-width: 1024px) {
  .card-grid__item > .is-link {
    padding: 2rem;
  }
}
.card-grid__item > .is-link .is-icon {
  color: hsl(187, 98%, 42%);
  display: block;
  margin-left: auto;
  margin-top: auto;
}
.card-grid__item > .is-body {
  margin-top: auto;
}
.card-grid__item.has-featured-background {
  background-color: hsl(214, 100%, 92%);
}
@media screen and (min-width: 1200px) {
  .card-grid__item.is-2-col {
    grid-column: span 2;
  }
}
.card-grid__body-layout {
  display: flex;
  flex: 1;
  flex-direction: column;
}

.card-grid-mini {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1rem;
  margin-inline: auto;
  max-width: 100%;
  width: 1200px;
}
.card-grid-mini__item {
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  padding: 1rem;
}

/*  Used on landing page  */
.scrolling-words {
  display: grid;
  width: 90vw;
}
@media screen and (min-width: 768px) {
  .scrolling-words {
    grid-template-columns: auto 300px;
    width: initial;
  }
}
@media screen and (min-width: 1024px) {
  .scrolling-words {
    grid-template-columns: auto 400px;
  }
}
@media screen and (min-width: 768px) {
  .scrolling-words__label {
    align-items: flex-end;
    display: flex;
    /*grid-column-start: 1;
    grid-column-end: 3;
    grid-row-start: 1;*/
    z-index: 2;
  }
}
.scrolling-words__collection {
  height: 9vw;
  overflow: hidden;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .scrolling-words__collection {
    grid-column-start: 1;
    grid-column-end: 3;
    grid-row-start: 2;
  }
}
.scrolling-words__list {
  animation: scrollUp 14s infinite;
  padding: 0;
}
.scrolling-words__item {
  align-items: center;
  display: flex;
  height: 9vw;
  font-size: 7vw;
}

.scrolling-graphics {
  height: 90vw;
  overflow: hidden;
  width: 90vw;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .scrolling-graphics {
    height: 400px;
    width: 400px;
  }
}
@media screen and (min-width: 768px) {
  .scrolling-graphics {
    grid-row-start: 1;
    grid-row-end: 3;
    grid-column-start: 2;
    width: initial;
  }
}
.scrolling-graphics__list {
  animation: scrollUp 14s infinite;
  animation-delay: 0.1s;
}
.scrolling-graphics__item {
  align-items: center;
  display: flex;
  height: 90vw;
  justify-content: center;
  max-width: 100%;
  width: 90vw;
}
@media screen and (min-width: 768px) {
  .scrolling-graphics__item {
    height: 400px;
    width: 400px;
  }
}

@keyframes scrollUp {
  15%, 30% {
    transform: translateY(0);
    opacity: 1;
  }
  40%, 50% {
    transform: translateY(-25%);
  }
  60%, 70% {
    transform: translateY(-50%);
  }
  80%, 99% {
    transform: translateY(-75%);
    opacity: 1;
  }
  99%, 100% {
    opacity: 0;
  }
}
.comparison-table {
  align-items: center;
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  flex-direction: column;
  width: 100%;
}
.comparison-table__row {
  display: grid;
  gap: 1rem;
  grid-template-columns: auto 100px;
}
@media screen and (min-width: 768px) {
  .comparison-table__row {
    padding-inline: 1rem;
  }
}
.comparison-table__row::after {
  background-color: hsl(216, 10%, 80%);
  content: "";
  display: block;
  grid-column: 1/3;
  height: 1px;
  margin-bottom: 1rem;
  width: 100%;
}
.comparison-table__title {
  padding-right: 2rem;
}
.comparison-table__checkbox {
  align-items: center;
  color: hsl(187, 98%, 42%);
  display: flex;
  height: 100%;
  justify-content: end;
}
@media screen and (min-width: 768px) {
  .comparison-table__checkbox {
    justify-content: center;
  }
}
.comparison-table__checkbox > .is-checkbox {
  border: 1px solid hsl(187, 98%, 42%);
  border-radius: 50%;
  font-size: var(--long-primer);
  padding: 1rem;
}

.why-ai {
  display: grid;
  gap: 1rem;
}
@media screen and (min-width: 1024px) {
  .why-ai {
    gap: 2rem;
    grid-template-columns: 2fr 1fr;
  }
}
@media screen and (min-width: 1024px) {
  .why-ai__title {
    grid-column: 1/3;
  }
}
.why-ai__social {
  align-items: center;
  background-color: hsl(214, 100%, 92%);
  border-radius: 3px;
  display: flex;
  padding: 2rem;
}
.why-ai__customer-type {
  background-color: hsl(216, 10%, 95%);
  border-radius: 3px;
  padding: 2rem;
}
@media screen and (min-width: 1024px) {
  .why-ai__customer-type {
    grid-column: 1/3;
    grid-row-start: 3;
  }
}
.why-ai__customer-type > .is-grid {
  display: grid;
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .why-ai__customer-type > .is-grid {
    gap: 2rem;
    grid-template-columns: 1fr 1fr;
  }
}
.why-ai__customer-type > .is-grid > .is-grid-item {
  border-bottom: 1px solid hsl(216, 10%, 80%);
  padding-bottom: 1rem;
}
@media screen and (min-width: 768px) {
  .why-ai__customer-type > .is-grid > .is-grid-item {
    border-bottom: initial;
    padding-bottom: initial;
  }
}
.why-ai__customer-type > .is-grid > .is-grid-item:last-of-type {
  border-bottom: none;
  padding-bottom: initial;
}

.media-grid {
  display: grid;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .media-grid {
    -moz-column-gap: 4rem;
         column-gap: 4rem;
    row-gap: 2rem;
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (min-width: 768px) {
  .media-grid:after {
    background-color: hsl(214, 100%, 52%);
    border: 2px solid hsl(0, 100%, 100%);
    border-radius: 1rem;
    box-shadow: 0 0 0 2px hsl(214, 100%, 52%);
    bottom: -0.5rem;
    content: "";
    display: block;
    height: 1rem;
    left: calc(50% - 0.5 * 1rem);
    position: absolute;
    width: 1rem;
  }
}
.media-grid__item {
  border-bottom: 1px solid hsl(216, 10%, 80%);
  position: relative;
}
.media-grid__item:last-of-type {
  border-bottom: initial;
}
@media screen and (min-width: 768px) {
  .media-grid__item {
    border-bottom: initial;
  }
}
@media screen and (min-width: 768px) {
  .media-grid__item:nth-child(even):after {
    background-color: hsl(216, 10%, 80%);
    content: "";
    display: block;
    height: 100%;
    left: -2rem;
    position: absolute;
    top: 0;
    width: 1px;
  }
}
.media-grid__item > .is-content {
  display: flex;
  gap: 1rem;
  flex-direction: column;
  padding-bottom: 2rem;
}
.media-grid__item .is-graphic {
  max-width: 300px;
}
@media screen and (min-width: 768px) {
  .media-grid__item:nth-child(n+3)::before {
    content: "";
    background-color: hsl(216, 10%, 80%);
    display: block;
    height: 1px;
    margin-top: -1rem;
  }
}
.media-grid__item > .is-content {
  padding-top: 2rem;
}

.badge {
  background-color: hsl(187, 98%, 42%);
  border-radius: 1rem;
  color: hsl(0, 100%, 100%);
  font-size: var(--brevier);
  letter-spacing: 0.05em;
  line-height: 2;
  text-transform: uppercase;
  padding-inline: 0.5rem;
  width: -moz-max-content;
  width: max-content;
}
.badge.is-case-study {
  background-color: hsl(291, 64%, 42%);
}
.badge.is-blog-post {
  background-color: hsl(45, 99%, 51%);
}
.badge.is-small {
  font-size: var(--minion);
}

.squeeze-contact {
  border-radius: 3px;
  margin-inline: -1rem;
  overflow: hidden;
  padding-block-start: 2rem;
  padding-inline: 2rem;
  position: relative;
  width: calc(100% + 2 * 1rem);
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .squeeze-contact {
    margin-inline: -2rem;
    margin-top: -5%;
    padding-top: 15%;
    padding-inline: 20%;
    width: calc(100% + 4 * 1rem);
  }
}
.squeeze-contact:before {
  aspect-ratio: 1/1;
  background: linear-gradient(180deg, rgba(241, 243, 244, 0.5), hsla(0, 0%, 100%, 0) 34.52%);
  border-radius: 50%;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  z-index: -1;
}
.squeeze-contact__action {
  background-color: hsl(214, 100%, 92%);
  border-radius: 3px;
  display: grid;
  gap: 1rem;
  grid-template-areas: "icon message" "icon action";
  grid-template-columns: min-content auto;
  margin-block: 1rem;
  padding: 1rem;
}
@media screen and (min-width: 768px) {
  .squeeze-contact__action {
    align-items: center;
    grid-template-areas: "icon message action";
    grid-template-columns: min-content auto max-content;
  }
}
.squeeze-contact__action > .is-message {
  grid-area: message;
}
.squeeze-contact__action > .is-icon {
  color: hsl(334, 80%, 49%);
  grid-area: icon;
}
.squeeze-contact__action > .is-action {
  grid-area: action;
}
.squeeze-contact__social {
  margin-bottom: 4rem;
  margin-inline: auto;
  margin-top: -2rem;
  max-width: 100%;
  width: 500px;
}
.squeeze-contact__form {
  display: grid;
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .squeeze-contact__form {
    gap: initial;
    grid-template-columns: 1fr 1fr;
  }
}
.squeeze-contact__form > .is-form {
  background-color: hsl(216, 10%, 95%);
  padding: 1rem;
}
@media screen and (min-width: 768px) {
  .squeeze-contact__form > .is-form {
    padding: 2rem;
  }
}
.squeeze-contact__form > .is-aside {
  padding: 1rem;
}
@media screen and (min-width: 768px) {
  .squeeze-contact__form > .is-aside {
    padding: 2rem;
  }
}

.media-scroller {
  display: grid;
  gap: 1rem;
  grid-auto-flow: column;
  grid-auto-columns: 90%;
  padding: 0.25rem;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
}
@media screen and (min-width: 768px) {
  .media-scroller {
    grid-auto-columns: 35%;
  }
}
@media screen and (min-width: 1024px) {
  .media-scroller {
    grid-auto-columns: 21%;
  }
}

.media-group {
  display: grid;
  gap: 1rem;
  grid-auto-flow: column;
}

.media-element {
  background-color: transparent;
  border-radius: 3px;
  color: hsl(216, 10%, 10%);
  cursor: pointer;
  display: grid;
  grid-template-rows: min-content;
  gap: 1rem;
  padding: 0.25rem;
  position: relative;
  transition: all 0.4s;
}
.media-element:hover {
  background-color: hsl(214, 100%, 92%);
  color: hsl(214, 100%, 52%);
}
.media-element:after {
  background-color: hsl(216, 10%, 80%);
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  top: 0;
  right: -0.5rem;
  width: 1px;
}
.media-element:last-of-type::after {
  content: initial;
}
.media-element > .is-badge {
  left: 0.5rem;
  position: absolute;
  top: 0.5rem;
}

.media-element > img {
  inline-size: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}

.snaps-inline {
  scroll-snap-type: inline mandatory;
  scroll-padding-inline: var(1rem, 1rem);
}

.snaps-inline > * {
  scroll-snap-align: start;
}

.sales-banner {
  background-color: #81ddea;
  border-radius: 3px;
  color: #0c3e55;
  display: flex;
  flex-direction: column;
  padding: 1rem;
}
@media screen and (min-width: 768px) {
  .sales-banner {
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
  }
}
.sales-banner__sub {
  display: block;
  font-size: var(--brevier);
  margin-bottom: 1rem;
}
@media screen and (min-width: 768px) {
  .sales-banner__sub {
    display: initial;
    margin-bottom: initial;
  }
}
.sales-banner .is-link {
  align-items: center;
  background-color: hsl(0, 100%, 100%);
  border-radius: 1rem;
  color: hsl(214, 100%, 52%);
  cursor: pointer;
  display: flex;
  height: 2rem;
  justify-content: center;
  padding-inline: 1rem;
  text-transform: uppercase;
  transition: all 0.4s;
  width: -moz-max-content;
  width: max-content;
}
.sales-banner .is-link:hover {
  background-color: hsl(187, 98%, 42%);
  color: hsl(0, 100%, 100%);
}

.squeeze-hero {
  display: grid;
  grid-template-areas: "main" "banner" "segments";
}
@media screen and (min-width: 768px) {
  .squeeze-hero {
    display: block;
  }
}
.squeeze-hero__main {
  grid-area: main;
}
.squeeze-hero__banner {
  grid-area: banner;
}
.squeeze-hero__segments {
  grid-area: segments;
}

.c-panel.has-flex-align {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.logo-grid {
  align-items: center;
  display: grid;
  gap: 3rem;
  grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
  padding: 0;
}
.logo-grid img {
  filter: grayscale(1);
}

.display-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4rem;
  justify-content: center;
}
.display-list__item {
  margin-bottom: 2rem;
  position: relative;
  width: calc(33.33% - 1rem * 4);
}
.display-list__item::after {
  background-color: hsl(216, 10%, 80%);
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  right: -2rem;
  top: 0;
  width: 1px;
}
.display-list__item:nth-child(3n+3):after {
  content: initial;
}
.display-list__item:nth-last-child(1)::after {
  content: initial;
}
.display-list__item > .is-content {
  display: flex;
  flex-direction: column-reverse;
  height: 100%;
}

.section--form fieldset {
  border: none;
}
.section--form .form-columns-1,
.section--form .form-columns-2,
.section--form .hs-form-field > .input {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1rem;
  max-width: 100% !important;
}
.section--form .form-columns-1 > *,
.section--form .form-columns-2 > *,
.section--form .hs-form-field > .input > * {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .section--form .form-columns-2 {
    flex-direction: row;
  }
}
.section--form label {
  font-size: var(--brevier);
  color: hsl(216, 10%, 50%);
}
.section--form input[type=text],
.section--form input[type=email],
.section--form input[type=tel] {
  border: 1px solid hsl(216, 10%, 10%);
  border-radius: 3px;
  font-size: 1rem;
  padding: 0.5rem 1rem;
  transition: all 0.4s;
  width: 100% !important;
}
.section--form input[type=text]:hover, .section--form input[type=text]:focus,
.section--form input[type=email]:hover,
.section--form input[type=email]:focus,
.section--form input[type=tel]:hover,
.section--form input[type=tel]:focus {
  border-color: hsl(214, 100%, 52%);
}

.hs-form-checkbox,
.hs-form-booleancheckbox {
  margin-bottom: 1rem;
}
.hs-form-checkbox-display,
.hs-form-booleancheckbox-display {
  display: flex;
  gap: 1rem;
}
.hs-form-checkbox p,
.hs-form-booleancheckbox p {
  margin-bottom: 0;
}

.legal-consent-container::before {
  background-color: hsl(216, 10%, 10%);
  content: "";
  display: block;
  height: 3px;
  width: 3rem;
}

.hs-richtext {
  font-size: var(--brevier);
}

.hs-recaptcha {
  margin-bottom: 1rem;
}

.hs-fieldtype-checkbox {
  background-color: hsl(216, 10%, 95%);
  border-radius: 3px;
  padding: 1rem;
}

.hs-form-checkbox-display,
.hs-form-booleancheckbox-display {
  color: hsl(216, 10%, 10%) !important;
}

.blog-lister {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1rem;
  margin-inline: auto;
  max-width: 100%;
}
.blog-lister__item {
  border-radius: 3px;
  overflow: hidden;
}
.blog-lister__link {
  background-color: hsl(0, 100%, 100%);
  border: 1px solid hsl(0, 100%, 100%);
  border-radius: 3px;
  color: hsl(216, 10%, 10%);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: space-between;
  transition: border-color 0.4s;
}
.blog-lister__link:hover {
  background-color: hsl(216, 10%, 95%);
  border-color: hsl(214, 100%, 52%);
}
.blog-lister__media {
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: center;
  padding: 1rem;
  padding-bottom: 0;
}
.blog-lister__body {
  padding: 1rem;
}
.blog-lister__body > .is-date {
  color: hsl(216, 10%, 50%);
  margin-bottom: 0.5rem;
}

.blog__preview {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  max-width: 100%;
}
.blog__preview-item {
  flex: 1;
}
.blog__preview-item-link {
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  color: hsl(216, 10%, 10%);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1rem;
  transition: background-color 0.6s;
}
.blog__preview-item-link:hover {
  background-color: hsl(216, 10%, 95%);
}
.blog__preview-item-link:hover > .is-title {
  color: hsl(214, 100%, 52%);
}
.blog__preview-item-link > .is-title {
  font-size: var(--primer);
  color: hsl(216, 10%, 10%);
  font-weight: bold;
  margin-bottom: 0;
  transition: color 0.6s;
}
.blog__preview-image {
  aspect-ratio: 3/2;
  -o-object-fit: contain;
     object-fit: contain;
}
.blog__preview-desc {
  font-size: var(--brevier);
  margin-bottom: 0;
  margin-top: auto;
}
.blog__preview-meta {
  font-size: var(--minion);
  align-items: center;
  color: hsl(216, 10%, 50%);
  display: flex;
  margin-bottom: 0;
}
.blog__preview-meta > .is-author {
  align-items: center;
  display: flex;
}
.blog__preview-meta > .is-author:after {
  color: hsl(216, 10%, 10%);
  content: "|";
  display: block;
  margin-inline: 0.25rem;
}

/*  Page header section */
[class*=c-cover] {
  align-items: center;
  background-color: hsl(0, 100%, 100%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding-block: 5vw;
  padding-inline: 3vw;
  margin-block-end: 1rem;
  margin-block-start: 2vw;
  margin-inline: auto;
  width: 96vw;
}
@media screen and (min-width: 768px) {
  [class*=c-cover] {
    flex-direction: row;
    min-height: 60vh;
  }
}
@media screen and (min-width: 1024px) {
  [class*=c-cover] {
    padding-inline: 5vw;
  }
}
@media screen and (min-width: 1500px) {
  [class*=c-cover] {
    padding-inline: 10vw;
  }
}

@media screen and (min-width: 1500px) {
  .c-cover > .is-focus {
    width: 70%;
  }
}
.c-cover--primary {
  background-color: hsl(52, 100%, 50%);
}
.c-cover--quiet {
  background-color: hsl(200, 18%, 80%);
}

.features__table {
  border-collapse: collapse;
  margin-bottom: 1rem;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .features__table {
    border: 3px solid hsl(0, 100%, 100%);
    border-spacing: 0;
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .features__table .is-group {
    border-bottom: 1px solid hsl(216, 10%, 80%);
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 0.5rem;
    padding-bottom: 1rem;
  }
}
.features__table .is-group > td {
  font-size: var(--minion);
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .features__table .is-group > td {
    font-size: var(--brevier);
    margin-bottom: 0;
  }
}
.features td,
.features th {
  padding: 0.5rem;
}
@media screen and (min-width: 768px) {
  .features td,
  .features th {
    padding: 0;
  }
}
.features__table-body {
  background-color: hsl(0, 100%, 100%);
  border: 3px;
  border-radius: 3px;
  border-top-right-radius: 0;
}
@media screen and (max-width: 768px) {
  .features__table-body tr {
    display: flex;
    flex-wrap: wrap;
  }
}
.features__table-body tr:last-of-type {
  border-bottom: none;
}
@media screen and (max-width: 768px) {
  .features__table-head {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }
}
.features__group {
  margin-bottom: 1rem;
}
@media screen and (min-width: 768px) {
  .features__group {
    margin-bottom: 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .features__group .is-heading {
    margin-bottom: -1rem;
  }
}
@media screen and (max-width: 768px) {
  .features tbody,
  .features tr,
  .features th,
  .features td {
    padding: 0;
    text-align: left;
    white-space: normal;
  }
}
@media screen and (max-width: 768px) {
  .features tr td,
  .features tr th {
    border: 1px solid hsl(216, 10%, 80%);
    border-top: none;
    padding-block: 0.5rem;
    padding-inline: 1rem;
    overflow: hidden;
    position: relative;
    vertical-align: top;
    width: 100%;
    white-space: normal;
  }
}
.features th[scope=row] {
  border: none;
}
@media screen and (max-width: 768px) {
  .features th[scope=row] {
    background-color: hsl(0, 100%, 100%);
    display: block;
    margin-inline: auto;
    padding: 0;
    width: 100%;
  }
}
.features td[data-header] {
  background-color: hsl(216, 10%, 95%);
  border: 2px solid hsl(0, 100%, 100%);
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .features td[data-header] {
    width: 33.3%;
  }
}
.features td[data-header].is-included {
  background-color: hsl(156, 78%, 85%);
}
.features td[data-header].is-excluded {
  color: hsl(216, 10%, 50%);
}
@media screen and (max-width: 768px) {
  .features td[data-header].is-included > .is-icon, .features td[data-header].is-excluded > .is-icon {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .features td[data-header]:before {
    content: attr(data-header);
    display: block;
    float: left;
  }
}
@media screen and (max-width: 768px) {
  .features td[data-header]:after {
    content: "";
    display: block;
    left: 0;
    padding-bottom: 200%;
    position: absolute;
    top: 0;
    width: 50%;
  }
}
.features td[data-header] .is-icon {
  color: hsl(216, 10%, 50%);
  display: flex;
  justify-content: center;
}
.features td[data-header] .is-yes {
  color: hsl(214, 100%, 52%);
}

.feature__header-type {
  font-size: var(--minion);
  color: hsl(0, 100%, 100%);
  margin-bottom: 0;
  width: 150px;
}
@media screen and (max-width: 768px) {
  .feature__header-type {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .feature__header-type {
    font-size: var(--brevier);
    margin-bottom: 0;
  }
}
@media screen and (min-width: 1024px) {
  .feature__header-type {
    width: 200px;
  }
}
.feature__header-type.is-pc-lite {
  background-color: hsl(216, 10%, 50%);
  border-top-left-radius: 3px;
}
.feature__header-type.is-pc {
  background-color: hsl(214, 100%, 52%);
}
.feature__header-type.is-occ {
  background-color: hsl(156, 78%, 43%);
  border-top-right-radius: 3px;
}
.feature__header-type.is-pc-lite, .feature__header-type.is-pc, .feature__header-type.is-occ {
  padding: 0.5rem;
}
@media screen and (min-width: 768px) {
  .feature__header-type.is-pc-lite, .feature__header-type.is-pc, .feature__header-type.is-occ {
    padding-block: 0.5rem;
    padding-inline: 1rem;
  }
}
.feature__expander {
  border: 3px solid hsl(0, 100%, 100%);
  border-radius: 3px;
}
@media screen and (min-width: 768px) {
  .feature__expander {
    border-width: 1px;
    padding: 0.5rem;
  }
}
.features__table-body > .is-group:last-of-type .feature__expander {
  border-bottom: none;
}

.feature__expander > .is-description {
  font-size: var(--brevier);
  display: none;
  padding-inline: 0.5rem;
}
@media screen and (min-width: 768px) {
  .feature__expander > .is-description {
    padding-inline: initial;
  }
}
.feature__expander > .is-title {
  font-size: var(--primer);
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .feature__expander > .is-title {
    font-weight: normal;
  }
}
.feature__expander-link {
  align-items: center;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding-inline: 0.5rem;
  transition: color 0.4s;
}
@media screen and (min-width: 768px) {
  .feature__expander-link {
    justify-content: initial;
    padding-inline: initial;
  }
}
.feature__expander-link:after {
  border-style: solid;
  border-width: 2px 2px 0 0;
  color: hsl(216, 10%, 50%);
  content: "";
  display: inline-block;
  height: 0.5rem;
  position: relative;
  top: -0.1rem;
  transform: rotate(135deg);
  vertical-align: top;
  width: 0.5rem;
}
.feature__expander-link:hover {
  color: hsl(214, 100%, 52%);
}

/*  Needs building out further to be properly useful */
.o-flex-pair {
  align-items: center;
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
.o-flex-pair.is-spaced {
  justify-content: space-between;
}

/*  Example usage
    <li class="card-grid__item">
        <div class="o-feature-icon">
            <span class="material-icons"> icon_name </span>
        </div>
        <div>
            ...
        </div>
    </li>
*/
.o-feature-icon {
  align-items: center;
  background-color: hsl(45, 99%, 51%);
  border-radius: 50%;
  color: hsl(0, 100%, 100%);
  display: flex;
  height: 3rem;
  justify-content: center;
  width: 3rem;
}

.features-list > .card-grid__item:nth-child(9n+1) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+1) .o-feature-icon {
  background-color: hsl(45, 99%, 51%);
}
.features-list > .card-grid__item:nth-child(9n+2) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+2) .o-feature-icon {
  background-color: hsl(231, 48%, 51%);
}
.features-list > .card-grid__item:nth-child(9n+3) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+3) .o-feature-icon {
  background-color: hsl(187, 98%, 42%);
}
.features-list > .card-grid__item:nth-child(9n+4) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+4) .o-feature-icon {
  background-color: hsl(182, 54%, 38%);
}
.features-list > .card-grid__item:nth-child(9n+5) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+5) .o-feature-icon {
  background-color: hsl(65, 68%, 54%);
}
.features-list > .card-grid__item:nth-child(9n+6) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+6) .o-feature-icon {
  background-color: hsl(334, 80%, 49%);
}
.features-list > .card-grid__item:nth-child(9n+7) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+7) .o-feature-icon {
  background-color: hsl(122, 50%, 52%);
}
.features-list > .card-grid__item:nth-child(9n+8) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+8) .o-feature-icon {
  background-color: hsl(199, 76%, 19%);
}
.features-list > .card-grid__item:nth-child(9n+9) .o-feature-icon,
.features-list > .c-use-case__item:nth-child(9n+9) .o-feature-icon {
  background-color: hsl(291, 64%, 42%);
}

/* ------------------------------------------------------------------------- *\
    <ul class="feature-link-display">
        <li class="feature-link__item has-link">
            <a href="" class="is-link">
                <div class="is-image has-focus">
                    <img src="..." alt="..."  />
                </div>
                <h3 class="is-title">...</h3>
                <p>....</p>
            </a>
        </li>
        ...
    </ul>

    Works well partnered with .card-grid eg:
    <ul class="feature-link-display card-grid">
        <li class="feature-link__item card-grid__item has-link">...</li>
        ...
    </ul>

\* ------------------------------------------------------------------------ */
.feature-link-display > .feature-link__item {
  color: hsl(0, 100%, 100%);
  cursor: pointer;
}
.feature-link-display > .feature-link__item > .is-link {
  background-color: inherit;
  border: 2px solid hsl(0, 100%, 100%);
  border-radius: 3px;
  color: hsl(216, 10%, 10%);
  height: 100%;
  transition: background-color 0.4s;
}
.feature-link-display > .feature-link__item .is-title {
  font-size: var(--long-primer);
  line-height: 1.3;
  font-weight: bold;
  margin-top: auto;
}
.feature-link-display > .feature-link__item:nth-child(9n+1) > .is-link {
  background-color: hsl(45, 99%, 67%);
}
.feature-link-display > .feature-link__item:nth-child(9n+1) > .is-link:hover {
  background-color: hsl(45, 99%, 51%);
}
.feature-link-display > .feature-link__item:nth-child(9n+2) > .is-link {
  background-color: hsl(231, 44%, 68%);
}
.feature-link-display > .feature-link__item:nth-child(9n+2) > .is-link:hover {
  background-color: hsl(231, 48%, 51%);
}
.feature-link-display > .feature-link__item:nth-child(9n+3) > .is-link {
  background-color: hsl(187, 70%, 56%);
}
.feature-link-display > .feature-link__item:nth-child(9n+3) > .is-link:hover {
  background-color: hsl(187, 98%, 42%);
}
.feature-link-display > .feature-link__item:nth-child(9n+4) > .is-link {
  background-color: hsl(182, 34%, 54%);
}
.feature-link-display > .feature-link__item:nth-child(9n+4) > .is-link:hover {
  background-color: hsl(182, 54%, 38%);
}
.feature-link-display > .feature-link__item:nth-child(9n+5) > .is-link {
  background-color: hsl(65, 68%, 65%);
}
.feature-link-display > .feature-link__item:nth-child(9n+5) > .is-link:hover {
  background-color: hsl(65, 68%, 54%);
}

.feature-link__item .has-focus {
  position: relative;
  width: -moz-max-content;
  width: max-content;
}
.feature-link__item .has-focus img {
  position: relative;
  z-index: 1;
}
.feature-link__item .has-focus::after {
  background-color: rgba(255, 255, 255, 0.4);
  border-radius: 50%;
  border: 2px solid hsl(0, 100%, 100%);
  content: "";
  display: block;
  height: 150px;
  left: calc(50% - 75px);
  position: absolute;
  top: 1rem;
  width: 150px;
  z-index: 0;
}

.accordion__container {
  overflow: hidden;
}
.accordion__item {
  border-radius: 3px;
  margin-bottom: 2px;
  overflow: hidden;
  transition: all 0.4s;
  width: 100%;
}
.accordion__icon {
  align-items: center;
  display: flex;
}
.accordion__trigger {
  background-color: hsl(0, 100%, 100%);
  border: none;
  cursor: pointer;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  line-height: 1.5;
  padding: 1rem;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .accordion__trigger {
    align-items: center;
  }
}
.accordion__trigger:hover {
  background-color: hsl(214, 100%, 92%);
}
.accordion__title {
  align-items: center;
  display: flex;
  gap: 1rem;
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .accordion__title {
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 1024px) {
  .accordion__title {
    gap: 2rem;
  }
}
.accordion__title-media {
  display: none;
  visibility: hidden;
}
@media screen and (min-width: 768px) {
  .accordion__title-media {
    display: block;
    visibility: initial;
  }
}
.accordion__title-intro {
  max-width: 80ch;
}
.accordion__item.is-active .accordion__icon {
  transform: rotate(180deg);
}

.accordion__content {
  height: 0;
  overflow: hidden;
  transition: 0.4s;
}

.c-accordion__content {
  background-color: hsl(0, 100%, 100%);
  border-top: 1px solid hsl(216, 10%, 80%);
  font-size: var(--brevier);
  gap: 1rem;
  padding: 1rem;
}
@media screen and (min-width: 1024px) {
  .c-accordion__content {
    align-items: center;
    flex-direction: row;
    gap: 2rem;
    padding: 2rem;
  }
}
.c-accordion__content p {
  margin-bottom: 1rem;
}

.c-callout {
  background-color: hsl(214, 100%, 92%);
  border-radius: 3px;
  margin-bottom: 2rem;
  padding: 2rem;
  position: relative;
}
.c-callout > * {
  position: relative;
  z-index: 1;
}
.c-callout:after {
  border-top: 2rem solid transparent;
  border-right: 2rem solid transparent;
  border-bottom: 2rem solid transparent;
  border-left: 2rem solid hsl(214, 100%, 92%);
  bottom: -32px;
  content: "";
  display: block;
  height: 2rem;
  position: absolute;
  width: 2rem;
}

[class*=o-banner] {
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-block: 1rem;
  padding-inline: 1rem;
  margin-inline: auto;
  min-height: 80px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  [class*=o-banner] {
    align-items: center;
    flex-direction: row;
    padding-inline: 2rem;
  }
}
@media screen and (min-width: 768px) {
  [class*=o-banner] > .is-action {
    margin-left: auto;
  }
}

.o-banner--featured {
  background-color: hsl(52, 100%, 50%);
}
.o-banner--featured > .is-icon {
  color: hsl(187, 98%, 42%);
}
.o-banner--alt-feature {
  background-color: hsl(187, 98%, 42%);
  color: hsl(0, 100%, 100%);
}
.o-banner--alt-feature > .is-icon {
  color: hsl(52, 100%, 50%);
}

[class*=o-section] {
  padding-block: 2rem;
}

.o-section--featured {
  background-color: hsl(52, 100%, 50%);
}
.o-section--featured {
  background-color: hsl(52, 100%, 50%);
}

.o-section__header {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .o-section__header {
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
  }
}
.o-section__header > .is-title {
  font-size: var(--long-primer);
  line-height: 1.3;
  display: flex;
  gap: 1rem;
  font-weight: bold;
}
.o-section__header > .is-title::before {
  content: "/";
}
.o-section--featured .o-section__header > .is-title::before {
  color: hsl(187, 98%, 42%);
}

.c-ticket-overflow {
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
  overflow: hidden;
  width: 100%;
}

.c-ticket__holder {
  display: grid;
  grid-template-columns: repeat(4, 300px);
  overflow: auto;
}
@media screen and (min-width: 1200px) {
  .c-ticket__holder {
    grid-template-columns: repeat(4, 1fr);
  }
}
.c-ticket__item {
  background: rgb(241, 242, 244);
  background: linear-gradient(90deg, rgb(241, 242, 244) 0%, rgb(247, 248, 251) 100%);
  border-radius: 6px;
  border-right: 1px solid hsl(0, 100%, 100%);
  padding: 1rem;
}
.c-ticket__item:last-of-type {
  border-right: initial;
}
.c-ticket__item > .is-image {
  display: block;
  max-width: 240px;
}
.c-ticket__item > .is-title {
  align-items: center;
  display: flex;
  gap: 1rem;
}
.c-ticket__item > .is-title:before {
  color: hsl(214, 100%, 52%);
  content: "/";
  display: block;
  font-weight: bold;
}

.c-gant-group__title {
  align-items: center;
  display: flex;
  gap: 1rem;
}
.c-gant-group__title > .is-label {
  font-weight: bold;
}
.c-gant-group__title > .is-icon {
  align-items: center;
  border-radius: 50%;
  color: hsl(0, 100%, 100%);
  display: flex;
  height: 40px;
  justify-content: center;
  width: 40px;
}
.c-gant-group__title > .is-icon.is-positive {
  background-color: hsl(214, 100%, 52%);
}
.c-gant-group__title > .is-icon.is-negative {
  background-color: hsl(334, 80%, 62%);
}

.c-use-case__item {
  align-items: center;
  background-color: hsl(0, 100%, 100%);
  border-radius: 3px;
  display: grid;
  grid-template-areas: "icon title" ". media" ". main ";
  grid-template-columns: min-content 1fr;
  -moz-column-gap: 1rem;
       column-gap: 1rem;
  margin-bottom: 1rem;
  padding: 1rem;
}
@media screen and (min-width: 768px) {
  .c-use-case__item {
    grid-template-areas: "icon title ." ". main media";
    grid-template-columns: min-content 1fr 300px;
  }
}
.c-use-case__item > .is-icon {
  grid-area: icon;
}
.c-use-case__item > .is-title {
  font-size: var(--long-primer);
  line-height: 1.3;
  font-weight: bold;
  grid-area: title;
}
.c-use-case__item > .is-article {
  grid-area: main;
}
.c-use-case__item > .is-media {
  grid-area: media;
  padding-inline: 1rem;
}/*# sourceMappingURL=styles.css.map */