/*
 Theme Name:    Mistä vetoa
 Author:        Mainostoimisto Halo Oy
 Author URI:    https://halo.fi
 Description:   Basic theme template
 Version:       1.3
*/

: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: 'Titillium Web', sans-serif;

    --fs-base: 1rem;
    --fs-m: 1.2rem;
    --fs-l: 1.4rem;
    --fs-xl: 1.8rem;
    --fs-xxl: 2.2rem;
    --fs-xxxl: clamp(2.6rem, 6vw, 4rem);

    --fw-base: 400;
    --fw-bold: 700;

    --lh-s: 1em;
    --lh-base: 1.5em;

    --primary-clr-400: #FF8961;
    --primary-clr-600: #f36738;

    --secondary-clr-200: #707070;
    --secondary-clr-400: #1a1a1a;
    --secondary-clr-600: #000;

    --tertiary-clr-400: #fff;

    --header-clr: var(--tertiary-clr-400);
    --text-clr: var(--tertiary-clr-400);
    --link-clr: var(--primary-clr-400);
    --link-highlight: var(--primary-clr-600);

    --horizontal-padding: 1.5rem;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--ff);
    font-size: var(--fs-base);
    font-weight: var(--fw-base);
}

p {
    margin: 0 0 1em;
    color: var(--_text-clr, var(--text-clr));
    line-height: var(--lh-base);
}

.lead {
    font-size: var(--fs-l);
}

.heading--primary {
    font-size: var(--fs-xxxl);
}

.heading--secondary {
    font-size: var(--fs-xxl);
}

.heading--tertiary {
    font-size: var(--fs-xl);
}

.heading--quaternary {
    font-size: var(--fs-l);
}

h1, h2, h3, h4, h5, h6 {
    margin: 0 0 0.8em;
    color: var(--_header-clr, var(--header-clr));
    font-weight: var(--fw-base);
    line-height:  var(--lh-s);
}

.heading--underline {
    position: relative;
    margin-bottom: 1.2em;
}

.heading--underline::after {
    content: '';
    position: absolute;
    bottom: -0.6em;
    left: 0;
    max-width: 80%;
    width: 12rem;
    border-bottom: 1.5px solid var(--primary-clr-400);
}

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: transparent;
    text-decoration-thickness: 0.1em;
    text-underline-offset: 0.1em;
    color: var(--_link-clr, var(--link-clr));
    transition: text-underline-offset 200ms ease, text-decoration-color 300ms ease;
}

p a:is(:hover, :focus-visible) {
    text-decoration-color: initial;
    text-underline-offset: 0.35em;
    color: var(--_link-highlight, var(--link-highlight));
    transition: text-underline-offset 200ms ease, text-decoration-color 100ms ease;
}

::selection {
    background-color: var(--primary-clr-400);
    color: var(--tertiary-clr-400);
}

figure {
    margin: 0;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
    font-style: italic;
    background-repeat: no-repeat;
    background-size: cover;
}

.editor-styles-wrapper {
    --_header-clr: var(--secondary-clr-600);
    --_text-clr: var(--secondary-clr-600);
    --_bg-hover: var(--secondary-clr-600);
}

.bg-clr--orange {
    background-color: var(--primary-clr-400);

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_bg-hover: var(--secondary-clr-600);
}

.bg-clr--light {
    background-color: var(--tertiary-clr-400);

    --_header-clr: var(--secondary-clr-600);
    --_text-clr: var(--secondary-clr-600);
    --_bg-hover: var(--secondary-clr-600);
}

.bg-clr--dark {
    background-color: var(--secondary-clr-400);

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_bg-hover: var(--primary-clr-400);
}

.bg-clr--darkest {
    background-color: var(--secondary-clr-600);

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_bg-hover: var(--primary-clr-400);
}

.container--l {
    padding: 1.5rem;
}

.container--m {
    padding: 1.5rem;
}

.container--s {
    display: flex;
    align-items: center;
    gap: 0.5em;
    padding: 0.8em 1.5em;
    font-size: var(--fs-m);
    line-height: var(--lh-s);
}

.container--xs {
    display: flex;
    align-items: center;
    gap: 0.5em;
    padding: 0.8em 1.5em;
    font-size: var(--fs-base);
    line-height: var(--lh-s);
}

.container--text {
    padding: 0.1em 0.4em;
    color: var(--_text-clr, var(--text-clr));
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
}

.container--text--max-width {
    max-width: 50rem;
}

.container__icon {
    width: 0.8em;
    height: 0.8em;
    fill: var(--_text-clr);
    transform: scale(1.4);
}

.btn {
    transition: background-color 200ms ease;
    cursor: pointer;
}

.btn:is(:hover, :focus-visible) {
    background-color: var(--_bg-hover, var(--secondary-clr-600));
}

.btn--offset {
    position: absolute;
    bottom: 0;
    transform: translateY(50%);
}

.btn-3d-container {
    perspective: 1000px;
}

.btn-3d-container .btn {
    transform-origin: left;
    transform-style: preserve-3d;
    transition: background-color 200ms ease, transform 200ms ease;
}

.btn-3d-container .btn:is(:hover, :focus-visible) {
    background-color: var(--_bg-hover, var(--secondary-clr-600));
    transform: rotateY(-25deg);
}

.grid--col-1,
.grid--col-2 {
    display: grid;
    grid-template-columns: 1fr;
    column-gap: 1rem;
    row-gap: 2.6rem;
}

.grid--col-1 .grid__col {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
}

.grid--col-2 .grid__col {
    position: relative;
    display: grid;
    grid-template-rows: auto 1fr;
}

.text-on-img {
    display: grid;
    grid-template-areas: 'stack';
    align-items: end;
}

.text-on-img__stack {
    grid-area: stack;
}

.grid__col img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.wp-block-list,
.list {
    margin: 0 0 1em;
    padding: 0 0 0 2.5rem;
}

.wp-block-separator {
    border-top: 1.5px solid var(--primary-clr-400);
}

.wp-block-button__link {
    display: flex;
    align-items: center;
    gap: 0.5em;
    padding: 0.8em 1.5em;
    border-radius: 0;
    background-color: var(--primary-clr-400);
    font-size: var(--fs-m);
    line-height: var(--lh-s);
    transition: background-color 200ms ease;

    --_header-clr: var(--tertiary-clr-400);
    --_text-clr: var(--tertiary-clr-400);
    --_bg-hover: var(--secondary-clr-600);
}

.wp-block-button__link:is(:hover, :focus-visible) {
    background-color: var(--_bg-hover, var(--secondary-clr-600));
}

.wp-block-button.arrow .wp-block-button__link::after {
    content: '';
    width: 0.8em;
    height: 0.8em;
    background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" fill="%23ffffff" width="5" height="5"><path d="M40.23,76.71c-1.02,0-2.05-.39-2.83-1.17-1.56-1.56-1.56-4.09,0-5.66l19.87-19.86-19.87-19.87c-1.56-1.56-1.56-4.09,0-5.66,1.56-1.56,4.09-1.56,5.66,0l25.52,25.52-25.52,25.52c-.78.78-1.8,1.17-2.83,1.17Z"></path></svg>');
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    transform: scale(1.4);
}

.no-margin {
    margin: 0;
}



/* =========== HEADER =========== */


.page-header {
    margin-top: 2.8rem;
    margin-bottom: 5rem;
    z-index: 100;
}

.page-header__inner {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    column-gap: 2.5rem;
    font-size: var(--fs-l);
    line-height: var(--lh-s);
}

.page-header__logo {
    margin-bottom: 2rem;
    width: 6rem;
}

.menu-button {
    justify-self: end;
    position: relative;
    margin-bottom: 2rem;
    padding: 0;
    width: 4rem;
    border: 1px solid transparent;
    outline: none;
    background: transparent;
    fill: var(--tertiary-clr-400);
    cursor: pointer;
}

.hamburger {
    width: 100%;
    pointer-events: none;
}

.hamburger .line {
    transition: y 100ms ease-in 100ms, rotate 100ms ease-in, opacity 0ms 100ms;
    transform-origin: center;
}

.menu-button[aria-expanded="true"] .line {
    transition: y 100ms ease-in, rotate 100ms ease-in 100ms, opacity 0ms 100ms;
}

.menu-button[aria-expanded="true"] :is(.top, .bottom) {
    y: 43px;
}

.menu-button[aria-expanded="true"] .top {
    rotate: 45deg;
}

.menu-button[aria-expanded="true"] .middle {
    opacity: 0;
}

.menu-button[aria-expanded="true"] .bottom {
    rotate: 135deg;
}

.primary-navigation {
    display: grid;
    grid-template-rows: 0fr;
    grid-column: span 2;
    margin: 0 calc(var(--horizontal-padding) * -1);
    background-color: var(--secondary-clr-400);
}

.primary-navigation[data-state="opened"] {
    animation: primaryMenuOpen 300ms ease forwards;
}

.primary-navigation[data-state="closing"] {
    animation: primaryMenuClose 300ms ease forwards;
}

.primary-navigation[data-state="closed"] {
    display: grid;
}

@keyframes primaryMenuOpen {
    0% { grid-template-rows: 0fr; }
    100% { grid-template-rows: 1fr; }
}

@keyframes primaryMenuClose {
    0% { grid-template-rows: 1fr; }
    100% { grid-template-rows: 0fr; }
}

.primary-navigation__inner {
    overflow: hidden;
}

.primary-navigation__list {
    display: grid;
    margin: 0;
    padding: 2rem var(--horizontal-padding) 3rem;
    list-style: none;
}

.primary-navigation li {
    position: relative;
    padding: 1.8rem 0 1.2rem;
    color: var(--_text-clr, var(--text-clr));
}

.primary-navigation li::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 3rem;
    border-bottom: 1.5px solid var(--primary-clr-400);
}



/* =========== MAIN =========== */


.content-grid {
    --_padding-inline: var(--horizontal-padding);
    --_content-max-width: 68rem;
    --_large-max-width: 80rem;

    --_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(.large, .full-width) {
    grid-column: content;
}

.content-grid > .large {
    grid-column: large;
}

.content-grid > .full-width {
    grid-column: full-width;
}

.bg-img {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    height: 100lvh;
    pointer-events: none;
    z-index: -1;
}

.bg-img img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.post-content {
    margin-bottom: 3rem;
    padding-bottom: 4rem;
}

.post-content h1, 
.post-content h2, 
.post-content h3, 
.post-content h4, 
.post-content h5, 
.post-content h6 {
    padding-top: 0.5em;
}



/* =========== FOOTER =========== */


.footer__top {
    position: relative;
    margin-top: 10rem;
    padding: 6rem 0 4rem;
}

.footer__logo {
    position: absolute;
    top: 0;
    left: 50%;
    width: 6rem;
    transform: translate(-50%, -50%);
}

.footer__bottom {
    padding: 1rem 0;
}

.footer__bottom__inner {
    display: flex;
    justify-content: space-between;

    --_text-clr: var(--secondary-clr-200);
}

.transitioner {
    position: fixed;
    inset: 0;
    background-color: var(--secondary-clr-600);
    clip-path: inset(0 0 0 0);
    transition: clip-path 300ms ease-out;
    z-index: 9999;
}

.transitioner[data-transition="opened"] {
    clip-path: inset(0 0 0 0);
    animation: transitionerOpening 400ms ease forwards;
}

.transitioner[data-transition="closing"] {
    animation: transitionerClosing 400ms ease forwards;
}

@keyframes transitionerClosing {
    0% { clip-path: inset(100% 0 0 0); }
    80% { clip-path: inset(0 0 0 0); }
    100% { clip-path: inset(0 0 0 0); }
}

@keyframes transitionerOpening {
    0% { clip-path: inset(0 0 0 0); }
    20% { clip-path: inset(0 0 0 0); }
    100% { clip-path: inset(0 0 100% 0); }
}


@media only screen and (min-width: 40rem) {
    .container--l {
        padding: 2rem 8rem;
    }
    .grid--col-2 {
        grid-template-columns: repeat(2, 1fr);
    }
    .grid--col-1 .grid__col {
        position: relative;
        display: grid;
        grid-template-columns: 1fr 1fr;
    }
    .grid--col-1 .grid__col > :last-child {
        display: grid;
        align-content: end;
        padding-bottom: 3rem;
    }
    .grid--separator {
        column-gap: 0;
    }
    .grid--separator .grid__col + .grid__col {
        padding-left: 3rem;
        border-left: 1.5px solid var(--primary-clr-400);
    }
    .grid--separator .grid__col:not(:last-child) {
        padding-right: 3rem;
    }
    .post-content {
        padding-bottom: 6rem;
    }
}

@media only screen and (min-width: 54rem) {
    :root {
        --horizontal-padding: 2rem;
    }
    .page-header__logo {
        margin-bottom: 0;
    }
    .menu-button {
        display: none;
    }
    .primary-navigation.primary-navigation {
        display: block;
        grid-column: initial;
        margin: 0;
        background-color: transparent;
    }
    .primary-navigation__list {
        display: flex;
        padding: 0;
    }
    .primary-navigation li {
        padding: 0.6rem 0.8rem;
        max-width: 12rem;
        border-left: 1.5px solid var(--tertiary-clr-400);
    }
    .primary-navigation li::after {
        display: none;
    }
    .front-page--main {
        margin-top: clamp(0rem, 23vh, 15rem);
    }
}