/* Alte-Haas-Grotesk Webfont */
@font-face {
  font-family: "Alte-Haas-Grotesk";
  src: url("assets/Alte-Haas-Grotesk.ttf.woff") format("woff"),
       url("assets/Alte-Haas-Grotesk.ttf.svg#Alte-Haas-Grotesk") format("svg"),
       url("assets/Alte-Haas-Grotesk.ttf.eot"),
       url("assets/Alte-Haas-Grotesk.ttf.eot?#iefix") format("embedded-opentype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* Apply Alte-Haas-Grotesk to headings and key elements */
h1, h2, h3, h4, h5, h6 {
  font-family: "Alte-Haas-Grotesk", system-ui, -apple-system, sans-serif;
}

:root {
  color-scheme: light;
}

*, 
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  width: 100%;
  height: 100%;
}

body {
  margin: 0;
  min-height: 100vh;
  background: #f6f7f9;
  color: #0f172a;
  font-family: "Alte-Haas-Grotesk", "Helvetica Neue", Arial, sans-serif;
  letter-spacing: 0.01em;
}

.fullscreen {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
}

.fullscreen video {
  width: 100vw;
  height: 100vh;
  object-fit: cover;
  display: block;
}

.corner-mark {
  position: absolute;
  left: clamp(14px, 3vw, 28px);
  top: clamp(14px, 3vw, 28px);
  display: inline-flex;
  flex-direction: column;
  gap: 0;
  z-index: 2;
}

.mark-word {
  display: block;
  background: #ffffff;
  color: #000000;
  padding: 16px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: clamp(1.8rem, 4vw, 2.2rem);
  width: fit-content;
  text-align: left;
}

.mark-word:first-child {
  padding-bottom: 8px;
}

.mark-word:last-child {
  padding-top: 0;
}

.contact-link {
  position: absolute;
  left: clamp(14px, 3vw, 28px);
  bottom: calc(clamp(14px, 3vw, 28px) + env(safe-area-inset-bottom, 0px));
  padding: 7px 10px;
  background: #ffffff;
  color: #000000;
  text-decoration: none;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: clamp(0.63rem, 1.4vw, 0.77rem);
  display: inline-block;
  z-index: 2;
}
