@font-face {
  font-family: Xillian;
  font-stretch: ultra-expanded;
  font-display: swap;
  src: url("../assets/fonts/XillianFamilyRegular.woff2") format("woff2"),
       url("../assets/fonts/XillianFamilyRegular.woff") format("woff");
}

@font-face {
  font-family: FiraSans;
  font-stretch: ultra-expanded;
  font-display: swap;
  src: url("../assets/fonts/FiraSans-Regular.woff2") format("woff2"),
       url("../assets/fonts/FiraSans-Regular.woff") format("woff");
}

:root {
  --site-bg: #f7f7f7;
  --surface: rgba(255, 255, 255, 0.9);
  --surface-strong: rgba(255, 255, 255, 0.97);
  --text: #111111;
  --muted: #5a5a5a;
  --accent: #927e70;
  --border: rgba(17, 17, 17, 0.18);
  --page-gutter: clamp(1rem, 3.6vw, 2.4rem);
  --max-content: 1200px;
  --menu-anchor-x: calc(100% - clamp(2.8rem, 6vw, 3.6rem));
  --menu-anchor-y: clamp(2.8rem, 6vw, 3.6rem);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

body.page {
  min-height: 100svh;
  background: var(--site-bg);
  color: var(--text);
  font-family: "Roboto", Helvetica, sans-serif;
  font-size: 1rem;
  line-height: 1.45;
  animation: fadein 600ms ease both;
}

body.page.menu-open {
  overflow: hidden;
}

.site-shell {
  min-height: 100svh;
  display: flex;
  flex-direction: column;
}

.site-header {
  position: relative;
  z-index: 30;
  padding: var(--page-gutter);
  min-height: 5.25rem;
}

.site-header__title {
  margin: 0;
  max-width: calc(100% - 4.8rem);
  color: #111111;
  font-family: Xillian, "Roboto", Helvetica, sans-serif;
  font-size: clamp(1.5rem, 4vw, 2.35rem);
  line-height: 1;
  letter-spacing: 0.03em;
}

.site-main {
  flex: 1 1 auto;
  width: min(var(--max-content), 100%);
  margin: 0 auto;
  padding: 0 var(--page-gutter) clamp(2rem, 3.6vw, 3rem);
}

.nav-btn-js {
  position: fixed;
  right: var(--page-gutter);
  top: var(--page-gutter);
  z-index: 50;
  width: 3.25rem;
  height: 3.25rem;
  border: 0;
  border-radius: 50%;
  background-color: #000000;
  cursor: pointer;
  display: grid;
  place-content: center;
  transition: transform 220ms ease, background-color 220ms ease;
}

.nav-btn-js::before,
.nav-btn-js::after {
  content: "";
  width: 1.25rem;
  height: 0.12rem;
  background: #ffffff;
  display: block;
  transition: transform 220ms ease;
}

.nav-btn-js::after {
  margin-top: 0.36rem;
}

.nav-btn-js:hover {
  transform: translateY(-1px);
}

.nav-btn-js[data-open="true"] {
  background-color: var(--accent);
}

.nav-btn-js[data-open="true"]::before {
  transform: translateY(0.24rem) rotate(45deg);
}

.nav-btn-js[data-open="true"]::after {
  transform: translateY(-0.24rem) rotate(-45deg);
}

.header__nav {
  position: fixed;
  inset: 0;
  z-index: 40;
  padding: clamp(2.8rem, 5vw, 3.8rem) var(--page-gutter);
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.96), rgba(244, 239, 234, 0.94));
  backdrop-filter: blur(8px);
  overflow: auto;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  clip-path: circle(var(--radius, 0) at var(--menu-anchor-x) var(--menu-anchor-y));
  transition: opacity 240ms ease;
}

.header__nav[data-active="true"] {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.header__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  min-height: 100%;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.4rem;
}

.header__menu-item a {
  color: #0f0f0f;
  text-decoration: none;
  text-transform: uppercase;
  font-family: Xillian, "Roboto", Helvetica, sans-serif;
  font-size: clamp(2.2rem, 11vw, 5.7rem);
  line-height: 1;
  letter-spacing: 0.05em;
  transition: color 180ms ease;
}

.header__menu-item--active a,
.header__menu-item a:hover,
.header__menu-item a:focus-visible {
  color: var(--accent);
}

.header__menu-item a:focus-visible,
.site-footer a:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

.page-title {
  margin: 0;
  font-family: Xillian, "Roboto", Helvetica, sans-serif;
  font-size: clamp(2rem, 5vw, 4rem);
  line-height: 1;
  letter-spacing: 0.01em;
}

.site-footer {
  margin-top: auto;
  border-top: 1px solid var(--border);
  background: var(--surface);
  backdrop-filter: blur(5px);
}

.site-footer__inner {
  width: min(var(--max-content), 100%);
  margin: 0 auto;
  padding: 1rem var(--page-gutter) 1.2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.85rem 1.2rem;
}

.site-footer__brand {
  margin: 0;
  color: #121212;
  font-family: Xillian, "Roboto", Helvetica, sans-serif;
  font-size: clamp(1rem, 2.6vw, 1.35rem);
  line-height: 1;
}

.site-footer__location {
  color: var(--muted);
  font-size: 0.94rem;
}

.site-footer__nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
}

.site-footer__nav a {
  color: #1d1d1d;
  text-decoration: none;
  font-weight: 700;
}

.site-footer__nav a:hover,
.site-footer__nav a:focus-visible,
.site-footer__nav .site-footer__link--active {
  color: var(--accent);
}

@media (max-width: 860px) {
  .site-main {
    padding-bottom: 2rem;
  }

  .site-footer__inner {
    align-items: flex-start;
    flex-direction: column;
  }

  .site-footer__nav {
    gap: 0.45rem 0.9rem;
  }
}

@media (max-width: 640px) {
  .site-header {
    min-height: 4.8rem;
  }

  .nav-btn-js {
    width: 3rem;
    height: 3rem;
  }

  .header__menu-item a {
    letter-spacing: 0.04em;
  }
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 1ms !important;
    scroll-behavior: auto !important;
  }
}

@keyframes fadein {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}
