/*
 Theme Name:    Halo
 Author:        Mainostoimisto Halo Oy
 Author URI:    https://halo.fi
 Description:   Basic theme template
 Version:       1.5
*/

:root {
    -moz-text-size-adjust: none;
    -webkit-text-size-adjust: none;
    text-size-adjust: none;
    -webkit-tap-highlight-color: transparent;

    font-size: clamp(75%, calc(1vw + 1px), 100%);

    --ff: 'Barlow', sans-serif;
    --hff: 'Barlow Condensed', sans-serif;

    --fs-s: 0.8rem;
    --fs-base: 1rem;
    --fs-m: 1.2rem;
    --fs-l: 1.4rem;
    --fs-xl: 1.6rem;
    --fs-xxl: 2rem;
    --fs-xxxl: 2.4rem;

    --fw-base: 400;
    --fw-heading: 600;
    --fw-bold: 700;

    --primary-clr-200: #158CD6;
    --primary-clr-400: #067BC4;
    --primary-clr-800: #05162b;

    --secondary-clr-200: #e56d95;
    --secondary-clr-400: #CC5F83;

    --tertiary-clr-400: #F7F7F7;

    --black-200: #4d4d4d;
    --black-400: #000;

    --header-clr: var(--tertiary-clr-400);
    --text-clr: var(--tertiary-clr-400);
    --text-hover-clr: var(--tertiary-clr-400);

    --link-clr: var(--tertiary-clr-400);
    --link-highlight: var(--tertiary-clr-400);

    --e-clr: var(--tertiary-clr-400);
    --bg-clr: var(--primary-clr-400);
    --bg-hover-clr: var(--primary-clr-200);

    --horizontal-p: 2rem;

    --basic-transition: 200ms ease;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--ff);
    font-size: var(--fs-base);
    font-weight: var(--fw-base);
}

.bg--blue {
    background-color: var(--_bg-clr, var(--bg-clr));

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_text-hover-clr: var(--tertiary-clr-400);

    --_link-clr: var(--tertiary-clr-400);
    --_link-highlight: var(--tertiary-clr-400);

    --_e-clr: var(--tertiary-clr-400);
    --_bg-clr: var(--primary-clr-400);
    --_bg-hover-clr: var(--primary-clr-200);
}

.bg--blue--dark {
    background-color: var(--_bg-clr, var(--bg-clr));

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_text-hover-clr: var(--tertiary-clr-400);

    --_link-clr: var(--primary-clr-400);
    --_link-highlight: var(--primary-clr-200);

    --_e-clr: var(--primary-clr-400);
    --_bg-clr: var(--primary-clr-800);
    --_bg-hover-clr: var(--primary-clr-200);
}

.bg--red {
    background-color: var(--_bg-clr, var(--bg-clr));

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_text-hover-clr: var(--tertiary-clr-400);

    --_link-clr: var(--tertiary-clr-400);
    --_link-highlight: var(--tertiary-clr-400);

    --_e-clr: var(--tertiary-clr-400);
    --_bg-clr: var(--secondary-clr-400);
    --_bg-hover-clr: var(--secondary-clr-200);
}

.bg--white {
    background-color: var(--_bg-clr, var(--bg-clr));

    --_header-clr: var(--primary-clr-400);
    --_text-clr: var(--black-400);
    --_text-hover-clr: var(--tertiary-clr-400);

    --_link-clr: var(--primary-clr-400);
    --_link-highlight: var(--primary-clr-200);

    --_e-clr: var(--primary-clr-400);
    --_bg-clr: var(--tertiary-clr-400);
    --_bg-hover-clr: var(--black-400);
}

.bg--black {
    background-color: var(--_bg-clr, var(--bg-clr));

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_text-hover-clr: var(--tertiary-clr-400);

    --_link-clr: var(--tertiary-clr-400);
    --_link-highlight: var(--tertiary-clr-400);

    --_e-clr: var(--tertiary-clr-400);
    --_bg-clr: var(--black-400);
    --_bg-hover-clr: var(--primary-clr-200);
}

.bg--grey {
    background-color: var(--_bg-clr, var(--bg-clr));

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_text-hover-clr: var(--tertiary-clr-400);

    --_link-clr: var(--tertiary-clr-400);
    --_link-highlight: var(--tertiary-clr-400);

    --_e-clr: var(--tertiary-clr-400);
    --_bg-clr: var(--black-200);
    --_bg-hover-clr: var(--black-400);
}

p, .text-small {
    margin: 0 0 1em;
    color: var(--_text-clr, var(--text-clr));
}

.text-small {
    font-size: var(--fs-s);
}

.text-big {
    font-size: var(--fs-m);
}

.text-align--center {
    text-align: center;
}

.text-align-mobile--center {
    text-align: center;
}

.heading--primary,
.heading--secondary,
.heading--tertiary,
.heading--quaternary,
.heading--quinary,
.heading--senary,
h1, h2, h3, h4, h5, h6 {
    margin: 0 0 0.5em;
    color: var(--_header-clr, var(--header-clr));
    font-family: var(--hff);
    font-weight: var(--fw-heading);
    text-transform: uppercase;
}

h1,
.heading--primary {
    font-size: var(--fs-xxxl);
}

h2,
.heading--secondary {
    font-size: var(--fs-xxl);
}

h3,
.heading--tertiary {
    font-size: var(--fs-xl);
}

h4,
.heading--quaternary {
    font-size: var(--fs-l);
}

h5,
.heading--quinary {
    font-size: var(--fs-m);
}

h6,
.heading--senary {
    font-size: var(--fs-base);
}

.heading--normal-case {
    text-transform: none;
}

a {
    text-decoration: none;
    color: var(--_text-clr, var(--text-clr));
    margin: 0;
    font-family: var(--ff);
    font-weight: inherit;
    font-style: normal;
}

p a {
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-color: initial;
    text-decoration-thickness: 0.1em;
    text-underline-offset: 0.3em;
    color: var(--_link-clr, var(--link-clr));
}

p a:is(:hover, :focus-visible) {
    color: var(--_link-highlight, var(--link-highlight));
}

.text-box {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 0.4em;
    margin: 0;
    padding: 0.25em 1em;
    width: 100%;
    text-align: center;
    font-family: var(--hff);
    font-weight: var(--fw-heading);
    text-transform: uppercase;
    box-sizing: border-box;
}

.text-box--large {
    padding: 0.6em 2em;
}

.text-box--fit-content {
    width: fit-content;
}

.text-box--skewed {
    position: relative;
    background-color: transparent;
}

.text-box--skewed::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: var(--_bg-clr, var(--bg-clr));
    transform: skewX(-15deg);
    z-index: -1;
}

.text-box--outline {
    background-color: transparent;
    border: 1px solid var(--_e-clr, var(--e-clr));
    color: var(--_text-clr, var(--text-clr));
}

.text-box--btn {
    transition: background-color var(--_basic-transition, var(--basic-transition)), color var(--_basic-transition, var(--basic-transition));
    cursor: pointer;
}

.text-box--btn:is(:hover, :focus-visible) {
    background-color: var(--_bg-hover-clr, var(--bg-hover-clr));
}

.text-box--skewed.text-box--btn {
    background-color: transparent;
}

.text-box--skewed.text-box--btn::before {
    transition: background-color var(--_basic-transition, var(--basic-transition));
}

.text-box--skewed.text-box--btn:is(:hover, :focus-visible)::before {
    background-color: var(--_bg-hover-clr, var(--bg-hover-clr));
}

.text-box--outline.text-box--btn:is(:hover, :focus-visible) {
    background-color: var(--_e-clr, var(--e-clr));
    color: var(--black-400);
}

.text-box__icon {
    width: 0.8em;
    fill: var(--_text-clr, var(--text-clr));
    transition: fill var(--_basic-transition, var(--basic-transition));
}

.text-box--btn:is(:hover, :focus-visible) .text-box__icon {
    fill: var(--_text-hover-clr, var(--text-hover-clr));
}

::selection {
    background-color: var(--_text-clr, var(--text-clr));
    color: var(--_bg-clr, var(--bg-clr));
}

figure {
    margin: 0;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
    font-style: italic;
    background-repeat: no-repeat;
    background-size: cover;
}



/* =========== HEADER =========== */


.page-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    display: grid;
    grid-template-columns: auto 1fr;
    padding: 3rem var(--horizontal-p);
    height: 7rem;
    transition: transform 300ms ease, background-color 300ms ease, height 300ms ease, padding 300ms ease;
    z-index: 100;
}

.page-header__logo {
    position: relative;
    z-index: 1;
}

.page-header__logo__icon {
    position: absolute;
    left: 4.5rem;
    max-width: none;
    width: 3rem;
    transform: translateX(-50%);
    transition: transform 300ms ease;
}

.page-header__logo__text {
    position: absolute;
    top: 3rem;
    max-width: none;
    width: 9rem;
    transition: transform 300ms ease, opacity 200ms ease;
}

.page-header--small {
    padding-block: 1rem;
    height: 4rem;
    background-color: var(--primary-clr-400);
}

.page-header--small .page-header__logo__icon {
    transform: translate(-4.5rem, 0.4rem) scale(1.2);
}

.page-header--small .page-header__logo__text {
    opacity: 0;
    transform: translate(4rem, -2rem);
}

.page-header__nav {
    display: grid;
    justify-content: end;
    align-content: center;
}

.menu-button {
    position: relative;
    padding: 0;
    width: 4rem;
    height: 4rem;
    border: 1px solid transparent;
    outline: none;
    background: transparent;
    fill: var(--tertiary-clr-400);
    cursor: pointer;
    z-index: 1;
}

.menu-button__hamburger {
    width: 100%;
    pointer-events: none;
}

.menu-button__hamburger__line {
    transition: y 100ms ease-in 100ms, rotate 100ms ease-in, opacity 0ms 100ms;
    transform-origin: center;
}

.menu-button[aria-expanded="true"] .menu-button__hamburger__line {
    transition: y 100ms ease-in, rotate 100ms ease-in 100ms, opacity 0ms 100ms;
}

.menu-button[aria-expanded="true"] :is(.menu-button__hamburger__line--top, .menu-button__hamburger__line--bottom) {
    y: 43px;
}

.menu-button[aria-expanded="true"] .menu-button__hamburger__line--top {
    rotate: 45deg;
}

.menu-button[aria-expanded="true"] .menu-button__hamburger__line--middle {
    opacity: 0;
}

.menu-button[aria-expanded="true"] .menu-button__hamburger__line--bottom {
    rotate: 135deg;
}

.primary-navigation {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: grid;
    align-content: safe center;
    gap: 2rem;
    margin: 0;
    padding: 14rem 0;
    height: 100vh;
    height: 100lvh;
    background-color: hsla(0, 0%, 0%, 0.4);
    text-align: center;
    list-style: none;
    text-transform: uppercase;
    backdrop-filter: blur(10px);
    overflow: auto;
}

.primary-navigation a {
    font-size: var(--fs-xxxl);
    font-family: var(--hff);
    font-weight: var(--fw-heading);
}

.primary-navigation[data-state="open"] {
    animation: primaryMenuOpen 300ms ease forwards;
}

.primary-navigation[data-state="closing"] {
    animation: primaryMenuClose 300ms ease forwards;
}

.primary-navigation[data-state="closed"] {
    display: none;
}

@keyframes primaryMenuOpen {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

@keyframes primaryMenuClose {
    0% { opacity: 1; }
    100% { opacity: 0; }
}



/* =========== MAIN =========== */


.content-grid {
    --_padding-inline: var(--horizontal-p);
    --_content-max-width: 50rem;
    --_large-max-width: 66rem;

    --_content-width: min(100% - (var(--_padding-inline) * 2), var(--_content-max-width));
    --_large-width: minmax(0, calc((var(--_large-max-width) - var(--_content-max-width)) / 2));
    --_full-width: minmax(var(--_padding-inline), 1fr);

    display: grid;
    grid-template-columns: [full-width-start] var(--_full-width) [large-start] var(--_large-width) [content-start] var(--_content-width) [content-end] var(--_large-width) [large-end] var(--_full-width) [full-width-end];
}

.content-grid > :not(.content-grid__large, .content-grid__full-width) {
    grid-column: content;
}

.content-grid > .content-grid__large {
    grid-column: large;
}

.content-grid > .content-grid__full-width {
    grid-column: full-width;
}

.content-grid__center {
    justify-self: center;
}

.page-bg {
    position: fixed;
    inset: 0;
    z-index: -1;
}

.page-bg__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 60% 50%;
}

.grid {
    display: grid;
}

.grid--4 {
    display: grid;
    grid-template-columns: 1fr;
}

.grid--3 {
    display: grid;
    grid-template-columns: 1fr;
}

.grid--2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}

.grid--1-2 {
    display: grid;
    grid-template-columns: 1fr;
}

.align-start {
    align-content: start;
}

.gap--xs {
    gap: 0.2rem;
}

.gap--s {
    gap: 0.4rem;
}

.gap--m {
    gap: 0.6rem;
}

.gap--l {
    gap: 1.2rem;
}

.m--xxs {
    margin-bottom: 0.3rem;
}

.m--xs {
    margin-bottom: 0.6rem;
}

.m--s {
    margin-bottom: 1rem;
}

.m--m {
    margin-bottom: 2rem;
}

.m--l {
    margin-bottom: 3rem;
}

.m--xl {
    margin-bottom: 3.5rem;
}

.m-t--xxs {
    margin-top: 0.3rem;
}

.m-t--xs {
    margin-top: 0.6rem;
}

.m-t--s {
    margin-top: 1rem;
}

.m-t--m {
    margin-top: 2rem;
}

.m-t--l {
    margin-top: 3rem;
}

.m-t--xl {
    margin-top: 3.5rem;
}

.p--xs {
    padding: 0.6rem;
}

.p--s {
    padding: 1rem;
}

.p--m {
    padding: 2rem;
}

.p--l {
    padding: 3rem;
}

.p--xl {
    padding: 3.5rem;
}

.p-i--s {
    padding-inline: 1rem;
}

.p-i--m {
    padding-inline: 2rem;
}

.p-i--l {
    padding-inline: 3rem;
}

.banner--front-page {
    align-content: end;
    padding: 20rem 0 6rem;
    min-height: 100vh;
    min-height: 100lvh;
    box-sizing: border-box;
}

.waltteri-logo {
    justify-self: center;
    margin-bottom: 4rem;
}

.secondary-navigation {
    display: grid;
    grid-template-columns: 1fr;
    margin: 0;
    padding: 0;
    list-style: none;
}

.casino-card__logo {
    display: grid;
    justify-content: center;
    height: 5rem;
}

.casino-card--big__logo img,
.casino-card__logo img {
    width: auto;
    height: 100%;
    object-fit: contain;
}

.casino-card--big {
    display: grid;
    grid-template-columns: 1fr;   
}

.casino-card--big__logo img {
    object-fit: cover;
}

.casino-card__pinnacle {
    width: 6rem;
}

.blue-overlay {
    padding: 4rem 0;
    background-color: hsla(203, 94%, 40%, 0.80);
    clip-path: polygon(0 0, calc(50% - 1.5rem) 0, 50% 1.5rem, calc(50% + 1.5rem) 0, 100% 0, 100% 100%, 0 100%);
}

.separator {
    border-bottom: 1px solid var(--_e-clr, var(--e-clr));
}

.star-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.star-list li::before {
    content: '★';
    padding-right: 0.3em;
    color: var(--_e-clr, var(--e-clr));
}

.welcome-pop-up {
    position: fixed;
    display: grid;
    inset: 0;
    align-content: center;
    justify-content: center;
    padding: 0 var(--horizontal-p);
    backdrop-filter: blur(10px);
    z-index: 10000;
}

.welcome-pop-up[data-state="open"] {
    animation: popUpOpen 300ms ease forwards;
}

.welcome-pop-up[data-state="closing"] {
    animation: popUpClose 300ms ease forwards;
}

.welcome-pop-up[data-state="closed"] {
    display: none;
}

@keyframes popUpOpen {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

@keyframes popUpClose {
    0% { opacity: 1; }
    100% { opacity: 0; }
}

.welcome-pop-up__inner {
    max-width: 30rem;
}

.welcome-pop-up__coin {
    display: grid;
    justify-content: center;
}

.welcome-pop-up__btns {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.welcome-pop-up__btns > :first-child {
    justify-self: end;
}

.welcome-pop-up__disclaimer p {
    font-size: var(--fs-s);
    margin-bottom: 0.5em;
}

.coin-scene {
    position: relative;;
    width: 1em;
    height: 1em;
    font-size: var(--_coin-size);
    perspective: 12.5em;
    perspective-origin: 50%;

    --_coin-size: 6rem;
    --_coin-thickness: 0.1em;
}

.coin-scene__wrapper {
    position: absolute;
    inset: 0;
    transform-style: preserve-3d;
    transform: rotateX(var(--_rotateX)) rotateY(var(--_rotateY));
    animation: coinRotate 10s linear infinite;
    
    --_rotateX: 0deg;
    --_rotateY: 0deg;
}

@keyframes coinRotate {
    0% { transform: rotateY(0deg) rotateX(0deg) }
    100% { transform: rotateY(360deg) rotateX(-1080deg) }
}

.coin-scene__top,
.coin-scene__bottom {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
}

.coin-scene__top {
    transform: translateZ(calc(var(--_coin-thickness) / 2));
}

.coin-scene__bottom {
    transform: translateZ(calc(var(--_coin-thickness) / 2 * -1)) rotateY(180deg) scaleX(-1);
}

.coin-scene__side {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: rotateY(90deg) rotateX(-4.8deg);
    transform-style: preserve-3d;

    --_side-rotate-base: 10deg;
    --_rotate-gap: calc(var(--_side-rotate-base) * 3);
}

.coin-scene__side--piece {
    position: absolute;
    top: 50%;
    left: 50%;
    width: var(--_coin-thickness);
    height: 0.09em;
    transform-origin: top;
    transform: rotateX(var(--_side-rotate)) translate(-50%, -50%);
    transform-style: preserve-3d;
}

.coin-scene__side--piece::after {
    content: '';
    position: absolute;
    inset: 0;
    background-color: #fefefe;
    backface-visibility: hidden;
    transform: translateZ(calc(var(--_coin-size) / 2 - 1px));
}

.coin-scene__side--piece-1 {
    --_side-rotate: var(--_side-rotate-base);
}
.coin-scene__side--piece-2 {
    --_side-rotate: calc(var(--_side-rotate-base) * 2);
}
.coin-scene__side--piece-3 {
    --_side-rotate: calc(var(--_side-rotate-base) * 3);
}
.coin-scene__side--piece-4 {
    --_side-rotate: calc(var(--_side-rotate-base) * 4 + var(--_rotate-gap));
}
.coin-scene__side--piece-5 {
    --_side-rotate: calc(var(--_side-rotate-base) * 5 + var(--_rotate-gap));
}
.coin-scene__side--piece-6 {
    --_side-rotate: calc(var(--_side-rotate-base) * 6 + var(--_rotate-gap));
}
.coin-scene__side--piece-7 {
    --_side-rotate: calc(var(--_side-rotate-base) * 7 + var(--_rotate-gap) * 2);
}
.coin-scene__side--piece-8 {
    --_side-rotate: calc(var(--_side-rotate-base) * 8 + var(--_rotate-gap) * 2);
}
.coin-scene__side--piece-9 {
    --_side-rotate: calc(var(--_side-rotate-base) * 9 + var(--_rotate-gap) * 2);
}
.coin-scene__side--piece-10 {
    --_side-rotate: calc(var(--_side-rotate-base) * 10 + var(--_rotate-gap) * 3);
}
.coin-scene__side--piece-11 {
    --_side-rotate: calc(var(--_side-rotate-base) * 11 + var(--_rotate-gap) * 3);
}
.coin-scene__side--piece-12 {
    --_side-rotate: calc(var(--_side-rotate-base) * 12 + var(--_rotate-gap) * 3);
}
.coin-scene__side--piece-13 {
    --_side-rotate: calc(var(--_side-rotate-base) * 13 + var(--_rotate-gap) * 4);
}
.coin-scene__side--piece-14 {
    --_side-rotate: calc(var(--_side-rotate-base) * 14 + var(--_rotate-gap) * 4);
}
.coin-scene__side--piece-15 {
    --_side-rotate: calc(var(--_side-rotate-base) * 15 + var(--_rotate-gap) * 4);
}
.coin-scene__side--piece-16 {
    --_side-rotate: calc(var(--_side-rotate-base) * 16 + var(--_rotate-gap) * 5);
}
.coin-scene__side--piece-17 {
    --_side-rotate: calc(var(--_side-rotate-base) * 17 + var(--_rotate-gap) * 5);
}
.coin-scene__side--piece-18 {
    --_side-rotate: calc(var(--_side-rotate-base) * 18 + var(--_rotate-gap) * 5);
}



/* =========== FOOTER =========== */


.page-footer {
    padding-top: 4rem;
}

.page-footer__logo {
    justify-self: center;
    width: 12rem;
    padding-bottom: 3rem;
}



/* =========== WORDPRESS =========== */


.editor-styles-wrapper {
    --header-clr: var(--primary-clr-400);
    --text-clr: var(--black-400);
    --link-clr: var(--primary-clr-400);
    --link-highlight: var(--primary-clr-200);
}



/* =========== GRAVITY FORMS =========== */


.page-footer__form {
    margin-top: 4.5rem;
}

.gform_wrapper .gform_fields {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.gfield {
    flex-grow: 1;
    flex-basis: 100%;
}

.gfield--width-half {
    flex-basis: unset;
}

.ginput_container > input,
.ginput_container > textarea {
    display: block;
    padding: 0.8rem 1.2rem;
    width: 100%;
    background: var(--tertiary-clr-400);
    border: none;
    outline: 1px solid transparent;
    font-family: var(--ff);
    font-size: var(--fs-base);
    color: var(--black-400);
    box-sizing: border-box;
}

.ginput_container > textarea {
    min-height: 2.7875rem;
    height: 10rem;
    resize: vertical;
}

.ginput_container > input::-webkit-input-placeholder,
.ginput_container > input::placeholder,
.ginput_container > textarea::-webkit-input-placeholder,
.ginput_container > textarea::placeholder {
    color: var(--black-400);
    font-size: var(--fs-base);
}

.hidden_label .gfield_label {
    display: none;
}

.gfield_required {
    color: var(--_e-clr, var(--e-clr));
}

.gform_button {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 0.4em;
    margin: 1rem 0 0 0;
    padding: 0.6em 2em;
    background-color: transparent;
    border: 1px solid var(--_e-clr, var(--e-clr));
    border-radius: 0;
    color: var(--_text-clr, var(--text-clr));
    text-align: center;
    font-size: var(--fs-m);
    font-family: var(--hff);
    font-weight: var(--fw-heading);
    text-transform: uppercase;
    box-sizing: border-box;
    transition: background-color var(--_basic-transition, var(--basic-transition)), color var(--_basic-transition, var(--basic-transition));
    cursor: pointer;
}

.gform_button:is(:hover, :focus-visible) {
    background-color: var(--_e-clr, var(--e-clr));
    color: var(--black-400);
}

.gform_submission_error {
    font-size: var(--fs-m);
    color: var(--_header-clr, var(--header-clr));
}

.gfield_description {
    padding: 1rem 1.4rem 0;
    font-size: var(--fs-s);
    color: var(--_header-clr, var(--header-clr));
}

.gform_confirmation_wrapper {
    display: grid;
    height: 100%;
    align-content: center;
}

.gform_confirmation_message {
    color: var(--_text-clr, var(--text-clr));
    text-align: center;
    font-size: var(--fs-l);
    font-family: var(--hff);
}

.gfield--type-honeypot {
    display: none;
}

.gform_heading {
    display: none;
}

.gform_hidden {
    display: none;
}



@media only screen and (min-width: 32rem) {
    .grid--4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media only screen and (min-width: 52rem) {
    :root {
        --horizontal-p: 4rem;
    }
    .text-align-mobile--center {
        text-align: left;
    }
    .grid--4 {
        grid-template-columns: repeat(4, 1fr);
    }
    .grid--3 {
        grid-template-columns: repeat(3, 1fr);
    }
    .grid--1-2 {
        grid-template-columns: 1fr 2fr;
    }
    .waltteri-logo {
        margin-bottom: 2rem;
    }
    .secondary-navigation {
        grid-template-columns: repeat(4, 1fr);
    }
    .casino-card--big {
        grid-template-columns: 6fr 5fr;
    }
    .page-footer__logo {
        justify-self: start;
    }
}

@media only screen and (min-width: 58rem) {
    .menu-button {
        display: none;
    }
    .primary-navigation.primary-navigation {
        position: static;
        display: flex;
        gap: 0;
        padding: 0;
        height: auto;
        background-color: transparent;
        backdrop-filter: none;
        overflow: unset;
    }
    .primary-navigation li {
        position: relative;
    }
    .primary-navigation li + li {
        padding-left: 2rem;
    }
    .primary-navigation li:not(:last-child) {
        padding-right: 2rem;
    }
    .primary-navigation li + li::after {
        content: '';
        position: absolute;
        top: -0.6rem;
        left: 0;
        height: 3rem;
        border-left: 1px solid var(--tertiary-clr-400);
        transform: rotate(15deg);
    }
    .primary-navigation a {
        font-size: var(--fs-l);
    }
}

@media only screen and (min-width: 94rem) {
    :root {
        font-size: max(0.8vw, 100%);
    }
}