/*
 Theme Name:    Tete de Moine AOP
 Author:        Mainostoimisto Halo Oy
 Author URI:    https://halo.fi
 Description:   Tete de Moine custom theme
 Version:       1.0
*/

@font-face {
    font-family: 'BodoniStd';
    src: url('./fonts/BodoniStd-BoldCondensed.woff2') format('woff2'),
         url('./fonts/BodoniStd-BoldCondensed.woff') format('woff');
    font-weight: bold;
    font-style: normal;
}

@font-face {
    font-family: 'FrutigerLT';
    src: url('./fonts/FrutigerLTPro-Light.woff2') format('woff2'),
         url('./fonts/FrutigerLTPro-Light.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'FrutigerLT';
    src: url('./fonts/FrutigerLTPro-Bold.woff2') format('woff2'),
         url('./fonts/FrutigerLTPro-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
}

: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%);

    --hff: "BodoniStd", serif;
    --ff: "FrutigerLT", sans-serif;

    --fs-base: 1rem;
    --fs-m: 1.2rem;
    --fs-l: 1.4rem;
    --fs-xl: 2rem;
    --fs-xxl: 3rem;
    --fs-xxxl: clamp(3.5rem, 6vw, 6rem);

    --fw-base: 400;
    --fw-bold: 700;

    --lh-base: 1.8em;
    --lh-tight: 1.2em;

    --primary-clr-200: #b19c8a;
    --primary-clr-400: #847365;

    --black-400: #000;
    --white-400: #fff;

    --aop-brand-clr: #d8232a;

    --heading-clr: var(--primary-clr-400);
    --text-clr: var(--black-400);
    --link-clr: var(--primary-clr-400);

    --e-clr: var(--primary-clr-400);
    --e-clr-focus: var(--primary-clr-200);
    --e-text-clr: var(--white-400);
    --e-text-clr-focus: var(--white-400);

    --horizontal-p: 2rem;

    --br-s: 0.4rem;
    --br-m: 1rem;

    --b--width-base: 1px;

    --shadow: drop-shadow(0 1rem 0.5rem hsla(0, 0%, 0%, 0.3));
    --shadow-reverse: drop-shadow(0 -1rem 0.5rem hsla(0, 0%, 0%, 0.3));
    --text-shadow: drop-shadow(0 0.1em 0.1em hsla(0, 0%, 0%, 0.8));
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--ff);
    font-size: var(--fs-base);
    font-weight: var(--fw-base);
    line-height: var(--lh-base);
}

*:is(:focus-visible) {
    outline: 3px solid var(--primary-clr-200);
    outline-offset: 4px;
}


/* =========== LAYOUT =========== */

.content-grid {
    --_padding-inline: var(--horizontal-p);
    --_content-max-width: 50rem;
    --_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(.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;
}

.wp-block-columns {
    margin: 0;
}


/* =========== CONTAINERS =========== */

.bg--white {
    background-color: var(--white-400);

    --_heading-clr: var(--black-400);
    --_text-clr: var(--black-400);
    --_link-clr: var(--primary-clr-400);
}

.br--m {
    border-radius: var(--br-m);
}


/* =========== TEXT =========== */

p {
    margin: 0 0 1em;
    color: var(--_text-clr, var(--text-clr));
    line-height: var(--lh-base);
}

h1, h2, h3, h4, h5, h6 {
    margin-bottom: 1.4em;
    color: var(--_heading-clr, var(--heading-clr));
    font-family: var(--hff);
    line-height: var(--lh-tight);
    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--alternative {
    margin-bottom: 1.2em;
    font-family: var(--ff);
    font-size: var(--fs-l);
    font-weight: var(--fw-bold);
    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-align--center {
    text-align: center;
}

.text-align--right {
    text-align: right;
}

.text--bigger {
    font-size: var(--fs-m);
}

.text-hidden {
    clip: rect(0 0 0 0); 
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap; 
    width: 1px;
}

.list {
    margin: 0;
    list-style: none;
}

.list li {
    position: relative;
    margin-bottom: 1em;
}

.list li::before {
    content: '';
    position: absolute;
    top: 0.1em;
    left: -2.5em;
    display: block;
    width: 1.5em;
    height: 1.5em;
    background-image: url(/wp-content/uploads/2026/01/swiss_icon.svg);
    background-size: contain;
    background-repeat: no-repeat;
}


/* =========== SPACING =========== */

.mi--auto {
    margin-inline: auto;
}

.m--0 {
    margin-block: 0;
}

.mt--xs {
    margin-top: 0.5rem;
}

.mt--s {
    margin-top: 1rem;
}

.mt--m {
    margin-top: 2rem;
}

.mt--l {
    margin-top: 3rem;
}

.mt--xl {
    margin-top: 4rem;
}

.mt--xxl {
    margin-top: 6rem;
}

.mt--xxxl {
    margin-top: 8rem;
}

.mb--xs {
    margin-bottom: 0.5rem;
}

.mb--s {
    margin-bottom: 1rem;
}

.mb--m {
    margin-bottom: 2rem;
}

.mb--l {
    margin-bottom: 3rem;
}

.mb--xl {
    margin-bottom: 4rem;
}

.mb--xxl {
    margin-bottom: 6rem;
}

.mb--xxxl {
    margin-bottom: 8rem;
}

.p--s {
    padding: 1rem;
}

.p--m {
    padding: 2rem;
}

.p--l {
    padding: 3rem;
}

.p--xl {
    padding: 4rem;
}

.header-margin {
    margin-top: 10rem;
}


/* =========== MEDIA =========== */

figure {
    margin: 0;
}

img {
    display: block;
    max-width: 100%;
    height: auto;
    font-style: italic;
    background-repeat: no-repeat;
    background-size: cover;
}

.separator {
    border-bottom: var(--b--width-base) solid var(--_e-clr, var(--e-clr));
    width: 8rem;
}

.img--max-width--m {
    max-width: 20rem;
}


/* =========== COMPONENTS =========== */

.btn {
    display: inline-block;
    padding: 0.4em 2.5em;
    border: none;
    background-color: var(--_e-clr, var(--e-clr));
    color: var(--_e-text-clr, var(--e-text-clr));
    font-family: var(--ff);
    font-size: var(--fs-m);
    line-height: var(--lh-base);
    text-transform: uppercase;
    text-decoration: none;
    transition: background-color 200ms ease-in-out, color 200ms ease-in-out, transform 200ms ease-in-out;
    cursor: pointer;
}

.btn:is(:hover, :focus-visible) {
    background-color: var(--_e-clr-focus, var(--e-clr-focus));
    color: var(--_e-text-clr-focus, var(--e-text-clr-focus));
    transform: scale(1.04);
}

.btn--small {
    padding: 0.1em 1.5em;
    font-size: var(--fs-base);
}

.page-banner {
    display: grid;
    justify-content: center;
    align-content: center;
    padding: 12rem 0 4rem;
    min-height: 100vh;
    min-height: 100lvh;
    text-align: center;
    clip-path: inset(0);
    box-sizing: border-box;
    overflow: hidden;

    --_text-clr: var(--white-400);
    --_heading-clr: var(--white-400);

    --_e-clr-focus: var(--white-400);
    --_e-text-clr-focus: var(--black-400);
}

.page-banner__img,
.page-banner__vid {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    height: 100lvh;
    object-fit: cover;
    z-index: -1;
}

.page-banner__heading {
    margin: 0 0 0.5em;
    filter: var(--text-shadow);
}

.page-banner__text {
    margin: auto;
    max-width: 66rem;
    filter: var(--text-shadow);
}

.page-banner--small {
    min-height: 50vh;
    min-height: 50lvh;
}

.page-banner--small .page-banner__heading {
    margin: 0 0 0.25em;
}

.split-section {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    overflow: hidden;
}

.split-section--top-aligned {
    align-items: start;
}

.split-section__img {
    position: relative;
    height: 100%;
    min-height: 50lvh;
}

.split-section__img img {
    position: absolute;
    inset: 0;
    object-fit: cover;
    object-position: center;
    width: 100%;
    height: 100%;
}

.split-section__img--graph {
    height: unset;
    min-height: unset;
}

.split-section__img--graph img {
    position: static;
    padding-bottom: 4rem;
    object-fit: contain;
}

.split-section--reverse .split-section__img--graph img {
    padding-top: 4rem;
    padding-bottom: 0;
}

.split-section__content {
    justify-items: left;
    padding: 4rem 0;
}

.text-on-image-section {
    position: relative;
    display: grid;
    align-content: center;
    padding: 4rem 0;
    min-height: 100vh;
    min-height: 100lvh;
}

.text-on-image-section__img img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.text-on-image-section__content {
    --_heading-clr: var(--white-400);
    --_text-clr: var(--white-400);

    --_e-clr-focus: var(--white-400);
    --_e-text-clr-focus: var(--black-400);
}

.text-on-image-section__heading {
    margin: 0 0 0.5em;
    font-size: var(--fs-xxxl);
    filter: var(--text-shadow);
}

.ingredients-list {
    margin: 0 0 2.5rem;
    padding: 0;
    list-style: none;
}

.ingredients-list li {
    display: flex;
}

.ingredients-list__amount {
    min-width: 4rem;
}

.card-grid {
    display: grid;
    column-gap: 1rem;
    row-gap: 4rem;
}

.card-grid__card {
    display: grid;
    grid-template-rows: auto 1fr;
}

.card-grid__card__img {
    aspect-ratio: 3/4;
    overflow: hidden;
}

.card-grid__card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.card-grid__card__content {
    display: grid;
    justify-items: left;
}

.card-grid__card__content .btn {
    align-self: end;
}


/* =========== HEADER =========== */

.page-header {
    position: fixed;
    left: 0;
    right: 0;
    padding: 0.5rem 1rem;
    transition: transform 400ms cubic-bezier(.70,0,.50,1);
    z-index: 100;
}

.page-header[data-state="closed"] {
    transform: translateY(calc(-100% - 10rem));
}

.page-header__nav {
    display: flex;
    justify-content: space-between;
}

.page-header__logo {
    padding: 1.5rem 1rem;
    width: 13rem;
}

.menu-button {
    position: relative;
    padding: 0;
    width: 6rem;
    border: 1px solid transparent;
    outline: none;
    background: transparent;
    stroke: var(--black-400);
    cursor: pointer;
}

.menu-button__hamburger {
    width: 100%;
    pointer-events: none;
}

.menu-button__hamburger__line {
    transition: stroke-dashoffset 400ms ease-in-out, stroke-dasharray 400ms ease-in-out;
}

.menu-button__hamburger__line--top,
.menu-button__hamburger__line--middle {
    stroke-dasharray: 65 300;
}

.menu-button__hamburger__line--bottom {
    stroke-dasharray: 32.5 300;
}

.menu-button[aria-expanded="true"] .menu-button__hamburger__line {
    transition: stroke-dashoffset 400ms ease-in-out, stroke-dasharray 400ms ease-in-out;
}

.menu-button[aria-expanded="true"] .menu-button__hamburger__line--top {
    stroke-dashoffset: -108;
}

.menu-button[aria-expanded="true"] .menu-button__hamburger__line--middle {
    stroke-dashoffset: -65;
}

.menu-button[aria-expanded="true"] .menu-button__hamburger__line--bottom {
    stroke-dashoffset: -76;
    stroke-dasharray: 65 300;
}

.primary-navigation {
    position: absolute;
    top: 0;
    left: 0;
    padding-top: 8rem;
    width: 100%;
    height: 100%;
    background-color: var(--white-400);
    filter: var(--shadow);
    transition: height 400ms cubic-bezier(.70,0,.50,1);
    box-sizing: border-box;
    z-index: -1;
}

.tdm-stamp {
    position: absolute;
    bottom: 0;
    right: 4rem;
    width: 10rem;
    height: 10rem;
    border-radius: 50%;
    background-color: var(--white-400);
    transform: translateY(50%);
    pointer-events: none;
}

.primary-navigation__list {
    display: grid;
    align-content: safe center;
    gap: 2em;
    height: calc(100vh - 10rem);
    margin: 0;
    padding: 0 0 4rem;
    text-align: center;
    font-size: var(--fs-xl);
    list-style: none;
    overflow: auto;
    box-sizing: border-box;
}

.primary-navigation__list li {
    transform: translateY(-3rem);
    opacity: 0;
    
    --_item-animation-delay: calc(260ms + 80ms * var(--_item-number));
}

.primary-navigation__list__languages {
    display: flex;
    gap: 2rem;
    justify-content: center;
}

.primary-navigation__list__languages__link {
    outline-color: transparent;
}

.primary-navigation__list__languages__link:is(:hover, :focus-visible),
.primary-navigation__list__languages__link.active {
    border-radius: 50%;
    outline: 3px solid var(--primary-clr-200);
    outline-offset: 4px;
    transition: outline-color 200ms ease;
}

.primary-navigation__list__languages__link img {
    width: 2rem;
    height: 2rem;
}

.primary-navigation[data-state="open"] {
    height: calc(100vh + 6rem);
}

.primary-navigation[data-state="open"] .primary-navigation__list li {
    animation: primaryMenuItemOpen 350ms cubic-bezier(.1,.35,.55,1) var(--_item-animation-delay) forwards;
}

.primary-navigation[data-state="closing"] .primary-navigation__list li {
    animation: primaryMenuItemClose 200ms ease forwards;
}

.primary-navigation[data-state="closed"] .primary-navigation__list {
    display: none;
}

@keyframes primaryMenuItemOpen {
    0% { opacity: 0; transform: translateY(-3rem); }
    100% { opacity: 1; transform: translateY(0); }
}

@keyframes primaryMenuItemClose {
    0% { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(-3rem); }
}


/* =========== FOOTER =========== */

.page-footer {
    position: relative;
    display: grid;
    align-content: end;
    min-height: 100vh;
    min-height: 100lvh;
}

.page-footer__inner {
    display: grid;
    justify-items: center;
}

.page-footer__bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1;
}

.page-footer__content {
    display: grid;
    justify-items: center;
    gap: 2rem;
    padding: 2rem;
    background-color: var(--white-400);
}

.page-footer__logo {
    width: 20rem;
    padding-left: 1rem;
}

.page-footer__link {
    display: flex;
    align-items: center;
    gap: 0.5em;
    font-size: var(--fs-m);
}

.page-footer__link__icon {
    width: 1.8em;
    height: 1.8em;
}

.cfs-footer {
  display: grid;
  grid-template-columns: 1fr 2fr;
  background-color: var(--aop-brand-clr);
  border-top: 0.5em solid var(--white-400);
  border-bottom: 0.5em solid var(--white-400);
  font-size: 0.8rem;
  z-index: 80;
}

.cfs-footer__container:first-child {
  border-right: 0.5em solid var(--white-400);
}

.cfs-footer__container {
  position: relative;
  height: 5.5em;
}

.cfs-footer__left,
.cfs-footer__aop,
.cfs-footer__right {
  position: absolute;
}

.cfs-footer__left {
  inset: auto auto 0 2em;
  height: 140%;
}

.cfs-footer__aop {
  display: none;
}

.cfs-footer__right {
  inset: 0 0 0 auto;
  padding-left: 1.5rem;
  max-width: 100%;
  height: 100%;
  box-sizing: border-box;
}

/* =========== ANIMATION =========== */

.animate-in {
    transition-property: transform, opacity;
    transition-duration: 1000ms;
    transition-timing-function: cubic-bezier(.05,.55,.15,1);
    transition-delay: 0ms;
    opacity: 0;

    --_movement-length: 8rem;
}

.animate-in--up {
    transform: translate(0, var(--_movement-length));
}

.animate-in--down {
    transform: translate(0, calc(var(--_movement-length) * -1));
}

.animate-in--left {
    transform: translate(var(--_movement-length), 0);
}

.animate-in--right {
    transform: translate(calc(var(--_movement-length) * -1), 0);
}

.animate-in--animated {
    transform: translate(0);
    opacity: 1;
}


/* =========== MISC =========== */

::selection {
    background-color: var(--primary-clr-400);
    color: var(--white-400);
}

.cookie-consent {
    position: fixed;
    display: grid;
    gap: 2rem;
    bottom: var(--horizontal-p);
    right: var(--horizontal-p);
    left: var(--horizontal-p);
    justify-items: center;
    padding: 2rem;
    text-align: center;
    filter: var(--shadow);
    z-index: 95;
}

.cookie-consent[data-opened=true] {
    animation: cookieConsentOpen 500ms ease forwards;
}

.cookie-consent[data-opened=closing] {
    animation: cookieConsentClose 500ms ease forwards;
}

.cookie-consent[data-opened=false] {
    display: none;
}

.cookie-consent__logo {
    margin-bottom: 0.6rem;
    max-width: 12rem;
}

.cookie-consent__btn--primary,
.cookie-consent__btn--secondary {
    text-wrap: nowrap;
}

.cookie-consent__btn--secondary {
    display: inline-block;
    margin-top: -0.8rem;
    background: none;
    border: none;
    color: var(--_e-clr, var(--e-clr));
    font-size: var(--fs-base);
    cursor: pointer;
}

@keyframes cookieConsentOpen {
    0% { opacity: 0; transform: translateY(2rem); }
    100% { opacity: 1; transform: translateY(0); }
}

@keyframes cookieConsentClose {
    0% { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(2rem); }
}


/* =========== MEDIA QUERIES =========== */


@media only screen and (min-width: 44rem) {


    /* =========== COMPONENTS =========== */

    .card-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}


@media only screen and (min-width: 54rem) {
    :root {
        font-size: max(0.7vw, 100%);
    }


    /* =========== LAYOUT =========== */

    .justify-self--right {
        justify-self: right;
    }


    /* =========== HEADER =========== */

    .tdm-stamp {
        width: 12rem;
        height: 12rem;
    }


    /* =========== FOOTER =========== */

    .cfs-footer {
        font-size: 1rem;
    }

    .cfs-footer__aop {
        display: block;
        inset: 0 0 0 auto;
        height: 100%;
        background-color: var(--white-400);
    }

    .cfs-footer__left {
        height: 160%;
    }

    .cfs-footer__right {
        padding-left: none;
    }
}

@media only screen and (min-width: 64rem) {


    /* =========== SPACING =========== */

    .header-margin--desk {
        margin-top: 10rem;
    }


    /* =========== COMPONENTS =========== */

    .split-section {
        grid-template-columns: 1fr 1fr;
        min-height: 100vh;
        min-height: 100lvh;
    }

    .split-section--reverse .split-section__img {
        order: -1;
    }

    .split-section__img--graph {
        max-width: 50rem;
    }

    .split-section__img--graph img {
        padding: 0;
    }

    .split-section__content {
        grid-template-columns: unset;
        padding: 6rem;
        max-width: 40rem;
    }

    .card-grid {
        grid-template-columns: repeat(3, 1fr);
    }


    /* =========== MISC =========== */

    .cookie-consent {
        display: flex;
        align-items: center;
        left: 4rem;
        right: 4rem;
        text-align: left;
    }

    .cookie-consent__btn--primary {
        margin-left: auto;
    }

    .cookie-consent__btn--secondary {
        margin-top: 0;
    }
}

@media (prefers-reduced-motion) {
    .page-banner__img,
    .page-banner__vid {
        position: absolute;
    }
    .animate-in {
        transition-property: opacity;
    }
}