:root {
  --color-primary: #f4d547;
  --color-secondary: #ef7e8f;
  --color-accent: #ff9254;
  --color-accent-soft: #fff0dc;
  --color-bg: #fff8f0;
  --color-bg-muted: #fff1dd;
  --color-bg-dark: #2f241d;
  --color-surface: #ffffff;
  --color-fg: #2d241d;
  --color-fg-on-light: #2d241d;
  --color-fg-on-dark: #fff8ef;
  --color-border: #e1cbb5;
  --color-border-strong: #b49170;
  --color-success: #118948;
  --color-error: #a23b2a;
  --color-alert: #c97717;
  --color-overlay: rgba(23, 16, 8, 0.48);
  --color-shadow: rgba(48, 32, 20, 0.14);
  --shadow-soft: 0 20px 45px rgba(48, 32, 20, 0.12);
  --shadow-strong: 0 30px 60px rgba(48, 32, 20, 0.18);
  --radius: var(--radius-md);
  --site-header-height: clamp(72px, 10vw, 94px);
  --font-body: "Rubik", system-ui, sans-serif;
  --font-heading: "Rubik", system-ui, sans-serif;
  --font-display: "Rubik", system-ui, sans-serif;
  --font-script: "Lobster", cursive;
}

/*<editor-fold desc="Generic">*/
:root {
  --primary-color: #FFD425;
  --primary-color-soft: #FFE063;
  --secondary-color: #231F20;
  --tertiary-color: #ffffff;
  --accent-color: #E9E3DE;
  --detail-color: #F4F4F4;
  --decorative-font: 'Lobster', cursive;
  --default-font: 'Rubik', sans-serif;
  --text-color-primary: #998871;
  --form-active-outline: #ddd;
  --form-inactive-outline: #ddd;
  --form-active-background: #fff;
  --form-inactive-background: #eee;
  --form-active-font: var(--secondary-color);
  --form-inactive-font: #aaa;
  --form-active-button: var(--primary-color);
  --form-inactive-button: var(--form-inactive-font);
  --form-active-button-border: #F5C400;
  --form-inactive-button-border: #F5C400;
  --overlay-color: #443322a0;
  --fixed-max-width: 1000px;
  --fixed-width: calc(100vw - 60px);
  --border-radius: 12px;
  --border-radius-small: 7px;
  --border-radius-large: calc(var(--border-radius) + calc(var(--padding-small) * .8));
  --padding-large: 32px;
  --padding-medium: 16px;
  --padding-small: 8px;
  --padding-tiny: 4px;
  --padding-text: .4rem .6rem;
  --header-space-top: 50px;
  --header-logo-height: 140px;
  --header-nav-height: 50px;
  --header-logo-buffer: calc(-1 * calc(calc(var(--header-logo-height) - var(--header-nav-height)) / 2));
  --header-total-padding: calc(calc(calc(var(--header-space-top) + var(--header-nav-height)) - var(--header-logo-buffer)) + 20px);
  font-family: "Rubik", sans-serif;
  font-size: 18px;
}

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

*[id]:target {
  scroll-margin-top: calc(var(--header-space-top) + var(--header-nav-height) - var(--header-logo-buffer));
}

html, body {
  max-width: 100%;
  overflow-x: hidden;
}

body {
  margin: 0;
  color: #231F20;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

a {
  text-decoration: none;
  font-weight: 700;
  color: #231F20;
}

a:hover {
  text-decoration: none;
}

/*a:hover {
    text-decoration: underline;
}*/
/*a.block-link:hover, nav a:hover, a.lifted-panel, a.a-button {
    text-decoration: none;
}*/
h1 {
  font-size: 2.7em;
}

.p1 {
  font-size: 1.2rem;
  font-weight: 200;
  line-height: 1.5;
}

.fancy-header {
  align-self: flex-start;
  position: relative;
  z-index: 1;
}

.fancy-header:after {
  position: absolute;
  content: "";
  background-color: var(--primary-color-soft);
  right: -10px;
  left: -10px;
  bottom: 0;
  height: 0.4em;
  border-radius: 4px;
  z-index: -1;
}

h2 {
  font-size: 2em;
  line-height: 1;
}

h3 {
  font-size: 1.5em;
}

h4 {
  font-size: 1.5em;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
}

hr {
  border-top: 2px solid var(--secondary-color);
  width: 100%;
}

main {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--padding-large);
  padding: 60px 0;
  flex-grow: 1;
}

p {
  margin: 0;
}

.tag {
  font-size: 0.85rem;
  font-weight: 800;
  text-transform: uppercase;
}

.p-body {
  font-weight: 200;
  line-height: 1.5;
  font-size: 1.2rem;
}

.p-mini {
  font-size: 0.8rem;
}

ul {
  margin: 0;
  list-style-type: none;
  padding: 0;
}

input.toggle[type=checkbox] {
  position: relative;
  border: 0;
  outline: 0;
  -webkit-appearance: none;
  height: 44px;
  cursor: pointer;
  width: 76px;
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
}

input.toggle[type=checkbox]:before {
  content: "";
  display: block;
  background-color: #f3f3f3;
  border: 1px solid #ddd;
  border-radius: 100px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: 150ms;
  margin: 7px;
  box-shadow: inset 0 1px 3px 0 rgba(0, 0, 0, 0.1882352941), inset 0 1px 1px 0 rgba(0, 0, 0, 0.3137254902);
}

input.toggle[type=checkbox]:after {
  content: "X";
  color: #d04020;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  width: 38px;
  height: 38px;
  position: absolute;
  border-radius: 100px;
  background-color: #fff;
  border: 1px solid #ccc;
  transition: 150ms;
  z-index: 100;
  box-sizing: border-box;
  margin: 3px;
  margin-right: 100%;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.1882352941), inset 0 -1px 1px 0 rgba(122, 98, 0, 0.1882352941), inset 0 1px 1px 0 rgba(255, 255, 255, 0.1882352941);
}

input.toggle[type=checkbox]:checked:after {
  /*background-color: var(--primary-color);
  border: 1px solid #F5C400;*/
  margin-left: calc(100% - 41px);
  margin-right: 3px;
  content: "O";
  color: #3ABF5B;
}

input.toggle[type=checkbox]:disabled, input.toggle[type=checkbox][readonly] {
  cursor: unset;
}

input.toggle[type=checkbox]:checked:before {
  background-color: #3ABF5B;
}

input.toggle[type=checkbox]:disabled:before, input.toggle[type=checkbox][readonly]:before {
  background-color: #eee;
  box-shadow: none;
}

input.toggle[type=checkbox]:disabled:after, input.toggle[type=checkbox][readonly]:after {
  box-shadow: none;
  background-color: #ccc;
  color: #fff;
}

input[type=submit], button {
  cursor: pointer;
  border: none;
}

@font-face {
  font-family: "icons";
  src: url("/resources/fonts/icons_2_2.eot");
  src: url("/resources/fonts/icons_2_2.woff") format("woff"), url("/resources/fonts/icons_2_2.ttf") format("truetype"), url("/resources/fonts/icons_2_2.svg#filename") format("svg");
}
.grecaptcha-badge {
  visibility: hidden;
}

/*</editor-fold>*/
/*<editor-fold desc="Generic Custom">*/
.button {
  display: block;
}

.button-wrapper {
  min-height: 44px;
}

button.button-wrapper {
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: inherit;
  font: inherit;
  text-align: inherit;
}

.button-trendy {
  border: 2px solid var(--secondary-color);
  padding: var(--padding-text);
  border-radius: var(--border-radius);
  box-shadow: 2px 2px 0 0 var(--secondary-color);
  transition: 75ms;
  background: var(--tertiary-color);
  height: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 700;
}

.button-trendy.yellow {
  background: var(--primary-color-soft);
}

.button-label {
  display: flex;
  flex-direction: row;
  gap: 0.4em;
}

.button-trendy .icon {
  font-size: 1.2em;
}

.button-wrapper:hover .button-trendy {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 0 var(--secondary-color);
}

.a-button, input[type=submit]:not(.button-wrapper):not(.button-trendy), button:not(.button-wrapper):not(.button-trendy) {
  border-radius: 8px;
  background-color: var(--primary-color);
  font-weight: 600;
  padding: 5px 10px;
  text-align: center;
  transition: 75ms;
  min-height: 44px;
}

.a-button span {
  font-size: 0.8em;
  font-weight: 400;
}

.a-button:hover, input[type=submit]:not([disabled]):not(.button-wrapper):not(.button-trendy):hover, button:not([disabled]):not(.button-wrapper):not(.button-trendy):hover {
  background-color: var(--secondary-color);
  color: var(--tertiary-color);
}

.fixed-width {
  align-self: center;
  width: var(--fixed-width);
  max-width: var(--fixed-max-width);
}

.fixed-width.small {
  max-width: 600px;
}

.fixed-width.medium {
  max-width: 900px;
}

.content-lister {
  display: flex;
  flex-direction: column;
  gap: var(--padding-medium);
}

.content-lister.horizontal {
  flex-direction: row;
}

.content-list.center {
  justify-content: center;
}

.content-text {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 20px;
  font-size: 1.2em;
  font-weight: 100;
  line-height: 1.5;
}

.default-display {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.default-display h2 {
  margin: 20px 0;
}

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

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

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

.center-content {
  align-items: center;
  justify-content: center;
  text-align: center;
}

.brand-span {
  font-family: "Lobster", cursive;
}

.image-wrapper-contain, .image-wrapper-cover {
  position: relative;
  overflow: hidden;
}

.image-wrapper-contain > img {
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
}

.image-wrapper-cover > img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.sub-text {
  font-size: 0.8rem;
  font-weight: 100;
  display: block;
  color: #888;
}

.sub-alert-text {
  font-size: 0.8rem;
  font-weight: 600;
  display: block;
  color: #DA4C3C;
}

.small-heading {
  font-weight: 700;
  font-size: 0.85em;
}

.small-link {
  font-weight: unset;
}

.faded-font {
  color: #888;
}

.lifted-panel {
  border: 1px solid #e5e5e5;
  border-radius: 20px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.0941176471), inset 0 1px 0 0 white;
  background-color: #f8f8f8;
}

a.lifted-panel:hover {
  background-color: white;
  border-color: #ddd;
}

.lifted-box {
  background-color: var(--tertiary-color);
  box-shadow: 5px 5px 0 0 var(--secondary-color);
}

.lifted-box.content-text {
  padding: 15px 25px;
}

.style-light-1 {
  border: 1px solid #ddd;
  border-radius: 20px;
  padding: var(--padding-medium);
}

.peek-top {
  margin-top: -100px;
}

.icon {
  font-family: "icons", sans-serif;
  font-weight: 100;
}

.promo-box {
  border: 4px solid var(--secondary-color);
  padding: 15px;
  border-radius: 5px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  font-size: 1.3em;
  transition: 75ms;
  gap: 20px;
}

.promo-box:hover {
  background-color: var(--secondary-color);
  color: var(--tertiary-color);
}

.promo-icons {
  display: flex;
  flex-direction: row;
  font-size: 2.5em;
  gap: 15px;
}

.stylish-text {
  font-size: 1em;
  font-weight: 100;
}

.stylish-text h4 {
  font-size: 0.8em;
  font-weight: 600;
}

.icon-text {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  flex-basis: 0;
  flex-grow: 1;
}

.icon-text > .icon {
  font-size: 2em;
}

.icon-text > p {
  font-weight: 600;
  text-align: left;
}

.decorative-list {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 20px;
}

.decorative-list li {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 20px;
}

.dl-number-wrapper {
  background-color: var(--secondary-color);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  flex-shrink: 0;
  position: relative;
}

.dl-number, .dl-number-background {
  color: var(--tertiary-color);
  font-family: "Lobster", cursive;
  font-size: 3em;
  position: absolute;
  top: -10px;
  left: -5px;
  line-height: 1;
  width: 40px;
  text-align: center;
}

.dl-number-background {
  color: var(--secondary-color);
  -webkit-text-stroke: 8px var(--secondary-color);
}

.dl-content {
  display: flex;
  flex-direction: column;
}

.full-column {
  display: flex;
  flex-direction: column;
  justify-content: stretch;
  gap: 10px;
  padding: 10px;
}

.row {
  display: flex;
  flex-direction: row;
  gap: 10px;
}

.full-row {
  display: flex;
  flex-direction: row;
  justify-content: stretch;
  align-items: stretch;
  gap: 10px;
}

.full-row > * {
  flex-grow: 1;
}

.equal-width > * {
  flex: 1 0 0;
}

.horizontal-list {
  display: flex;
  flex-direction: row;
  gap: var(--padding-small);
  flex-wrap: wrap;
}

.horizontal-list-fixed {
  display: grid;
  gap: var(--padding-small);
  grid-template-columns: repeat(2, 1fr);
}

.horizontal-display {
  display: flex;
  flex-direction: row;
  gap: var(--padding-small);
}

.horizontal-display > * {
  flex-grow: 1;
}

.vertical-display {
  display: flex;
  flex-direction: column;
  gap: var(--padding-large);
}

.vertical-list {
  display: flex;
  flex-direction: column;
  gap: var(--padding-small);
}

.vertical-list-tiny {
  display: flex;
  flex-direction: column;
  gap: var(--padding-tiny);
}

.vertical-list-medium {
  display: flex;
  flex-direction: column;
  gap: var(--padding-medium);
}

.columns {
  display: flex;
  flex-direction: row;
  gap: var(--padding-large);
  align-items: stretch;
  flex-wrap: wrap;
}

.display-columns {
  display: flex;
  flex-direction: row;
  gap: var(--padding-large);
  align-items: stretch;
}

.display-columns > * {
  flex: 1 0 0;
}

.columns-small {
  display: flex;
  flex-direction: row;
  gap: var(--padding-small);
  align-items: stretch;
  flex-wrap: wrap;
}

.columns-small > * {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  flex: 1 0 0;
}

.columns > * {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  flex: 1 0 0;
}

.columns .column-icon {
  max-width: 210px;
}

.box-padding {
  padding: 10px;
}

.no-gap {
  gap: 0;
}

.no-gap > *:not(.full-width) {
  margin-top: var(--padding-large);
}

.full-width {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.full-width.style {
  padding: var(--padding-large) 0;
}

.full-width:has(.background-image-overlay) {
  color: var(--tertiary-color);
}

.background-image-wrapper {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -100;
}

.background-image-overlay {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: var(--overlay-color);
}

.background-image-wrapper > img.background-image {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -100;
}

.info-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  padding-left: var(--padding-medium);
}

.info-text:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  background-color: var(--primary-color);
  border-radius: 2px;
  width: 7px;
}

.info-text h3 {
  font-size: 1em;
  position: relative;
}

.info-text p {
  font-weight: 100;
}

.info-text .em-text {
  font-size: 1.8em;
  font-weight: 100;
}

.stylized-text {
  font-family: "Lobster", cursive;
}

.giant-text {
  font-size: 4em;
}

.bold {
  font-weight: 500;
}

.mini-heading {
  font-weight: 700;
  font-size: 0.75rem;
  text-transform: uppercase;
}

.mini-link {
  font-size: 0.85rem;
  color: var(--text-color-primary);
}

.mini-link:hover {
  text-decoration: none;
}

.small-caps {
  text-transform: uppercase;
}

.small-caps-bold {
  text-transform: uppercase;
  font-weight: 800;
  font-size: 1rem;
}

/*</editor-fold>*/
/*<editor-fold desc="Header">*/
/*header {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 20px;
}

#header-wrapper {
    background-color: #FFD425;
    background-image: url("/media/images/background-design-primary.jpg");
    background-repeat: repeat;
    background-attachment: fixed;
}

#header-upper {
    height: 250px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
    z-index: 100;
}

#logo-container {
    height: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

#header-logo {
    height: 400px;
}

#header-picture-wrapper {
    background-color: #231F20;
    height: 400px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
}

.header-picture {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
    filter: brightness(.5);
    object-position: 65% 50%;
}

#header-picture-wrapper h2 {
    color: white;
    z-index: 1;
    position: relative;
    text-align: right;
    margin-bottom: 20px;
    font-size: 2.5em;
}

#header-lower {
    height: 30px;
}

#header-content-wrapper {
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
}

#nav-wrapper {
    transition: height 400ms;
    overflow: hidden;
    padding: 8px;
}

nav {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    font-size: 1.5em;
    gap: 5px;
}

nav a {
    padding: 4px 8px 3px;
    position: relative;
}

nav a::before {
    position: absolute;
    display: block;
    content: " ";
    top: 0;
    right: 0;
    left: 100%;
    bottom: 0;
    background-color: white;
    z-index: 0;
    transition: 250ms;
    border-radius: 3px;
}

nav a:hover::before {
    left: 0;
}

nav a > p {
    z-index: 100;
    position: relative;
    margin: 0;
}

#hamburger-menu {
    display: none;
    font-size: 2em;
    position: absolute;
    top: 0;
    right: 0;
    width: 70px;
    height: 70px;
    text-align: center;
    cursor: pointer;
}*/
/*</editor-fold>*/
/*<editor-fold desc="header-new">*/
.site-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  position: relative;
}

.site-header--simple {
  min-height: var(--header-total-padding);
  background-color: var(--primary-color);
  background-image: linear-gradient(#F9E069, #F8CE50);
}

.site-header--overlay {
  min-height: 0;
  background: transparent;
}

.site-hero-banner {
  min-height: 650px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  background-color: var(--primary-color);
  background-image: linear-gradient(#F9E069, #F8CE50);
}

.site-hero-banner--with-copy {
  min-height: 450px;
}

.header-media-wrapper {
  width: 100%;
  height: 100%;
  position: absolute;
}

.header-media-wrapper > img, .header-media-wrapper > video {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.nav-wrapper {
  width: var(--fixed-width);
  max-width: var(--fixed-max-width);
  background-color: var(--tertiary-color);
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: stretch;
  border-radius: var(--border-radius);
  z-index: 1000;
  position: fixed;
  top: var(--header-space-top);
  box-shadow: 0 0 1px 0 rgba(0, 0, 0, 0.6274509804), 0 0 5px 0 rgba(0, 0, 0, 0.1254901961);
}

#header-logo {
  height: var(--header-logo-height);
  margin: var(--header-logo-buffer) 0 var(--header-logo-buffer) 20px;
  display: block;
}

nav {
  display: flex;
  align-items: stretch;
  flex-direction: row;
  padding: var(--padding-tiny) var(--padding-large);
  gap: var(--padding-small) var(--padding-large);
  flex-wrap: wrap;
}

nav a {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

nav a span {
  position: relative;
}

nav a span:after {
  position: absolute;
  left: -5px;
  right: calc(100% + 5px);
  bottom: 0;
  height: 10px;
  content: "";
  background-color: var(--primary-color);
  transition: 250ms ease-out;
  border-radius: 2px;
  z-index: -100;
}

nav a:hover span:after {
  left: -5px;
  right: -5px;
}

.header-bottom-pattern {
  --bottom-pattern-height: 20px;
  --pottom-pattern-width: calc(var(--bottom-pattern-height) * calc(428 / 60));
  background-image: url(/media/vectors/wave-shadow.png);
  background-size: contain;
  background-repeat: repeat-x;
  height: 20px;
  position: absolute;
  bottom: 0;
  width: 100%;
  animation: pan 6s linear infinite;
}

@keyframes pan {
  from {
    background-position: 0;
  }
  to {
    background-position: var(--pottom-pattern-width);
  }
}
.nav-toggle-wrapper {
  display: none;
}

.header-banner-overlay {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: var(--overlay-color);
  padding: calc(var(--header-space-top) + var(--header-nav-height)) 0 var(--header-nav-height);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tertiary-color);
}

.header-banner-overlay > * {
  width: var(--fixed-width);
  max-width: var(--fixed-max-width);
  text-align: center;
}

/*</editor-fold>*/
/*<editor-fold desc="Footer">*/
footer {
  position: relative;
  background-color: var(--secondary-color);
  margin-top: 120px;
  color: var(--tertiary-color);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 30px;
}

.footer-socials {
  display: flex;
  flex-direction: row;
  gap: 16px;
}

.footer-socials a {
  color: var(--tertiary-color);
  font-size: 2em;
}

.block-link {
  min-height: 44px;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
}

.block-button {
  min-height: 44px;
  padding: 5px 9px 4px;
  transition: 75ms;
  border-radius: 8px;
  color: var(--secondary-color);
}

.block-button.icon {
  padding: 5px;
}

/*.block-button.alert-text {
    color: #DA4C3C;
}

.block-button:hover {
    background-color: var(--secondary-color);
    color: var(--tertiary-color);
}

.block-button.alert-text:hover {
    background-color: #DA4C3C;
    color: var(--tertiary-color);
}*/
.internal-link:after {
  content: "\e905";
  padding-left: 5px;
  opacity: 0;
  transition: 150ms;
  transform: translateX(-20px);
  font-family: "icons", sans-serif;
  font-weight: unset;
  font-size: 1.3rem;
}

.internal-link:hover:after {
  opacity: 1;
  transform: none;
}

.block-link span {
  padding: 5px 9px 4px;
  transition: 75ms;
  border-radius: 3px;
  color: var(--secondary-color);
}

.block-link.alert-text span, .block-button.alert-text {
  color: #DA4C3C;
}

.block-link:hover span, .block-button:hover {
  background-color: var(--secondary-color);
  color: var(--tertiary-color);
}

.block-link.alert-text:hover span, .block-button.alert-text:hover {
  background-color: #DA4C3C;
  color: var(--tertiary-color);
}

footer .block-link span {
  color: var(--tertiary-color);
}

footer .block-link:hover span {
  background-color: var(--tertiary-color);
  color: var(--secondary-color);
}

.footer-content-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  padding: 30px 0;
  flex-grow: 1;
  position: relative;
  z-index: 100;
}

.footer-left {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 16px;
}

.footer-right {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
}

.footer-mask-wrapper, .footer-logo-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.footer-logo-wrapper {
  justify-content: center;
}

.footer-mask-wrapper > img {
  max-width: 500px;
  height: auto;
  width: 100%;
}

.footer-logo-wrapper > img {
  max-width: 200px;
  height: auto;
  /* margin-bottom: 50px; */
  margin-top: -120px;
  width: 40vw;
}

/*</editor-fold>*/
/*<editor-fold desc="Prominence">*/
.prominence {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100vw;
}

.prominence-background {
  background-color: #FFD425;
  background-image: url("/media/images/background-design-primary.jpg");
  background-repeat: repeat;
  background-attachment: fixed;
  overflow-x: hidden;
  width: 100vw;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.prominence-wrapper {
  position: relative;
  padding-top: 100px;
}

.prominence h2 {
  z-index: 100;
  position: relative;
  margin: 0 0 -0.65em;
  text-transform: uppercase;
  font-size: 3rem;
  font-weight: 800;
}

.prominence-subheading {
  position: absolute;
  font-size: 7em;
  top: -22px;
  left: -10px;
  color: var(--tertiary-color);
  z-index: 1;
  text-transform: uppercase;
  font-weight: 900;
  margin: 0;
  line-height: 1;
  white-space: nowrap;
}

.prominence-content {
  padding: 10px 0 30px;
}

.prominence-link {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
}

/*</editor-fold>*/
/*<editor-fold desc="Home Flavor List">*/
.home-flavor-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 1fr;
  gap: 10px;
}

.home-flavor-list .promo-box {
  grid-row-start: 3;
  grid-row-end: 4;
  grid-column-start: 1;
  grid-column-end: 3;
}

.home-flavor-list-item {
  border-radius: 4px;
  overflow: hidden;
}

.home-flavor-list-item img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/*</editor-fold>*/
/*<editor-fold desc="Locations Display">*/
/*.locations-display {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.locations-display address {
    font-style: normal;
    font-weight: 100;
    padding: 5px 0;
}

.location-display-state {
    display: flex;
    flex-direction: row;
    gap: 20px;
    align-items: flex-start;
}

.location-display-state-label .image-wrapper-contain {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.location-display-state-list {
    flex-grow: 1;
    padding-top: 150px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.location-display-state-list-item {
    display: flex;
    flex-direction: column;
    padding: 15px;
}

.location-display-state-list-item-header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
}

.location-display-state-list-item-socials {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    font-size: 2em;
    gap: 5px;
}

.location-display-state-list-item-socials .block-link .icon {
    padding: 5px;
}

.location-display-state-label {
    width: 300px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    height: 400px;
    z-index: -100;
    padding-top: 60px;
    overflow: hidden;
    flex-shrink: 0;
}

.location-display-state-label h2 {
    font-size: 3em;
    position: relative;
    line-height: 1;
    margin: 0;
    z-index: 1;
}

.location-display-state-label-subheading {
    position: relative;
    text-transform: uppercase;
    font-weight: 900;
    font-size: 8em;
    line-height: 1;
    color: white;
    margin-top: -.25em;
    white-space: nowrap;
    margin-left: 32px;
}

.location-contact-links {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.location-display-state-list-item > *:not(:nth-last-child(1)) {
    border-bottom: 1px solid #ddd;
    padding-bottom: 10px;
}

.location-display-state-list-item > *:not(:nth-child(1)) {
    padding-top: 10px;
}

.location-display-state-list-item-location-wrapper {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
*/
/*</editor-fold>*/
/*<editor-fold desc="Gelati Presentation">*/
#gelati-presentation {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  overflow: hidden;
}

.gelati-presentation-background {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: -100;
}

.gelati-presentation-background p {
  color: #f3f3f3;
  font-size: calc(20em + 10vw);
  font-family: "Lobster", cursive;
  transform: translateX(20%);
  margin: 0;
  /* line-height: 1; */
  /* padding: 0; */
}

.gelati-presentation-title h2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1;
}

.gelati-presentation-title span {
  font-size: 1.5em;
  font-weight: 100;
}

.gelati-presentation-title .brand-span {
  font-size: 3.5em;
}

.gelati-presentation-gelati {
  display: grid;
  position: relative;
  grid-template: "a" 1fr/1fr;
  /* height: 500px; */
  width: 100%;
  justify-items: center;
}

.gelati-presentation-gelati > img {
  grid-area: a;
  /* height: auto; */
  max-height: 500px;
  max-width: 70vw;
}

.gelati-presentation-tag {
  position: absolute;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  left: calc(50% - 15px);
  right: 10px;
}

#gelati-presentation.gelati-presentation-preanimation .gelati-presentation-gelati > .gelati-presentation-gelati-unit, #gelati-presentation.gelati-presentation-preanimation .gelati-presentation-gelati > .gelati-presentation-tag {
  opacity: 0;
}

#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > img {
  animation: gpa-drop 300ms;
  animation-fill-mode: both;
  animation-timing-function: ease-in;
}

#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > .gelati-presentation-gelati-unit.cup {
  animation-delay: 0ms;
}

#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > .gelati-presentation-gelati-unit.bottom {
  animation-delay: 250ms;
}

#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > .gelati-presentation-gelati-unit.middle {
  animation-delay: 350ms;
}

#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > .gelati-presentation-gelati-unit.top {
  animation-delay: 450ms;
}

.fun-list {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 30px;
}

.fun-list .content-text {
  gap: 0px;
}

.fun-list-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 20px;
}

.fun-list-item .image-wrapper-contain {
  flex-basis: 90px;
  flex-shrink: 0;
}

@keyframes gpa-drop {
  0% {
    opacity: 0;
    transform: translateY(-100px);
  }
  60% {
    opacity: 1;
    transform: translateY(0);
  }
  80% {
    transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > .gelati-presentation-tag {
  animation: gpa-tag-pop 300ms;
  animation-fill-mode: both;
  animation-timing-function: ease-out;
}

#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > .gelati-presentation-tag.top {
  animation-delay: 600ms;
}

#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > .gelati-presentation-tag.middle {
  animation-delay: 800ms;
}

#gelati-presentation.gelati-presentation-animation .gelati-presentation-gelati > .gelati-presentation-tag.bottom {
  animation-delay: 1000ms;
}

@keyframes gpa-tag-pop {
  from {
    opacity: 0;
    transform: translateX(-20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
.gelati-presentation-tag > img {
  height: 30px;
}

.gelati-presentation-tag.bottom {
  top: 75%;
}

.gelati-presentation-tag.middle {
  top: 45%;
}

.gelati-presentation-tag.top {
  top: 15%;
}

.gelati-presentation-tag p {
  /* white-space: nowrap; */
  padding-left: 10px;
  font-weight: 600;
  font-size: 1.3em;
  margin: 0;
}

/*</editor-fold>*/
/*<editor-fold desc="Flavor List">*/
.flavor-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.flavor-list h4 {
  position: relative;
  z-index: 100;
  font-size: 1.4em;
  text-align: center;
}

.flavor-list h4 {
  position: relative;
  z-index: 100;
  font-size: 1.4em;
}

.flavor-list-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-basis: 250px;
  padding: 20px;
  overflow: hidden;
}

.flavor-list-icon-wrapper {
  width: 100%;
  position: relative;
  height: 200px;
  flex-grow: 1;
}

.flavor-list-icon-wrapper img {
  width: 100%;
  height: 100%;
  position: absolute;
  object-fit: contain;
  transition: 200ms;
}

.flavor-list-icon-foreground {
  opacity: 0;
}

/*</editor-fold>*/
/*<editor-fold desc="Menu > Allergens">*/
.allergen-category {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.allergen-category ul {
  border-top: 2px solid var(--secondary-color);
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.allergen-category li {
  display: flex;
  flex-direction: column;
}

/*</editor-fold>*/
/*<editor-fold desc="Accent Banner">*/
.accent-banner-wrapper {
  width: 100vw;
  overflow: hidden;
  padding-top: 40px;
}

.accent-banner {
  background-color: var(--secondary-color);
  position: relative;
  min-height: 300px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: stretch;
}

.accent-banner-background {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
}

.accent-banner-background p {
  color: #302F2F;
  font-size: 17em;
  white-space: nowrap;
  font-family: "Lobster", cursive;
}

.accent-banner-container {
  display: flex;
  flex-direction: row;
  justify-content: stretch;
  position: relative;
  /* height: 100%; */
  flex-grow: 1;
  gap: 20px;
}

.accent-banner-picture-container {
  flex-basis: 400px;
  margin: -80px 0;
  border-radius: 10px 10px 0 0;
  overflow: hidden;
  position: relative;
  transform: rotate(-6deg);
}

.accent-banner-picture-container:nth-last-child(1) {
  transform: rotate(6deg);
}

.accent-banner-picture-container img {
  width: 100%;
  display: block;
  position: absolute;
  height: 100%;
  object-fit: cover;
}

.accent-banner-container .decorative-text {
  flex-grow: 1;
}

.decorative-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--tertiary-color);
  font-size: 2.1em;
  line-height: 1;
}

.decorative-text .simple {
  font-family: "Rubik", sans-serif;
}

.decorative-text .decorative {
  font-family: "Lobster", cursive;
}

.decorative-text .small {
  font-size: 0.8em;
}

.decorative-text .medium {
  font-size: 1.2em;
}

.decorative-text .large {
  font-size: 2em;
}

.decorative-text .giant {
  font-size: 4em;
}

.decorative-text .underline {
  border-bottom: 1px solid var(--tertiary-color);
}

.decorative-text .decorative.giant {
  margin: -20px 0 -5px;
}

/*</editor-fold>*/
/*<editor-fold desc="Messages">*/
.message {
  display: flex;
  flex-direction: row;
  border-radius: 8px;
  align-items: stretch;
  border: 2px solid #959595;
  overflow: hidden;
  background-color: #959595;
}

.message .message-content {
  background-color: #DDDDDD;
}

.message-icon {
  flex-shrink: 1;
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 1.4em;
}

.message-content {
  flex-grow: 1;
  padding: 7px 12px;
  border-radius: 5px;
}

.message.error {
  background-color: #DA4C3C;
  border-color: #DA4C3C;
}

.message.error .message-content {
  background-color: #F2C0BA;
}

.message.alert {
  background-color: #EBD636;
  border-color: #EBD636;
}

.message.alert .message-content {
  background-color: #F6ECA2;
}

.message.success {
  background-color: #5ACE30;
  border-color: #5ACE30;
}

.message.success .message-content {
  background-color: #CAF0BC;
}

.alert-text {
  color: #DA4C3C;
  font-weight: 600;
}

/*</editor-fold>*/
/*<editor-fold desc="Public Alert">*/
.public-alert {
  width: min(100%, 38rem);
  margin: 1rem auto 0;
  padding: 0.95rem 1rem;
  border: 1px solid var(--color-primary);
  border-radius: var(--border-radius);
  background: var(--color-bg-muted);
  color: var(--color-fg);
  line-height: 1.6;
  text-align: left;
}

.public-alert__title {
  margin: 0 0 0.35rem;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.public-alert__content,
.public-alert__content p {
  margin: 0;
  font-size: 0.95rem;
}

/*</editor-fold>*/
/*<editor-fold desc="Polaroid Display">*/
.polaroid-display-wrapper {
  width: 100vw;
  background-color: var(--secondary-color);
  display: flex;
  flex-direction: column;
  align-items: center;
  background-image: url("/media/images/background-design-secondary.jpg");
  background-repeat: repeat;
  background-attachment: fixed;
}

.polaroid-display {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  min-height: 400px;
}

.polaroid-wrapper {
  /* flex-grow: 1; */
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.polaroid-wrapper.pos-bottom {
  justify-content: flex-end;
}

.polaroid {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  border-radius: 16px;
  padding: 5px;
  background-color: white;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.3764705882), 0 3px 8px 0 rgba(0, 0, 0, 0.1254901961);
  max-width: 450px;
}

.polaroid.tilt-left {
  transform: rotate(-4deg);
}

.polaroid.tilt-right {
  transform: rotate(4deg);
}

.polaroid .image-wrapper-cover {
  flex-grow: 1;
  border-radius: 12px;
  overflow: hidden;
}

.polaroid .image-wrapper-cover img {
  position: unset;
}

.polaroid-title {
  font-family: "Lobster", cursive;
  font-size: 1.5em;
  text-align: center;
}

.polaroid-date {
  font-size: 0.8em;
  text-align: center;
}

/*</editor-fold>*/
/*<editor-fold desc="Mission Statement">*/
.home-mission-image-wrapper {
  height: 400px;
  width: 100%;
  position: relative;
}

.home-mission-image {
  height: 100%;
  width: 100%;
  border-radius: 5px;
}

.home-image-wrapper {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.home-mission-label-top, .home-mission-label-bottom {
  padding: 8px 12px;
  font-weight: bold;
  font-size: 1.2em;
}

.home-mission-label-top {
  position: absolute;
  top: 10px;
  left: -10px;
  margin-right: 10px;
}

.home-mission-label-bottom {
  position: absolute;
  right: -10px;
  bottom: 10px;
  margin-left: 10px;
}

/*</editor-fold>*/
.menu-header {
  display: flex;
  flex-direction: row;
  align-items: center;
}

.menu-header > h2 {
  background-color: var(--primary-color);
  padding: 6px 20px;
}

.menu-header:after {
  content: "";
  display: block;
  background-color: var(--primary-color);
  height: 10px;
  flex-grow: 1;
}

.menu-separators.full-column > *:not(:nth-last-child(1)) {
  border-bottom: 2px solid var(--primary-color);
}

.menu-item-compact {
  display: grid;
  grid-template: "a c" 0fr "b c" 1fr/auto 40%;
  padding: 10px;
  gap: 10px;
}

.menu-item-compact > .menu-item-header {
  grid-area: a;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.menu-item-compact > .menu-item-description {
  grid-area: b;
  display: flex;
  flex-direction: column;
  gap: 5px;
  align-items: center;
  text-align: center;
}

.menu-item-compact > .menu-item-image {
  grid-area: c;
  max-height: 200px;
}

.menu-subheader {
  font-size: 1.3em;
  font-family: "Lobster", cursive;
}

.menu-item-header > h2, .menu-subheader-block {
  font-family: "Lobster", cursive;
  color: var(--tertiary-color);
  background-color: var(--secondary-color);
  padding: 8px 16px;
  border-radius: 7px;
  font-size: 1.5em;
}

.menu-emphasis {
  font-family: "Lobster", cursive;
}

.menu-size-item {
  padding: 5px;
}

.menu-size-item > .image-wrapper-contain {
  max-width: 150px;
}

.menu-mini-header {
  background-color: var(--primary-color);
  padding: 2px 6px;
  border-radius: 3px;
}

.menu-mini-list {
  list-style-type: disc;
  font-size: 0.9em;
}

.menu-flavors {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
  padding: 10px;
}

.menu-flavor-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  font-size: 1.3em;
  gap: 10px;
}

.menu-flavor-item > img {
  width: 30px;
}

.menu-label {
  font-size: 1.3em;
}

.dynamic-allergen-table {
  --dat-radius-large: 7px;
  --dat-padding: 2px;
  --dat-radius-small: calc(var(--dat-radius-large) - var(--dat-padding));
  display: grid;
  grid-template-columns: 1fr;
  background-color: var(--primary-color);
  padding: var(--dat-padding);
  gap: var(--dat-padding);
  border-radius: var(--dat-radius-large);
}

.dat-divider {
  display: grid;
  gap: var(--dat-padding);
}

.dat-divider > * {
  min-width: 0;
}

.dat-divider.divide-5 {
  grid-template-columns: repeat(5, 1fr);
}

.dat-divider.divide-3 {
  grid-template-columns: repeat(3, 1fr);
}

.dat-cell {
  background-color: var(--tertiary-color);
  border-radius: var(--dat-radius-small);
  padding: 5px;
}

.dat-cell:has(.alert-text) {
  background-color: #ffeeee;
}

.dat-divider > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.dat-contains {
  height: 60px;
}

.dat-label {
  grid-column: 1/-1;
  align-items: flex-start;
  font-weight: 500;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-end;
}

.dat-header {
  font-weight: 400;
  background-color: var(--primary-color);
  padding: 2px;
}

.dat-header > div {
  font-weight: 800;
  padding: 5px 2px;
  font-size: 0.9em;
}

.allergen-sub-text {
  text-align: center;
  font-size: 0.7em;
}

.allergen-sub-text:not(.alert-text) {
  color: #aaa;
}

#us-map {
  width: 100%;
  max-width: 800px;
}

#us-map #ID, #us-map #UT {
  fill: var(--primary-color) !important;
  transform-box: fill-box;
  transform-origin: center;
  transition: 50ms;
}

.pop-image {
  border-radius: 4px;
  min-height: 400px;
}

.location-panels {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: var(--padding-medium);
}

.location-panel {
  --offset: 6px;
  --radius: 14px;
  --border: 3px;
  position: relative;
  border: var(--border) solid var(--secondary-color);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--padding-small);
  padding: var(--offset);
}

.location-panel address {
  font-size: 0.85rem;
  font-style: normal;
}

.lp-heading {
  display: flex;
  flex-direction: column;
  gap: var(--padding-tiny);
}

.lp-heading h3 {
  font-size: 1.7rem;
  font-weight: 800;
  text-transform: uppercase;
  text-shadow: 5px 5px white;
  line-height: 1;
}

.lp-back {
  background-color: var(--primary-color-soft);
  position: absolute;
  white-space: nowrap;
  left: var(--offset);
  right: calc(-1 * var(--offset) - var(--border));
  top: var(--offset);
  bottom: calc(-1 * var(--offset) - var(--border));
  z-index: -1;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 5rem;
  overflow: hidden;
  border-radius: calc(var(--radius) - var(--offset) - var(--border)) var(--radius) calc(var(--radius) + var(--offset) - var(--border)) var(--radius);
}

.inactive .lp-back {
  background-color: var(--accent-color);
}

.lp-back-text {
  color: rgba(255, 255, 255, 0.5019607843);
  position: absolute;
  top: -0.24em;
  left: -0.1em;
}

.lp-content {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--padding-medium);
  padding: 0 var(--offset) var(--padding-small);
  font-weight: 200;
  flex-grow: 1;
}

.lp-content p {
  font-size: 1rem;
}

.lp-alert {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 120px;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 1.1rem;
  text-align: center;
}

.lp-alert-heading {
  font-weight: 500;
  font-size: 0.75rem;
}

.lp-content address {
  font-style: normal;
  gap: var(--padding-small);
}

.mini-list {
  display: flex;
  flex-direction: column;
  gap: var(--offset, 2px);
}

.hours-unit {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

.hours-list-all-times {
  display: flex;
  flex-direction: column;
}

.hours-list-times {
  font-weight: 400;
  text-align: right;
}

.time-suffix {
  text-transform: uppercase;
  font-weight: 500;
  font-size: 0.75rem;
}

.lp-buttons {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--offset);
}

.lp-button {
  min-height: 44px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: var(--secondary-color);
  color: var(--tertiary-color);
  border-radius: calc(var(--radius) - var(--offset));
  border: 3px solid var(--secondary-color);
}

.mini-list h4 {
  padding-bottom: 3px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2509803922);
}

.lp-button.inverted {
  background-color: transparent;
  color: var(--secondary-color);
}

.lp-button:hover {
  background-color: var(--tertiary-color);
  color: var(--secondary-color);
}

.state-header {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  position: relative;
  margin-bottom: 14px;
  z-index: 1;
  gap: var(--padding-small);
}

.state-header:after {
  content: "";
  position: absolute;
  left: -10px;
  right: -10px;
  height: 20px;
  bottom: -4px;
  background-color: var(--accent-color);
  border-radius: 4px;
  z-index: -1;
}

.state-icon {
  height: 60px;
}

.location-page {
  gap: var(--padding-medium);
}

.location-page-title {
  text-transform: uppercase;
  line-height: 1.1;
}

.location-page-title h1 {
  position: relative;
}

.location-page-title h1 .bg {
  color: var(--primary-color-soft);
  opacity: 0.5;
  z-index: -1;
  position: absolute;
  top: -0.15em;
  left: -0.15em;
  font-size: 1.7em;
  white-space: nowrap;
}

.location-page-title h1 > * {
  display: block;
}

.location-page-title .subtitle {
  text-transform: none;
  font-size: 0.5em;
}

.location-page-widget {
  width: 100%;
  min-height: 400px;
  background: var(--primary-color-soft);
  display: grid;
  grid-template-columns: 1fr min(var(--fixed-width) * 0.5, var(--fixed-max-width) * 0.5) min(var(--fixed-width) * 0.5, var(--fixed-max-width) * 0.5) 1fr;
}

.lpw-map-wrapper {
  grid-column: 1/3;
  background: var(--accent-color);
}

.lpw-map {
  width: 100%;
  height: 100%;
}

.lpw-info {
  padding: var(--padding-medium);
  padding-right: 0;
}

.location-page-widget address {
  opacity: 0.6;
  font-weight: 200;
  font-style: normal;
}

.lpw-info h2 {
  text-transform: uppercase;
}

.lpw-small {
  max-width: 250px;
}

.location-info-banner {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.lib-image-banner {
  min-height: 450px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--padding-medium) 0;
}

.lib-image-banner-content {
  color: white;
  font-size: 1.2rem;
  font-weight: 200;
  line-height: 1.5;
}

.lib-buttons-wrapper {
  background: var(--accent-color);
}

.lib-buttons {
  display: flex;
  flex-direction: row;
  padding: var(--padding-medium) 0;
}

.lib-buttons-social {
  padding: var(--padding-small);
  padding-right: var(--padding-large);
  padding-left: 0;
}

.lib-buttons-social-links {
  display: flex;
  flex-direction: row;
  gap: var(--padding-medium);
  font-size: 1.7rem;
}

.lib-buttons-etc {
  padding: var(--padding-small);
  padding-left: var(--padding-large);
  border-left: 1px solid rgba(0, 0, 0, 0.1254901961);
}

.lib-buttons-etc--solo {
  padding-left: 0;
  border-left: 0;
}

.big-heading-1 {
  color: var(--primary-color);
  text-transform: uppercase;
  font-weight: 800;
  font-size: 3.5rem;
  line-height: 1;
}

.style-yellow {
  background: var(--primary-color-soft);
}

.big-heading-2 {
  color: var(--secondary-color);
  text-transform: uppercase;
  font-weight: 800;
  font-size: 3.5rem;
  line-height: 1;
}

.full-image-banner {
  display: flex;
  flex-direction: column;
}

h1.peek-top {
  margin-top: -0.27em;
}

.peek-padding-bottom {
  padding-bottom: 100px;
}

.fib-content {
  width: var(--fixed-width);
}

.fib-image {
  width: 100%;
  display: flex;
  flex-direction: row;
}

.text-right .fib-image {
  justify-content: flex-start;
}

.text-right .fib-content {
  text-align: right;
  align-items: flex-end;
}

.text-left .fib-image {
  justify-content: flex-end;
}

.fib-image img {
  width: 100%;
  display: block;
  min-width: 800px;
  max-width: 1200px;
}

.fib-multi-image {
  position: relative;
  height: 100%;
  min-height: 400px;
  overflow: hidden;
  width: 100%;
}

.fib-multi-image > * {
  position: absolute;
}

.fib-content p {
  max-width: 450px;
}

.multi-gelati > img {
  height: calc(100% + 100px);
  bottom: -100px;
  max-height: 600px;
}

.multi-gelati > img:nth-child(1) {
  right: 300px;
  animation-delay: 0s;
}

.multi-gelati > img:nth-child(2) {
  right: 180px;
  animation-delay: 0.15s;
}

.multi-gelati > img:nth-child(3) {
  right: 0;
  animation-delay: 0.3s;
}

.will-animate.multi-gelati > img {
  opacity: 0;
}

.animate.multi-gelati > img {
  animation-name: pop-up;
  animation-duration: 500ms;
  animation-fill-mode: both;
}

.info-panel {
  display: flex;
  flex-direction: column;
  line-height: 1.5;
  font-weight: 200;
  border-radius: var(--border-radius);
  border: 1px solid var(--accent-color);
  padding: var(--padding-medium);
  padding-top: calc(var(--padding-medium) + 12px);
  position: relative;
  overflow: hidden;
  gap: var(--padding-tiny);
}

.info-panel:before {
  content: "";
  display: block;
  height: 12px;
  width: 100%;
  background: var(--primary-color);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}

.info-panel ul {
  list-style-type: disc;
  padding-left: 20px;
}

.info-panel h3 {
  text-transform: uppercase;
  font-size: 1.1rem;
  line-height: 1.2;
}

.info-panel h3:after {
  content: "";
  display: block;
  height: 4px;
  width: 30px;
  background: var(--primary-color);
  margin: var(--padding-tiny) 0;
}

.small-price-display {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-weight: 600;
  text-transform: uppercase;
  text-align: center;
  font-size: 0.8rem;
  padding: var(--padding-small);
  background: var(--primary-color-soft);
  border-radius: var(--border-radius-small);
}

.small-price-display .price {
  font-size: 1.5rem;
  font-weight: 200;
}

@keyframes pop-up {
  0% {
    opacity: 0;
    transform: translateY(100px);
  }
  50% {
    opacity: 1;
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (min-width: 1000px) {
  .big-heading-1, .big-heading-2 {
    font-size: 4.5rem;
  }
  .text-right.full-image-banner {
    display: grid;
    grid-template-columns: 1fr min(var(--fixed-width) * 0.35, var(--fixed-max-width) * 0.35) min(var(--fixed-width) * 0.65, var(--fixed-max-width) * 0.65) 1fr;
    align-items: flex-start;
  }
  .text-left.full-image-banner {
    display: grid;
    grid-template-columns: 1fr min(var(--fixed-width) * 0.65, var(--fixed-max-width) * 0.65) min(var(--fixed-width) * 0.35, var(--fixed-max-width) * 0.35) 1fr;
    align-items: flex-start;
  }
  .text-right .fib-image, .text-right .fib-multi-image {
    grid-column: 1/4;
    grid-row: 1/2;
  }
  .text-left .fib-image, .text-left .fib-multi-image {
    grid-column: 2/-1;
    grid-row: 1/2;
  }
  .fib-content {
    width: unset;
    z-index: 1;
    max-width: unset;
    grid-column: 3/4;
    grid-row: 1/-1;
    padding-bottom: 120px;
  }
  .text-right .fib-content {
    grid-column: 3/4;
    grid-row: 1/-1;
  }
  .text-left .fib-content {
    grid-column: 2/3;
    grid-row: 1/-1;
  }
  .fib-image, .fib-multi-image {
    padding-top: 120px;
    align-items: flex-end;
    align-self: flex-end;
  }
}
@media only screen and (max-width: 1000px) {
  .home-flavor-list {
    grid-template-columns: repeat(3, 1fr);
  }
  .location-display-state {
    flex-direction: column;
    align-items: unset;
  }
  .location-display-state-label {
    align-self: center;
  }
  .location-display-state-list {
    padding-top: 0;
  }
  .location-display-state-list-item-socials {
    justify-content: center;
  }
  .location-contact-links {
    align-items: center;
  }
  .accent-banner-wrapper {
    padding-top: unset;
  }
  .accent-banner-picture-container {
    display: none;
  }
}
@media (min-width: 701px) {
  .flavor-list-item:hover .flavor-list-icon {
    transform: scale(1.1) rotate(10deg);
  }
  .flavor-list-item:hover .flavor-list-icon-foreground {
    opacity: 1;
    transform: scale(1.3) rotate(-10deg);
  }
  .menu-separators.full-row > *:not(:last-child) {
    border-right: 3px solid var(--primary-color);
  }
  .fun-list-item:nth-child(1) {
    padding-left: 10px;
  }
  .fun-list-item:nth-child(2) {
    padding-left: 50px;
  }
  .fun-list-item:nth-child(3) {
    padding-left: 30px;
  }
  .fun-list-item:nth-child(4) {
    padding-left: 60px;
  }
  .fun-list-item:nth-child(5) {
    padding-left: 90px;
  }
}
@media only screen and (max-width: 700px) {
  /*<editor-fold desc="Mobile: Header">*/
  /*#hamburger-menu {
      display: flex;
      align-self: flex-end;
      align-items: center;
      justify-content: center;
  }

  #header-upper {
      height: unset;
  }

  #logo-container {
      height: 200px;
  }

  #header-logo {
      height: 300px;
      margin-bottom: -60px;
  }

  #header-content-wrapper {
      flex-direction: column;
      align-items: stretch;
  }

  #nav-wrapper {
      height: 0;
      padding: 0;
  }

  #nav-wrapper > nav > a {
      opacity: 0;
      transform: scale(.6);
      transition: opacity 250ms, transform 250ms;
  }

  #nav-wrapper.nav-wrapper-visible > nav > a {
      opacity: 1;
      transform: scale(1) translateY(0);
      animation: pop-in 400ms;
      animation-delay: 100ms;
      animation-fill-mode: backwards;
  }

  @keyframes pop-in {
      0% {opacity: 0; transform: scale(.6);}
      50% {opacity: .5; transform: scale(1.1);}
      100% {opacity: 1; transform: scale(1);}
  }

  #nav-wrapper.nav-wrapper-visible {
      height: 40vh!important;
  }

  nav {
      align-items: center;
      font-size: 2.3em;
      justify-content: space-around;
      height: 100%;
      padding: 40px 20px 20px;
  }*/
  /*</editor-fold>*/
  /*<editor-fold desc="header-new">*/
  header {
    --header-nav-height: 60px;
  }
  nav {
    flex-direction: column;
    align-items: flex-end;
    grid-area: c;
    max-height: 0;
    transition: 700ms;
    overflow: hidden;
  }
  nav a {
    opacity: 0;
    transition: 300ms;
    transform: translateY(-10px);
    font-size: 1.5em;
  }
  *:has(#nav-toggle-checkbox:checked) ~ nav a {
    opacity: 1;
    transform: translateY(0px);
  }
  *:has(#nav-toggle-checkbox:checked) ~ nav {
    display: flex;
    max-height: 500px;
    padding: var(--padding-large);
  }
  .nav-wrapper {
    display: grid;
    grid-template-areas: "a b" "c c";
  }
  nav {
    flex-wrap: nowrap;
    padding: 0 var(--padding-large);
  }
  #nav-toggle-checkbox {
    display: none;
  }
  .nav-toggle {
    position: relative;
    width: 30px;
    height: 20px;
  }
  .nav-toggle-wrapper {
    grid-area: b;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    min-height: 44px;
    min-width: 44px;
    padding: 0 20px;
    --hamburger-size-y: 7px;
  }
  .nav-toggle:before, .nav-toggle:after {
    content: "";
    background-color: var(--secondary-color);
    width: 100%;
    height: var(--hamburger-size-y);
    border-radius: 3px;
    position: absolute;
    transition: top 100ms 100ms ease-out, bottom 100ms 100ms ease-out, transform 100ms ease-out;
  }
  .nav-toggle-wrapper:has(> #nav-toggle-checkbox:checked) .nav-toggle:before, .nav-toggle-wrapper:has(> #nav-toggle-checkbox:checked) .nav-toggle:after {
    position: absolute;
    transition: top 100ms ease-out, bottom 100ms ease-out, transform 100ms 100ms ease-out;
  }
  .nav-toggle:before {
    top: 0;
  }
  .nav-toggle:after {
    bottom: 0;
  }
  .nav-toggle-wrapper:has(> #nav-toggle-checkbox:checked) .nav-toggle:before {
    top: calc(50% - var(--hamburger-size-y) / 2);
    transform: rotate(45deg);
  }
  .nav-toggle-wrapper:has(> #nav-toggle-checkbox:checked) .nav-toggle:after {
    bottom: calc(50% - var(--hamburger-size-y) / 2);
    transform: rotate(-45deg);
  }
  /*</editor-fold>*/
  .display-columns {
    flex-direction: column;
  }
  .display-columns > * {
    flex: unset;
  }
  .horizontal-display, .columns {
    flex-direction: column;
  }
  .full-row {
    flex-direction: column;
  }
  .gelati-presentation-tag {
    flex-direction: column;
    align-items: center;
    left: 0;
    right: 0;
  }
  .gelati-presentation-tag > .dotted-line {
    display: none;
  }
  .gelati-presentation-tag > p {
    background-color: white;
    padding: 3px 8px;
    border-radius: 5px;
  }
  .flavor-list {
    flex-direction: column;
  }
  .flavor-list-item {
    flex-basis: 300px;
  }
  .flavor-list-item.highlighted .flavor-list-icon {
    transform: scale(1.1) rotate(10deg);
  }
  .flavor-list-item.highlighted .flavor-list-icon-foreground {
    opacity: 1;
    transform: scale(1.3) rotate(-10deg);
  }
  .footer-content-wrapper {
    padding: 90px 0 30px;
  }
  .home-flavor-list {
    grid-template-columns: repeat(2, 1fr);
  }
  .footer-content-wrapper {
    flex-direction: column-reverse;
    align-items: center;
    gap: 20px;
  }
  .footer-right, .footer-left {
    align-items: center;
  }
  .footer-left {
    gap: 24px;
  }
  .location-display-state-list-item > * {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
  }
  .content-lister.horizontal {
    flex-direction: column;
  }
  .location-display-state-list-item-location-wrapper {
    align-items: center;
  }
  .polaroid-display {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
  .menu-separators.full-row > *:not(:nth-last-child(1)) {
    border-bottom: 2px solid var(--primary-color);
  }
  .dat-header > div {
    font-size: calc(0.4em + 1.5vw);
  }
  .peek-top {
    margin-top: 0;
  }
  .location-page-widget {
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
  }
  .lpw-info {
    width: var(--fixed-width);
    padding: var(--padding-medium) 0;
  }
  .lpw-map-wrapper {
    width: 100%;
    height: 400px;
  }
  .lib-buttons {
    flex-direction: column;
    gap: var(--padding-medium);
  }
  .lib-buttons-social, .lib-buttons-etc {
    padding: 0;
  }
  .lib-buttons-etc {
    border-left: none;
  }
}
.nutrition-label {
  font-family: Arial, sans-serif;
  width: 300px;
  border: 8px solid black;
  padding: 10px;
  background: white;
  color: black;
}

.nutrition-label h1 {
  font-size: 24px;
  font-weight: bold;
  margin: 0 0 10px 0;
}

.nutrition-label .divider {
  border-top: 8px solid black;
  margin: 5px 0;
}

.nutrition-label .sub-divider {
  border-top: 1px solid black;
  margin: 2px 0;
}

.nutrition-label .nutrient {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
  font-weight: bold;
}

.nutrition-label .indented {
  padding-left: 15px;
  font-weight: normal;
}

.nutrition-label .note {
  font-size: 10px;
  margin-top: 8px;
}

.allergen-guide-page {
  gap: var(--padding-large);
  padding-top: var(--padding-medium);
  padding-bottom: var(--padding-large);
}

.allergen-guide-intro {
  max-width: 760px;
}

.allergen-guide-intro h1,
.allergen-directory-section__header h2 {
  text-transform: uppercase;
}

.allergen-guide-note {
  background: #fffdf9;
  border: 1px solid rgba(35, 31, 32, 0.12);
  border-radius: var(--border-radius-small);
  padding: var(--padding-medium);
}

.allergen-guide-note__eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.allergen-guide-section {
  gap: var(--padding-medium);
}

.allergen-guide-search {
  max-width: 520px;
}

.allergen-guide-search__input {
  width: 100%;
  min-height: 48px;
  padding: 0.75rem 0.9rem;
  border: 1px solid rgba(35, 31, 32, 0.16);
  border-radius: var(--border-radius-small);
  background: white;
  font: inherit;
  color: var(--secondary-color);
}

.allergen-guide-search__input::placeholder {
  color: rgba(35, 31, 32, 0.5);
}

.allergen-guide-search__input:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(255, 212, 37, 0.2);
}

.allergen-directory {
  gap: var(--padding-large);
}

.allergen-directory [hidden] {
  display: none !important;
}

.allergen-directory__empty {
  margin: 0;
  padding: 0.9rem 1rem;
  border-radius: var(--border-radius-small);
  background: #fffdf9;
  border: 1px solid rgba(35, 31, 32, 0.12);
}

.allergen-directory-section {
  gap: var(--padding-medium);
}

.allergen-directory-section__header h2 {
  text-transform: uppercase;
}

.allergen-directory-group {
  gap: var(--padding-small);
}

.allergen-directory-group__header {
  padding-top: var(--padding-small);
  border-top: 1px solid rgba(35, 31, 32, 0.12);
}

.allergen-directory-group__header h3 {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  opacity: 0.65;
}

.allergen-directory-list {
  gap: var(--padding-small);
}

.allergen-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--padding-medium);
  align-items: start;
  background: white;
  border: 1px solid rgba(35, 31, 32, 0.12);
  border-left: 5px solid var(--flavor-accent, var(--primary-color));
  border-radius: var(--border-radius-small);
  padding: 0.85rem 1rem;
}

.allergen-row__main {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  min-width: 0;
}

.allergen-row__title h4 {
  margin: 0;
  font-size: 1.05rem;
}

.allergen-row__details {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.55rem;
}

.allergen-detail {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.35rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(35, 31, 32, 0.1);
  background: #fffdfa;
  font-size: 0.8rem;
  line-height: 1.25;
}

.allergen-detail--present {
  background: #fff5c5;
  border-color: rgba(35, 31, 32, 0.16);
}

.allergen-row__nutrition {
  white-space: nowrap;
  align-self: center;
}

@media only screen and (max-width: 700px) {
  .allergen-guide-page {
    gap: var(--padding-medium);
    padding-bottom: var(--padding-medium);
  }
  .allergen-row {
    grid-template-columns: 1fr;
    gap: var(--padding-small);
  }
  .allergen-row__nutrition {
    align-self: flex-start;
  }
}
:root {
  --site-form-surface: #fff;
  --site-form-surface-soft: #fffbef;
  --site-form-line: rgba(78, 63, 43, 0.16);
  --site-form-line-strong: rgba(78, 63, 43, 0.28);
  --site-form-text-muted: #7e6d5a;
  --site-form-focus: #f5c400;
  --site-form-focus-ring: rgba(255, 212, 37, 0.24);
  --site-form-danger: #b14229;
  --site-form-field-radius: var(--radius-md);
  --site-form-group-gap: var(--space-sm);
}

.site-form {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.5rem;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.site-form__field,
.site-form__group {
  grid-column: 1/-1;
  min-width: 0;
}

.site-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.site-form__field--half {
  grid-column: span 6;
}

.site-form__field--third {
  grid-column: span 4;
}

.site-form__field label {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  align-self: flex-start;
  gap: var(--space-xs);
  width: auto;
  max-width: 100%;
  color: var(--secondary-color);
  font-size: var(--font-xs);
  font-weight: 700;
  letter-spacing: 0.01em;
  text-align: left;
  flex-wrap: wrap;
}

.site-form__field label > .site-form__label-text,
.site-form__field label > .site-form__required {
  display: inline;
  flex: 0 0 auto;
}

.site-form__label-text {
  display: inline;
}

.site-form__required {
  color: var(--site-form-danger);
  display: inline;
}

.site-form__help,
.site-form__group-help {
  color: var(--site-form-text-muted);
  font-size: 0.8rem;
  line-height: 1.5;
}

.site-form input:not([type=radio]):not([type=checkbox]):not([type=hidden]),
.site-form select,
.site-form textarea,
.check-location input {
  width: 100%;
  min-height: calc(var(--space-md) + var(--space-sm) + var(--space-xs));
  padding: var(--space-sm) calc(var(--space-sm) + var(--space-xs));
  border: 1px solid var(--site-form-line-strong);
  border-radius: var(--site-form-field-radius);
  background: #fff;
  color: var(--secondary-color);
  font: inherit;
  line-height: 1.35;
  transition: border-color 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
}

.site-form textarea {
  min-height: calc(var(--space-xl) + var(--space-lg));
  resize: vertical;
}

.site-form input::placeholder,
.site-form textarea::placeholder,
.check-location input::placeholder {
  color: rgba(126, 109, 90, 0.7);
}

.site-form input:hover,
.site-form select:hover,
.site-form textarea:hover,
.check-location input:hover {
  border-color: rgba(153, 136, 113, 0.68);
}

.site-form input:focus,
.site-form select:focus,
.site-form textarea:focus,
.check-location input:focus {
  outline: none;
  border-color: var(--site-form-focus);
  box-shadow: 0 0 0 3px var(--site-form-focus-ring);
  background-color: #ffffff;
}

.site-form select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: calc(var(--space-lg) + var(--space-sm));
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.25L6 6.25L11 1.25' stroke='%23231F20' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-position: right var(--space-sm) center;
  background-size: 0.75rem 0.5rem;
  background-repeat: no-repeat;
}

.site-form select::-ms-expand {
  display: none;
}

.site-form input[type=file] {
  padding: var(--space-xs);
  background: #fff;
}

.site-form input[type=file]::file-selector-button {
  margin-right: 0.9rem;
  padding: var(--space-xs) calc(var(--space-sm) + var(--space-xs));
  border: 1px solid rgba(35, 31, 32, 0.14);
  border-radius: var(--site-form-field-radius);
  background: var(--primary-color-soft);
  color: var(--secondary-color);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.site-form__group {
  padding: var(--space-sm);
  border: 1px solid var(--site-form-line);
  border-radius: calc(var(--site-form-field-radius) + var(--site-form-group-gap));
  background: transparent;
}

.site-form__group-header {
  display: grid;
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
}

.site-form__group-title {
  margin: 0;
  color: var(--secondary-color);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.2;
}

.site-form__group-body {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: var(--site-form-group-gap);
}

.site-form__group--compact {
  padding: var(--space-sm);
  background: var(--site-form-surface-soft);
}

.site-form__group--compact .site-form__group-title {
  font-size: 0.95rem;
}

.site-form__location-summary {
  padding: var(--space-sm) calc(var(--space-sm) + var(--space-xs));
  border: 1px solid var(--site-form-line-strong);
  border-radius: var(--site-form-field-radius);
  background: #fff;
}

.site-form__location-name {
  color: var(--secondary-color);
  font-weight: 700;
}

.site-form__location-meta {
  margin-top: 0.2rem;
  color: var(--site-form-text-muted);
  font-size: 0.86rem;
  line-height: 1.45;
}

.site-form__error {
  color: var(--site-form-danger);
  font-size: 0.84rem;
  font-weight: 600;
  line-height: 1.4;
}

.site-form__field.is-error input,
.site-form__field.is-error select,
.site-form__field.is-error textarea,
.site-form__field.is-error .site-form__location-summary {
  border-color: rgba(177, 66, 41, 0.62);
  box-shadow: 0 0 0 3px rgba(177, 66, 41, 0.1);
}

.site-form__field.is-error label {
  color: var(--site-form-danger);
}

.site-form__counter {
  min-height: 1.1rem;
  color: var(--site-form-text-muted);
  font-size: 0.78rem;
  text-align: right;
}

.site-form__counter.is-warning {
  color: #946100;
}

.site-form__counter.is-danger {
  color: var(--site-form-danger);
}

.site-form__actions {
  grid-column: 1/-1;
  display: block;
  margin-top: var(--space-sm);
}

.site-form__actions .button-wrapper {
  min-height: 44px;
  display: block;
  width: 100%;
}

.site-form__submit {
  appearance: none;
  -webkit-appearance: none;
  display: block;
  min-height: 44px;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: inherit;
  cursor: pointer;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  text-align: inherit;
  width: 100%;
}

.site-form__submit .button-trendy {
  min-height: 44px;
  width: 100%;
}

.site-form__submit .button-label {
  display: flex;
  justify-content: center;
  width: 100%;
  gap: 0.4em;
}

.site-form button.site-form__submit[type=submit],
.site-form button.site-form__submit[type=submit]:hover,
.site-form button.site-form__submit[type=submit]:focus,
.site-form button.site-form__submit[type=submit]:active {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: inherit;
  filter: none;
  transform: none;
}

.site-form button.site-form__submit[type=submit]:focus-visible {
  outline: none;
}

.site-form button.site-form__submit[type=submit]:focus-visible .button-trendy {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 0 var(--secondary-color);
}

.site-form__honeypot {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

body#contact .content-lister > h2 {
  font-size: clamp(2.1rem, 5vw, 3rem);
  line-height: 0.95;
}

body#contact .content-lister > p,
body#contact .content-lister > ul {
  max-width: 48rem;
}

body#contact .content-lister > ul {
  display: grid;
  gap: 0.55rem;
}

body#contact .content-lister > ul li {
  position: relative;
  padding-left: 1.2rem;
  line-height: 1.45;
}

body#contact .content-lister > ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62rem;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(255, 212, 37, 0.22);
}

.check-location {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  width: min(100%, 760px);
  padding: var(--padding-medium);
  border: 1px solid var(--accent-color);
  border-radius: var(--border-radius);
  background: #fff;
}

.check-location .check-location__button {
  appearance: none;
  -webkit-appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 13rem;
  min-height: 44px;
  margin: 0;
  border: 2px solid var(--secondary-color);
  border-radius: var(--border-radius);
  background: var(--primary-color-soft);
  box-shadow: 2px 2px 0 0 var(--secondary-color);
  color: var(--secondary-color);
  cursor: pointer;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.1;
  text-transform: none;
  padding: var(--padding-text);
}

.check-location .check-location__button:hover,
.check-location .check-location__button:focus {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 0 var(--secondary-color);
  background: var(--primary-color-soft);
  color: var(--secondary-color);
}

.check-location .check-location__button:active {
  transform: translateY(0);
}

#result {
  width: min(100%, 540px);
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.result-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--secondary-color);
  font-weight: 700;
  text-decoration: none;
}

@media (max-width: 900px) {
  .site-form__field--half,
  .site-form__field--third {
    grid-column: 1/-1;
  }
  .check-location {
    grid-template-columns: 1fr;
  }
  .check-location .check-location__button,
  .site-form__submit {
    width: 100%;
  }
}
.location-menu-section {
  padding: var(--padding-large) 0;
}

.location-menu-shell {
  gap: var(--padding-medium);
}

.location-menu-shell__intro {
  max-width: 760px;
}

.location-menu-shell__intro h2 {
  text-transform: uppercase;
}

.location-menu-subsection {
  gap: var(--padding-medium);
}

.location-menu-subsection__header {
  max-width: 760px;
}

.location-menu-subsection__header h3 {
  text-transform: uppercase;
}

.location-menu-product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--padding-medium);
}

.location-menu-product-card,
.location-menu-flavor-group {
  background: var(--tertiary-color);
  border: 2px solid var(--secondary-color);
  border-radius: var(--border-radius-small);
  overflow: hidden;
}

.location-menu-product-card__accent,
.location-menu-flavor-group::before {
  content: "";
  display: block;
  height: 10px;
  background: var(--primary-color);
}

.location-menu-product-card__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px;
  align-items: center;
  gap: var(--padding-medium);
  padding: var(--padding-medium);
}

.location-menu-product-card__copy h3,
.location-menu-flavor-group__header h3 {
  font-family: var(--decorative-font);
  color: var(--secondary-color);
}

.location-menu-product-card__detail {
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.location-menu-product-card__image {
  max-height: 120px;
}

.location-menu-product-card__image img {
  max-height: 120px;
}

.location-menu-flavor-groups {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--padding-medium);
}

.location-menu-flavor-group__header {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--padding-small);
  padding: var(--padding-medium);
  padding-bottom: 0;
}

.location-menu-flavor-group__count {
  white-space: nowrap;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  opacity: 0.7;
}

.location-flavor-pill-list {
  list-style: none;
  margin: 0;
  padding: var(--padding-medium);
  display: flex;
  flex-wrap: wrap;
  gap: var(--padding-small);
}

.location-flavor-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  min-height: 44px;
  padding: 0.45rem 0.75rem;
  border: 1px solid rgba(35, 31, 32, 0.14);
  border-radius: calc(var(--border-radius-small) + 2px);
  background: white;
}

.location-flavor-pill__swatch {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 1px solid rgba(35, 31, 32, 0.2);
  flex-shrink: 0;
}

.location-flavor-pill__name {
  font-weight: 600;
}

.flavor-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  background: var(--accent-color);
  color: var(--secondary-color);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.flavor-pill--limited {
  background: var(--primary-color);
}

.location-menu-empty {
  padding: 0 var(--padding-medium) var(--padding-medium);
  opacity: 0.7;
}

.location-menu-footer__link {
  font-weight: 600;
}

@media only screen and (max-width: 900px) {
  .location-menu-product-grid,
  .location-menu-flavor-groups {
    grid-template-columns: 1fr;
  }
}
@media only screen and (max-width: 700px) {
  .location-menu-section {
    padding: var(--padding-medium) 0;
  }
  .location-menu-product-card__body {
    grid-template-columns: 1fr;
  }
  .location-menu-product-card__image,
  .location-menu-product-card__image img {
    max-height: 100px;
  }
  .location-menu-flavor-group__header {
    flex-direction: column;
  }
}
main > * + * {
  margin-block-start: 0;
}

/*# sourceMappingURL=site.css.map */
