@font-face { font-display: swap; font-family: 'Alkatra'; font-style: normal; font-weight: 400; src: url('fonts/alkatra-v3-latin-regular.woff2') format('woff2'); }
@font-face { font-display: swap; font-family: 'Alkatra'; font-style: normal; font-weight: 600; src: url('fonts/alkatra-v3-latin-600.woff2') format('woff2'); }
:root {
    --bl: hsl(207, 75%, 31%);
    --bg: hsl(207, 75%, 21%);
    --y: hsl(43, 69%, 75%);
    --c: #FFF;
    --sh:  0 0 1rem hsla(0deg, 0%, 0%, 0.25);
    --font: 'Alkatra', Georgia, serif;
}
main, article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
input, button, textarea, select, input::placeholder { font: inherit; }
html, body { height: 100%; padding: 0; margin: 0; font-family: var(--font); font-weight: 400; letter-spacing: 0.02em; font-size: 100%; -webkit-font-smoothing: antialiased; color: var(--c); }
html { background: var(--bg); scroll-behavior: smooth; }
@media (prefers-reduced-motion) {
    html { scroll-behavior: auto; }
}
a.skip { background-color: var(--c); color: var(--bg); position: absolute; height: 3rem; line-height: 3rem; font-size: 1rem; top: -3rem; left: 0; padding: 0 0.5rem; border-radius: 0 0 1rem 0; transition: .3s; z-index: 950; }
a.skip:focus { top: 0; }
.visually-hidden { clip: rect(0 0 0 0); clip-path: inset(50%); height: 1px; overflow: hidden; position: absolute; white-space: nowrap; width: 1px; }
a#to_top { position: fixed; right: 2.25rem; bottom: -3rem; width: 2.5rem; height: 2.5rem; padding: 0; margin: 0; color: var(--c); transition: bottom 0.5s ease-in-out; }
a#to_top svg { width: 2.5rem; height: 2.5rem; }
h1, h2, h3 { font-weight: 600; margin-block: 0 1em; letter-spacing: 0.057em; font-size: 2rem; line-height: 1.2; text-wrap-style: balance; }
p, ul { line-height: 1.2; }
/* Header */
header { height: 4rem; width: 100%; position: absolute; top: 0; background-image: linear-gradient(180deg, var(--bg), transparent); }
header nav { height: 3rem; line-height: 3rem; font-size: 1rem; text-align: center; }
nav a { padding: 0 0.5em; display: inline-block; color: var(--y); margin: 0; text-decoration: none; }
nav a.active { text-decoration-line: underline; }
nav a:focus, nav a:hover { text-decoration: underline; }
#menu_toggle { appearance: none; position: relative; display: none; width: auto; height: 100%; line-height: 2rem; padding: 1rem 0; margin: 0 0 0 1.25rem; cursor: pointer; font-weight: 600; letter-spacing: 0.06rem; border: 0; background: transparent; color: var(--c); z-index: 900; }
#menu_toggle svg { display: inline-block; width: 2rem; height: 2rem; margin: 0 0 0 0.5rem; vertical-align: middle; }
#menu_toggle .line { transform-origin: center; transition: 0.2s; }
#menu_toggle[aria-expanded="true"] .line:not(.middle) { y: 45; opacity: 0; }
#menu_toggle[aria-expanded="true"] .line.middle { transform: rotate(45deg); }
#menu_toggle[aria-expanded="true"] .line.middle:nth-child(even) { transform: rotate(-45deg); }
/* Content */
main > section { --bgi: unset; --bgip: var(--bgi); margin: 0; background-image: var(--bgi); background-size: cover; background-repeat: no-repeat; background-position: center; }
@media (orientation: portrait) {
    main > section { background-image: var(--bgip); }
}
header > div, main > section > hgroup, footer > div { width: 90%; max-width: 72rem; margin-inline: auto; }
section.title > hgroup { padding: 0 0 3rem; text-align: center; }
section.title > hgroup h2, section.title > hgroup h2 { margin: 0 0 1rem; }
section.text-block > hgroup { padding: 4rem 0; text-shadow: 0.1em 0.1em 0.25em var(--bg); text-align: center; }
section.text-block > hgroup h2 { font-size: 2.5rem; }
section.text-block > hgroup p { font-size: 2rem; }
section.text-block > div { display: flex; flex-wrap: wrap; align-items: stretch; justify-content: center; gap: 2rem; background-image: linear-gradient(0deg, var(--bg) 50%, transparent 75%); }
section.text-block > div > div { flex: 0 1 30%; max-width: 28rem; background-color: var(--bl); padding: 1.5em 2.5em; border-radius: 2rem; box-shadow:var(--sh); }
section.photos > div, div.photos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 2rem; width: 90%; margin: 0 auto; padding: 4rem 0; }
section.photos > div > figure, div.photos > figure { flex: 0 1 calc((100% - 10rem) / 6); background-color: var(--bl); border-radius: 2rem; aspect-ratio: 1/1; overflow: hidden; box-shadow:var(--sh); }
section.photos > div > figure > img, div.photos > figure > img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: center; }
section.title + section.photos > div { padding-top: 0rem; }
section.options { min-height: 56.25vw; margin: 0 0 -20vw; padding: 0 0 30vw; }
section.options > div { display: flex; flex-wrap: wrap; align-items: stretch; justify-content: center; gap: 2rem; background-image: linear-gradient(180deg, var(--bg) 25%, transparent 75%); }
section.options > div.photos { background-image: none; padding: 4rem 0 0; }
section.options > div > div { flex: 0 1 calc(25% - 2rem); max-width: 22rem; background-color: var(--bl); padding: 1.5em 2.5em; border-radius: 2rem; box-shadow:var(--sh); display: flex; flex-direction: column; justify-content: space-between; }
section.options > div > div h2 { font-size: 1.2em; width: 100%; color: var(--y); margin-bottom: 0.5em; }
section.options > div > div p { width: 100%; padding: 0 0 1em; }
section.options > p { position: relative; top: 5vw; text-align: center; width: 90%; max-width: 72rem; margin-inline: auto; }
/*section.options:after { content: '-'; display: block; position: relative; top: 5vw; width: fit-content; margin: 0 auto; pointer-events: none; }*/
section.options_info { background-image: linear-gradient(180deg, transparent, var(--bg) 18vw); }
section.options_info > div { width: 90%; max-width: 72rem; margin-inline: auto; background-color: var(--bl); border-radius: 2rem; box-shadow:var(--sh); padding: 2rem; margin: 0 auto 2rem; }
section.options_info > div > div { display: flex; align-items: stretch; justify-content: center; gap: 2rem; }
section.options_info > div > div:first-child { padding: 0 0 1rem; }
section.options_info > div > div:last-child { padding: 1rem 0 0; }
section.options_info figure { max-width: calc((100% - 4rem) / 3); aspect-ratio: 16/9; overflow: hidden; border-radius: 1rem; }
section.options_info figure > img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: center; }
section.options_info h2 { margin: 0 0 0.5em; }
section.options_info p:not(:last-of-type) { padding-bottom: 1em; }
main a { color: var(--y); }
/* Footer */
footer { background-color: var(--bl); border-radius: 2rem clamp(6rem, 12vw, 18rem) 0 0; margin: 0; padding: 0; }
footer > div { padding: 2rem; }
footer > div > div { display: flex; align-items: stretch; gap: 2rem; padding: 0 0 2rem; }
footer figure { aspect-ratio: 16/9; overflow: hidden; border-radius: 1rem; }
footer figure > img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: center; }
footer > div > figure { float: left; aspect-ratio: 1/1; width: auto; height: 4.5em; margin: 0 1em 0 0; }
footer p { padding: 0; line-height: 1.5; }
footer a { color: inherit; }
footer button { clear: both; }
footer div.copyright { font-size: 0.8em; text-align: center; }
/* Form */
dialog { margin: auto; background-color: var(--bl); color: var(--c); padding: 2rem 1rem; border: 0; border-radius: 2rem; }
dialog::backdrop { background-color: hsla(0deg, 0%, 0%, 0.5); backdrop-filter: blur(1em); }
form label { display: block; width: 80%; padding: 0.5em 0; }
form input, form textarea, form select { display: block; width: 80%; background-color: #FFF; color: var(--bg); padding: 0.5em 1em; border: 0; border-radius: 0.5em; resize: none; }
form input:focus, form textarea:focus, form select:focus { outline: 2px solid var(--c); }
dialog p.small { font-size: 0.7em; padding: 0.5em 0; }
dialog p a { color: inherit; }
.grecaptcha-badge { visibility: hidden; }
button { appearance: none; border: 0; padding: 0.5em 1em; background-color: var(--bg); color: var(--c); cursor: pointer; margin: 1em 0; border-radius: 1em; text-decoration: none; transition: background-color 0.2s, color 0.2s; }
button:not(.pswp__button):hover { color: var(--bl); background-color: var(--c); }
button.close_form { float: right; border-radius: 50%; margin: 0; width: 2.5em; height: 2.5em; line-height: 2.75em; padding: 0; }
button.close_form.large { float: none; border-radius: 1em; margin: 1em 0; width: auto; height: auto; line-height: unset; padding: 0.5em 1em; }
dialog > div { padding: 0 1rem; overflow-x: hidden; overflow-y: auto; max-width: calc(80vw - 4rem); max-height: calc(80vh - 4rem); }
dialog > div::-webkit-scrollbar { width: 0.5rem; }
dialog > div::-webkit-scrollbar-track { background: transparent; }
dialog > div::-webkit-scrollbar-thumb { background: var(--c); border-radius: 1rem; }
/*@media screen and (max-width: 58rem) {
	#menu_toggle { display: block; }
    header nav { position: absolute; top: -100vh; right: 0; height: auto; padding: 6rem 0 0 0; background-color: var(--bg); box-shadow: 0 0 2rem 2rem var(--bg); opacity: 0; transition: top 0.15s ease-in-out, opacity 0.25s ease-in-out; }
	header nav.open, header nav:focus-within { top: 0; opacity: 1; }
    nav a { display: block; height: 1.5em; line-height: 1.5em; text-align: right; padding: 0 2rem 2.5rem; }
}*/
@media screen and (max-width: 64rem) {
    section.options > div > div { flex: 0 1 45%; }
}
@media screen and (max-width: 50rem) {
    section.text-block > div { flex-direction: column; align-content: space-evenly; }
    section.photos > div > figure, div.photos > figure { flex: 0 1 45%; }
    section.options > div > div { flex: 0 1 90%; max-width: 90%; }
    section.options_info > div > div, footer > div > div { flex-direction: column; }
    section.options_info figure {max-width: 100%; }
    footer figure { aspect-ratio: unset; }
    footer { border-radius: 0; }
    footer > div { padding: 2rem 0; }
}