body {
    position: relative;
    font-family: var(--ff-regular);
    font-size: 1rem;
    background-color: hsl(var(--primary-dark-color));
    color: hsl(var(--text-color));
    line-height: 1.55;
    letter-spacing: 0.033em;
    overflow-x: hidden;
}

main {
    overflow-x: hidden;
}

.hero {
    position: relative;
    background-image: url(/images/hero.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    min-height: 100svh;
    z-index: 1;
}

.hero-wrapper {
    align-items: start;
    margin-block-start: 14rem;
}

.hero-title.section-title {
    --gap: .2rem;
    position: relative;
    justify-content: start;
    background-color: hsl(var(--primary-dark-color) / .3);
    padding-block-start: 1.5rem;
    padding-block-end: 1.3rem;
    padding-inline: 1rem;
    width: max-content;
}

.hero-title h3 {
    position: absolute;
    bottom: -3rem;
    left: 0;
    display: block;
    background-color: hsl(var(--primary-dark-color));
    color: hsl(var(--title-color));
    padding-block: .6rem;
    padding-inline: 1.5rem;
    text-transform: uppercase;
    letter-spacing: .4rem;
    opacity: 0;
    transform: translateX(-100%);
}

h3.show-subtitle {
    animation: showSubTitle 1000ms 1800ms forwards;
}

.hero-title .letter > span {
    font-size: clamp(1.8rem, 10vw, 5.5rem);
    line-height: 1;
    animation: fillLetter 1500ms ease-out;
}

.scroller {
    position: absolute;
    left: calc(50% - 1rem);
    bottom: 2rem;
}

.scroll-down {
    flex-direction: column;
    align-items: center;
    --gap: 1rem;
}
.scroll {
    width: 2rem;
    height: 4rem;
    border: 2px solid hsl(var(--title-color));
    border-radius: 2rem;
    justify-content: center;
    align-items: flex-start;
}
.scroll span {
    background-color: hsl(var(--title-color));
    width: 0.6rem;
    aspect-ratio: 1;
    border-radius: 50%;
    display: block;
    animation: cursor 1.15s linear infinite;
    transform: translateY(.4rem);
}

.arrow-down {
    width: 0.8rem;
    aspect-ratio: 1/1;
    border: 2px solid transparent;
    border-right-color: hsl(var(--title-color));
    border-bottom-color: hsl(var(--title-color));
    transform: rotate(45deg);
    animation: arrow 1.15s infinite;
}

#uvod,
#galeria,
#ubytovanie,
#region,
#kontakt {
    --gap: 0;
}

.intro-container,
.reservation-container,
.contact-container {
    position: relative;
    isolation: isolate;
}

#uvod {
    background-image: linear-gradient(348deg, transparent 0%, transparent 76%,rgba(194, 194, 194,0.04) 76%, rgba(194, 194, 194,0.04) 93%,transparent 93%, transparent 100%),linear-gradient(150deg, transparent 0%, transparent 10%,rgba(194, 194, 194,0.04) 10%, rgba(194, 194, 194,0.04) 74%,transparent 74%, transparent 100%),linear-gradient(68deg, transparent 0%, transparent 36%,rgba(194, 194, 194,0.04) 36%, rgba(194, 194, 194,0.04) 47%,transparent 47%, transparent 100%),linear-gradient(199deg, transparent 0%, transparent 37%,rgba(194, 194, 194,0.04) 37%, rgba(194, 194, 194,0.04) 47%,transparent 47%, transparent 100%),linear-gradient(90deg, rgb(10,10,11),rgb(10,10,11));
}

.intro-container {
    padding-block-start: 3rem;
    padding-block-end: 5rem;
}

.content-wrapper {
    place-items: center;
}

.intro-wrapper {
    --gap: 7rem;
    grid-template-columns: 1fr;
    align-content: center;
}

.section-title {
    --gap: 0.5rem;
    justify-content: center;
    padding-block-end: 3rem;
}

.letter {
    opacity: 1;
    transform: translate(0, 0);
    transition: transform 400ms ease-out, opacity 400ms ease-out;
    isolation: isolate;
}

.letter > span {
    cursor: default;
    font-family: var(--ff-title);
    font-size: clamp(2.5rem, 16vw, 8.55rem);
    font-weight: 900;
    line-height: 1.3;
    color: transparent;
    -webkit-text-stroke-color: hsl(var(--title-color) / .5);
    -webkit-text-stroke-width: 1px;
    transition: color 300ms ease-out;
}

.reservation-container .section-title {
    --gap: .2rem;
}

.reservation-container .letter > span {
    font-size: clamp(2rem, 12.5vw, 8.55rem);
}

.letter > span:hover {
    color: hsl(var(--title-color));
}
.gallery-wrapper .letter > span:hover,
.region-wrapper .letter > span:hover {
    color: hsl(var(--secondary-dark-color));
}
.gallery-wrapper .letter > span,
.region-wrapper .letter > span {
    -webkit-text-stroke-color: hsl(var(--secondary-dark-color) / .6)
}
.hero-title .letter > span {
    -webkit-text-stroke-color: hsl(var(--title-color));
    -webkit-text-stroke-width: 1px;
    text-shadow: 0px 0px 13px hsl(var(--secondary-dark-color) / .1);
}

.section-title.hidden > .letter {
    opacity: 0;
    transform: translate(0, 100%);
}

.plates-grid {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(400px, auto);
}

.plate-merge {
    position: relative;
}

.plate {
    --gap: 0;
    position: relative;
    grid-template-columns: 1fr;
    grid-template-rows: 10px minmax(390px, auto);
    align-items: center;
    justify-content: center;
    overflow: hidden;
    isolation: isolate;
}
.plate::before {
    content: '';
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: transform 400ms ease-out;
    z-index: -2;
}

.plate:hover::before {
    transform: scale(1.1);
}
.plate:hover .plate-description > h1 {
    color: hsl(var(--highlight-color));
}

[data-plate="housing"]::before {
    background-image: url(/images/cards/plates/family.jpg);
}
[data-plate="price"]::before {
    background-image: url(/images/cards/plates/price.jpg);
}
[data-plate="location"]::before {
    background-image: url(/images/cards/plates/location.jpg);
}
[data-plate="booking"]::before {
    background-image: url(/images/cards/plates/booking.jpg);
}
[data-plate="ground-floor"]::before {
    background-image: url(/images/cards/plates/floor.jpg);   
}
[data-plate="first-floor"]::before {
    background-image: url(/images/cards/plates/room.jpg);
}

.plate-description {
    position: relative;
    text-align: center;
}

.plate-description > h1 {
    font-family: var(--ff-title);
    font-size: clamp(2.5rem, 14vw, 3rem);
    color: transparent;
    -webkit-text-stroke-color: hsl(var(--highlight-color));
    -webkit-text-stroke-width: 1px;
    text-transform: uppercase;
    transition: color 400ms ease-out;
}

.plate-description .text {
    font-size: 1rem;
    margin-inline: 2rem;
}

.price {
    position: relative;
}

.price h2 {
    color: hsl(var(--highlight-color));
    font-family: var(--ff-title);
    font-size: 2.3rem;
    line-height: 1.2;
    font-weight: 600;
}

.price > span:first-of-type {
    display: inline-block;
    background-color: hsl(var(--primary-dark-color));
    text-transform: uppercase;
    padding-block: .3rem;
    padding-inline: .6rem;
    margin-block-start: .3rem;
}

.price-info {
    position: absolute;
    width: 30px;
    aspect-ratio: 1;
    bottom: -2.2rem;
    left: calc(50% - 15px);
    border-radius: 50%;
    background-color: hsl(var(--primary-dark-color));
    color: hsl(var(--title-color));
    font-size: 1.125rem;
    line-height: 30px;
    cursor: pointer;
    text-align: center;
}

.price-list {
    padding-inline-start: 1.5rem;
}

.price-list li {
    color: hsl(var(--highlight-color));
    list-style: square;
}
.price-list span {
    color: hsl(var(--title-color));
}

.room-info > * {
    font-size: 1.2rem;
    list-style: inside;
}

.props {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}
.corner {
    --pos: 0px;
    position: absolute;
    border: 1px solid hsl(var(--title-color) / .5);
    width: 30px;
    height: 30px;
}
.top-left {
    border-right: unset;
    border-bottom: unset;
    top: var(--pos);
    left: var(--pos);
}
.top-right {
    top: var(--pos);
    right: var(--pos);
    border-left: unset;
    border-bottom: unset;
}
.bottom-left {
    bottom: var(--pos);
    left: var(--pos);
    border-right: unset;
    border-top: unset;
}
.bottom-right {
    bottom: var(--pos);
    right: var(--pos);
    border-left: unset;
    border-top: unset;
}

.plate-merge:nth-child(2) .top-left,
.plate-merge:nth-child(2) .top-right,
.plate-merge:nth-child(3) .top-left,
.plate-merge:nth-child(3) .top-right {
    border-top: unset;
}

.plus {
    position: absolute;
    top: -30px;
    left: calc(50% - 30px);
}

.plus-aside {
    top: unset;
    bottom: -30px;
    left: calc(50% - 30px);
}

.description {
    --line-gap : 1rem;
    position: relative;
    color: hsl(var(--title-color));
    background-color: hsl(var(--secondary-dark-color));
    border: 1px solid hsl(var(--title-color) / .2);
    max-width: 75ch;
    padding: clamp(2rem, 10vw, 2.6rem);
}
.description::after,
.card::after {
    content: '';
    position: absolute;
    inset: 0rem;
    border-right: 1px solid hsl(var(--title-color) / .4);
    border-bottom: 1px solid hsl(var(--title-color) / .4);
    transform: translate(var(--line-gap), var(--line-gap));
    z-index: -1;
}

.card::after {
    border-color: hsl(var(--title-color));
}

.description h1 {
    color: hsl(var(--highlight-color));
    margin-block-end: 1rem;
    text-transform: uppercase;
    white-space: balance;
}

.region-wrapper .description {
    background-color: hsl(var(--title-color));
    color: hsl(var(--secondary-dark-color));
    margin-inline: 1.5rem;
    margin-block-start: clamp(10rem, 15vw, 18rem);
    margin-block-end: 2rem;
	text-align: center;
}

.region-wrapper .description::after {
    border-color: hsl(var(--title-color))
}

.reservation-link-container {
    position: relative;
    width: 200px;
    aspect-ratio: 1;
    background-color: transparent;
    border: 1px solid hsl(var(--title-color) / .2);
    transform: rotate(45deg);
    transition: transform 400ms ease-out;
}

.reservation-link-container .corner {
    transition: inset 400ms;
    --pos: -1px;
}

.reservation-link-container:hover .corner {
    border-color: hsl(var(--secondary-dark-color) / .5);
    --pos: 12px;
}

.reservation-link-container a {
    position: absolute;
    background-color: hsl(var(--secondary-dark-color));
    color: hsl(var(--title-color));
    text-align: center;
    inset: 0;
    overflow: hidden;
    transition: background 400ms ease-out, color 400ms ease-out;
}

.reservation-link-container a::before {
    content: 'Rezervovať ubytovanie';
    position: absolute;
    inset: 0;
    transform: rotate(-45deg) translateY(65px);
    z-index: 1;
}

.reservation-link-container a:hover,
.reservation-link-container a:focus {
    background-color: hsl(var(--title-color));
    color: hsl(var(--secondary-dark-color));
}

.reservation-link-container > h1 {
    font-size: clamp(1rem, 8vw, 1.4rem);
    color: hsl(var(--title-color));
    text-transform: uppercase;
}

#galeria {
    background-color: hsl(var(--title-color));
}

.gallery-wrapper {
    padding-block-start: 3rem;
}

img[alt="gallery-peak"],
img[alt="region-peak"] {
    width: 100%;
}

img[alt="gallery-peak"] {
    padding-block-start: 3rem;
}

.gallery {
    position: relative;
    --gap: 0rem;
    grid-template-columns: repeat(2, 1fr);
}

.element-item {
    position: relative;
    overflow: hidden;
    background-color: hsl(var(--primary-dark-color));
}
.element-item > * > * {
    transition: transform 400ms ease-out;
}
.element-item > *:hover > *,
.element-item > *:focus > * {
    transform: scale(1.1);
}

.filter-control {
    --gap: 0;
    width: 100%;
    justify-content: center;
    padding-block: 1rem;
    border-top: 1px solid hsl(var(--primary-dark-color) / .4);
    border-bottom: 1px solid hsl(var(--primary-dark-color) / .4);
}
.filter-name {
    position: relative;
    display: none;
}
.filter-heading {
    position: absolute;
    top: -1.26rem;
    font-size: 1.5rem;
    text-transform: uppercase;
    color: hsl(var(--primary-dark-color));
}
.filter-buttons button {
    color: hsl(var(--secondary-dark-color));
    font-size: clamp(.9rem, 5vw, 1.3rem);
    background-color: transparent;
    padding-inline: 1rem;
    cursor: pointer;
    text-transform: uppercase;
}
.filter-buttons button.highlight {
    color: hsl(var(--highlight-color));
}
.filter-buttons > [data-filter="exterior"] {
    border-left: 1px solid hsl(var(--primary-dark-color));
    border-right: 1px solid hsl(var(--primary-dark-color));
}
.filter-buttons  > *:hover:not(.highlight),
.filter-buttons  > *:focus:not(.highlight) {
    color: hsl(var(--highlight-color));
}

#ubytovanie {
    background-image: linear-gradient(346deg, rgb(17,18,19) 0%, rgb(17,18,19) 22%,rgba(68,68,68, 0.09) 22%, rgba(68,68,68, 0.09) 69%,rgba(51,51,51, 0.04) 69%, rgba(51,51,51, 0.04) 100%),linear-gradient(31deg, rgb(17,18,19) 0%, rgb(17,18,19) 42%,rgba(68,68,68, 0.09) 42%, rgba(68,68,68, 0.09) 85%,rgba(51,51,51, 0.04) 85%, rgba(51,51,51, 0.04) 100%),linear-gradient(55deg, rgb(17,18,19) 0%, rgb(17,18,19) 13%,rgba(68,68,68, 0.09) 13%, rgba(68,68,68, 0.09) 72%,rgba(51,51,51, 0.04) 72%, rgba(51,51,51, 0.04) 100%),linear-gradient(90deg, rgb(10,10,11),rgb(10,10,11));
}

.reservation-container {
    padding-block-start: 3rem;
    padding-block-end: 3rem;
}

.reservation-wrapper,
.message-wrapper {
    position: relative;
    --gap: 0;
    grid-template-columns: minmax(auto, 600px);
    grid-template-rows: 250px 1fr;
    justify-content: center;
}

.form-image {
    background-size: cover;
    background-position: center;
    place-items: center;
}

.reservation-image,
.message-image {
    position: relative;
    z-index: 0;
}

.reservation-image {
    background-image: url(/images/reservation-back.png);
}

.message-image {
    background-image: url(/images/message-back.png);
}

.reservation-image::before,
.message-image::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url(/images/dotspattern.png);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    z-index: -1;
}

.form-heading {
    color: hsl(var(--title-color));
    text-transform: uppercase;
}

.reservation-form,
.message-form {
    background-color: hsl(var(--primary-dark-color));
    padding: clamp(2rem, 12vw, 4rem);
}

.form-heading {
    margin-block-end: 1.5rem;
}

.reservation-form form,
.message-form form {
    position: relative;
    --gap: 0;
    flex-direction: column;
}

#region {
    position: relative;
    background-color: hsl(var(--title-color));
    background-image: url(/images/region-back.jpg);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    z-index: 0;
}

.region-container {
    padding-block-end: 2rem;
}

.region-wrapper {
    place-items: center;
}

.title-wrapper {
    position: relative;
    background-color: hsl(var(--title-color));
    background-position: 0 -400px;
    background-size: cover;
    width: 100%;
    padding-block-start: clamp(1.5rem, 3vw, 3rem);
}
.title-wrapper::before {
    content: '';
    position: absolute;
    bottom: -55px;
    height: 60px;
    width: 100%;
    background-image: url(/images/region-title-peak.svg);
    background-size: cover;
    background-repeat: no-repeat;
}

.title-wrapper .section-title {
    padding-block-end: 1rem;
}

.card-wrapper {
    padding-block-end: 1rem;
}

#myCarousel {
    display: none;
    --f-carousel-slide-width: auto;
}
#myCarousel > * {
    padding-block: 1rem;
}

.f-carousel__track .f-carousel__slide {
    overflow: hidden;
}

.card {
    --line-gap : 1rem;
    position: relative;
    grid-template-columns: minmax(auto, 330px);
    grid-template-rows: 200px minmax(270px, auto) 50px;
    grid-template-areas: "image" "text" "button";
    background-color: hsl(var(--title-color));
    margin: 1rem;
    z-index: 0;
}

.card .corner {
    border-color: hsl(var(--primary-dark-color))
}

.card-image {
    position: relative;
    grid-area: image;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.card-sudopark {
    background-image: url(/images/cards/region/sudopark.jpg);
}
.card-raca {
    background-image: url(/images/cards/region/velka-raca.jpg);
}
.card-sportcentrum {
    background-image: url(/images/cards/region/sportcentrum.jpg);
}
.card-luka {
    background-image: url(/images/cards/region/carovna-luka.jpg);
    background-position: 0 -50px;
}
.card-orloj {
    background-image: url(/images/cards/region/orloj.png);
}
.card-vychylovka {
    background-image: url(/images/cards/region/vychylovka.png);
}
.card-megonky {
    background-image: url(/images/cards/region/megonky.jpg);
}
.card-rozhladna {
    background-image: url(/images/cards/region/oscadnica-rozhladna3.jpg);
    background-position: bottom;
}
.card-lavicka {
    background-image: url(/images/cards/region/korna-lavicka.jpg);
}

.card-text {
    grid-area: text;
}

.card-title {
    position: relative;
    z-index: 1;
}

.card-title::before {
    content: attr(data-subtitle);
    position: absolute;
    top: .5rem;
    left: 1rem;
    color: hsl(var(--primary-dark-color));
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1;
    text-transform: uppercase;
    z-index: -1;
}

.card-title h2 {
    color: transparent;
    -webkit-text-stroke: 1px;
    -webkit-text-stroke-color: hsl(var(--highlight-color));
    text-transform: uppercase;
    font-size: 2rem;
    font-weight: bold;
    line-height: .7;
    padding-block-start: 2.2rem;
    padding-block-end: 1rem;
    padding-inline-start: 1rem;
    text-align: left;
}

.card-text hr {
    border-color: hsl(var(--highlight-color));
    border-style: dashed;
    margin: 0;
}

.card-text .text {
    font-weight: 300;
    color: hsl(var(--secondary-dark-color));
    margin-inline: 2rem;
    margin-block-start: 1rem;
}

.card-button {
    grid-area: button;
    align-items: center;
    border-top: 1px solid hsl(var(--secondary-dark-color) / .1);
}

.card-button > * {
    color: hsl(var(--secondary-dark-color));
    position: relative;
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    transition: color 300ms ease-out;
}
.card-button > *::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: hsl(var(--primary-dark-color));
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 300ms ease-out;
    z-index: -1;
}
.location-button {
    border-left: 1px solid hsl(var(--secondary-dark-color) / .1);
}
.location-button::before {
    transform-origin: left;
}

.card-button > *:hover::before {
    transform: scaleX(1);
}
.card-button > *:hover {
    color: hsl(var(--title-color));
}

#kontakt {
    background-image: linear-gradient(283deg, rgba(228, 228, 228,0.04) 0%, rgba(228, 228, 228,0.04) 30%,rgba(130, 130, 130,0.04) 30%, rgba(130, 130, 130,0.04) 49%,rgba(31, 31, 31,0.04) 49%, rgba(31, 31, 31,0.04) 100%),linear-gradient(297deg, rgba(228, 228, 228,0.04) 0%, rgba(228, 228, 228,0.04) 20%,rgba(130, 130, 130,0.04) 20%, rgba(130, 130, 130,0.04) 60%,rgba(31, 31, 31,0.04) 60%, rgba(31, 31, 31,0.04) 100%),linear-gradient(242deg, rgba(228, 228, 228,0.04) 0%, rgba(228, 228, 228,0.04) 29%,rgba(130, 130, 130,0.04) 29%, rgba(130, 130, 130,0.04) 48%,rgba(31, 31, 31,0.04) 48%, rgba(31, 31, 31,0.04) 100%),linear-gradient(90deg, rgb(10,10,11),rgb(10,10,11));
}

.contact-container {
    padding-block-start: 3rem;
    padding-block-end: 5rem;
}

.contact-grid {
    --gap: 3rem;
    grid-template-columns: minmax(auto, 600px);
}

.contact-card {
    position: relative;
    z-index: 0;
    padding: 1rem;
    border: 1px solid hsl(var(--title-color) / .2);
    text-align: center;
}

.contact-card .corner {
    --pos: -1px;
}

.contact-title {
    font-size: 1.3rem;
    color: hsl(var(--highlight-color));
    text-transform: uppercase;
}
.contact-text {
    font-size: 1.1rem;
}
.contact-icon {
    display: none;
    position: absolute;
    top: 2rem;
    right: 2rem;
    opacity: .5;
}

[alt="telefon"] {
    width: 35px;
}
[alt="email"] {
    height: 40px;
}
[alt="mapa"] {
    width: 60px;
}

.cookies {
    transform: translateY(calc(100% + 30px));
    font-size: .75rem;
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: hsl(var(--secondary-dark-color));
    transition: transform 400ms ease-out;
    z-index: 998;
}

.cookies .wrapper {
    padding: 1.5rem;
}
.cookies header {
    align-items: center;
    --gap: .5rem;
}
.cookies h1 {
    color: hsl(var(--highlight-color));
    font-size: 1.10rem;
    text-transform: uppercase;
    line-height: 1;
}
.cookies h3 {
    color: hsl(var(--highlight-color));
    font-weight: bold;
}

.cookie {
    align-items: center;
}

.cookies-close,
.close-price-info {
    background-color: transparent;
    cursor: pointer;
    position: absolute;
    top: 0;
    right: 0;
}

.cookies-close:hover,
.cookies-close:focus,
.close-price-info:hover,
.close-price-info:focus {
    opacity: .75;
}

.reservations-link {
    margin-inline-end: auto;
}

.cookies hr {
    border-style: dashed;
    border-color: hsl(var(--highlight-color));
}

.cookies .buttons {
    --gap: .5rem;
    padding-inline: .8rem;
    align-items: center;
}
.buttons button {
    padding-inline: 1rem;
    padding-block: .4rem;
    cursor: pointer;
}
#accept {
    color: hsl(var(--title-color));
    background-color: hsl(var(--highlight-color));
    
}
#accept:hover,
#accept:focus {
    background-color: hsl(var(--highlight-color) / .7);
}
#decline {
    color: hsl(var(--error-color));
    background-color: transparent;
}
#decline:hover, 
#decline:focus {
    color: hsl(var(--error-color) / .7);
}

.cookies-btn {
    position: fixed;
    bottom: .5rem;
    left: .5rem;
    z-index: 1;
}
.cookies-btn button {
    background-color: transparent;
    cursor: pointer;
}

.show-cookies {
    transform: translateY(0);
    transition-delay: 1000ms;
}

.scroll-top {
    display: none;
    position: fixed;
    bottom: 1rem;
    right: 1rem;
}

.scroll-to-top {
    position: relative;
    cursor: pointer;
    background-color: hsl(var(--primary-dark-color));
    place-items: center;
    width: 40px;
    aspect-ratio: 1/1;
    border-radius: 10px;
    box-shadow: 0px 0px 35px 2px hsl(var(--text-color)/0.3);
    transition: box-shadow 400ms ease-out;
    z-index: 999;
}

.scroll-to-top > img {
    transition: transform 400ms ease-out;
}

.price-overlay {
    display: none;
    position: fixed;
    inset: 0;
    place-items: center;
    background-color: hsl(var(--primary-dark-color) / .40);
    backdrop-filter: blur(.6rem);
    -webkit-backdrop-filter: blur(.6rem);
    z-index: 9999;
}
.price-overlay .description {
    text-align: left;
}

footer {
    display: none;
}

@media (hover) {
    .scroll-top:hover > button > img {
        transform: translateY(-3px);
    }

    .scroll-top:hover .scroll-to-top {
        box-shadow: 0px 0px 35px 2px hsl(var(--text-color)/0.5);
    }
}

@media screen and (min-width: 18.75em) {
    .contact-card {
        padding: 2rem;
        text-align: left;
    }

    .contact-icon {
        display: block;
    }
}

@media screen and (min-width: 24.5em) {
    .phone-icon {
        --pos: 40.5px
    }
    .email-icon {
        --pos: 27.5px;
    }
    .map-icon {
        --pos: 37.5px;
    }

    .contact-icon {
        top: calc(50% - var(--pos));
    }

    [alt="telefon"] {
        width: 45px;
    }
    [alt="email"] {
        height: 55px;
    }
    [alt="mapa"] {
        width: 75px;
    }
}

@media screen and (min-width: 35em) {
    .plate-description .text {
        max-width: 35ch;
        margin-inline: auto;
    }
	
    .reservation-container .section-title {
        --gap: .5rem;
    }

    .filter-control {
        align-items: center;
        justify-content: space-around;
    }

    .filter-name {
        display: block;
    }

    .title-wrapper::before {
        bottom: -115px;
        height: 118px;
    }

    .gallery-wrapper {
        padding-block-start: 1rem;
    }

    .cookies {
        max-width: 450px;
        bottom: 1rem;
        right: 1rem;
    }

    .cookies .buttons {
        padding-inline: 0rem;
    }

    .f-button {
        --f-button-bg: hsl(var(--secondary-dark-color));
        --f-button-color: hsl(var(--title-color));
    } 
    .f-button:hover:not([disabled]) {
        --f-button-hover-bg: hsl(var(--secondary-dark-color));
    }

    .cookies {
        transform: translateX(calc(100% + 30px));
    }

    .show-cookies {
        transform: translateX(0);
    }
}

@media screen and (min-width: 50em) {

    .hero-wrapper {
        align-items: center;
        margin-block-start: 0;
    }

    .hero-title.section-title {
        --gap: .5rem;
        background-color: transparent;
        justify-content: center;
        padding-inline: 0;
        padding-block-end: 3rem;
        width: 100%;
    }

    .hero-title .letter:first-child > span {
        margin-inline-end: clamp(0.8rem, 10.9vw, 1.3rem);
    }
   
    .hero-title .letter > span {
        font-size: clamp(1.7rem, 10.9vw, 9rem);
    }

    .hero-title.hidden > .letter {
        transform: translate(0, 25%);
    }

    .hero-title h3 {
        left: unset;
        bottom: .5rem;
        transform: translateY(30px);
    }
    
    .gallery {
        grid-template-columns: repeat(3, 1fr);
    }

    footer {
        display: block;
        padding-block-start: 1rem;
        padding-block-end: 1.5rem;
        font-size: .8em;
        background-image: linear-gradient(45deg, transparent 0%, transparent 27%,rgba(214, 214, 214,0.06) 27%, rgba(214, 214, 214,0.06) 38%,transparent 38%, transparent 100%),linear-gradient(45deg, transparent 0%, transparent 39%,rgba(214, 214, 214,0.06) 39%, rgba(214, 214, 214,0.06) 68%,transparent 68%, transparent 100%),linear-gradient(90deg, transparent 0%, transparent 74%,rgba(214, 214, 214,0.06) 74%, rgba(214, 214, 214,0.06) 79%,transparent 79%, transparent 100%),linear-gradient(90deg, rgb(0,0,0),rgb(0,0,0));
        background-position: center;
    }

    .footer-container {
        padding-inline: 5rem;
        align-items: center;
        justify-content: space-between;
    }

    .created-by p {
        --gap: .4rem;
        align-items: center;
    }
            
}

@media screen and (min-width: 60em) {
    .letter > span {
        font-size: 8.55rem;
    }

    .gallery {
        grid-template-columns: repeat(4, 1fr);
    }

    .reservation-wrapper,
    .message-wrapper {
        grid-template-columns: repeat(2, minmax(auto, 500px));
        grid-template-rows: 1fr;
    }

    .message-wrapper {
        grid-template-columns: minmax(auto, 350px) minmax(auto, 500px);
    }
}
@media screen and (min-width: 77em) {

    [data-plate="price"] .top-left,
    [data-plate="house"] .top-left,
    [data-plate="price"] .bottom-left,
    [data-plate="house"] .bottom-left {
        border-left: unset;
    }

    .intro-wrapper {
        grid-template-columns: 75ch 280px;
        justify-content: center;
        grid-template-rows: 1fr;
    }

    .contact-grid {
        grid-template-columns: repeat(3, minmax(auto, 380px));
    }

    .title-wrapper::before {
        bottom: -159px;
        height: 225px;
    }
}


@media screen and (min-width: 90em) {
    .plates-grid {
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: minmax(500px, auto);
    }

    .plate {
        grid-template-rows: 240px minmax(260px, auto);
        align-items: baseline;
    }    

    .plate-description {
        text-align: right;
        margin-inline: 4rem;
    }
    .plate-description::before {
        content: '';
        position: absolute;
        top: -1rem;
        right: 0;
        width: 250px;
        height: 3px;
        background-color: hsl(var(--highlight-color));
    }

    .plate-description .text {
        text-align: right;
        margin: 0;
        margin-inline-start: auto;
    }

    .plate-merge:nth-child(2) .top-left,
    .plate-merge:nth-child(2) .bottom-left,
    .plate-merge:nth-child(3) .top-left,
    .plate-merge:nth-child(3) .bottom-left {
        border-left: unset;
    }

    .plate-merge:nth-child(2) .top-left,
    .plate-merge:nth-child(2) .top-right,
    .plate-merge:nth-child(3) .top-left,
    .plate-merge:nth-child(3) .top-right {
        border-top: 1px solid hsl(var(--title-color) / .5);
    }

    .plus {
        position: absolute;
        left: -30px;
        top: calc(50% - 30px);
    }
    
    .plus-aside {
        left: unset;
        right: -30px;
    }

    .intro-container {
        padding-block-start: 5rem;
        padding-block-end: 0;
    }

    .intro-wrapper {
        padding-block: 5rem;
    }

    .intro-container .section-title {
        position: absolute;
        top: 58%;
        flex-direction: column;
        transform: rotate(180deg) translate(-1rem, 50%);
        overflow: hidden;
        padding: 0;
    }

    .intro-container .letter > span {
        writing-mode: vertical-lr;
    }

    .intro-container .section-title.hidden > .letter {
        opacity: 0;
        transform: translate(-100%, 0);
    }

    .price-info {
        bottom: 0.4rem;
        right: 5rem;
        left: unset;
    }
    
    .gallery {
        grid-template-columns: repeat(5, 1fr);
    }
}

@media screen and (min-width: 104em) {
    .contact-container {
        padding-block: 8rem;
    }

    .contact-container .section-title {
        position: absolute;
        top: 50%;
        flex-direction: column;
        transform: rotate(180deg) translate(-1rem, 50%);
        padding: 0;
        overflow: hidden;
    }

    .contact-container .section-title.hidden > .letter {
        opacity: 0;
        transform: translate(-100%, 0);
    }

    .contact-container .letter > span {
        writing-mode: vertical-lr;
    }

}
