/* =========================================================================
   Contact page
   ========================================================================= */

/* ─── Page base ─── */
.page-contact {
  background: var(--dark);
  color: var(--light);
}

/* ─── Navbar on contact ─── */

/* ═══════════════════════════════════════════════════════════════════════
   HERO — full-viewport, giant email display
   ═══════════════════════════════════════════════════════════════════════ */
.ct-hero {
  position: relative;
  width: 100%;
  height: 90vh;
  min-height: 600px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0 var(--page-pad);
  overflow: hidden;
  isolation: isolate;
}

/* full-bleed background video */
.ct-hero__video {
  position: absolute; inset: 0;
  z-index: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}

/* 50% solid black overlay to darken the video */
.ct-hero__overlay {
  position: absolute; inset: 0;
  z-index: 1;
  background: rgba(0, 0, 0, 0.5);
  pointer-events: none;
}

.ct-hero__vignette {
  position: absolute; inset: 0;
  z-index: 1;
  background:
    radial-gradient(80% 60% at 50% 55%, transparent 0%, rgba(0,0,0,0.35) 75%, rgba(0,0,0,0.7) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.15) 0%, transparent 20%, transparent 70%, rgba(0,0,0,0.5) 100%);
  pointer-events: none;
}

/* ─── Email block wrapper ─── */
.ct-hero__email-block {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 0;
}

/* ─── Giant email display ─── */
.ct-hero__display {
  position: relative;
  z-index: 2;
  margin: 0;
  font-size: 80px; /* fallback before JS kicks in */
  line-height: 0.92;
  letter-spacing: -0.04em;
  font-weight: 500;
  text-transform: uppercase;
  color: #eeece4;
  display: flex;
  flex-direction: column;
  gap: 0;
  /* Fill the container width (respects the page padding — not edge to edge) */
  width: 100%;
}

.ct-hero__display-row {
  display: block;
  line-height: 0.92;
  overflow: hidden;
  white-space: nowrap;
}

/* Slide-up entrance — each line slides up independently */
@keyframes ctSlideUp {
  0% {
    transform: translateY(110%);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

.ct-hero__display-row {
  transform: translateY(110%);
  opacity: 0;
  animation: ctSlideUp 1.2s var(--ease-out) forwards;
}

.ct-hero__display-row:nth-child(1) {
  animation-delay: 0.2s;
}
.ct-hero__display-row:nth-child(2) {
  animation-delay: 0.45s;
}

/* ─── Location — left-aligned, above title ─── */
.ct-hero__location {
  display: flex;
  align-items: baseline;
  gap: 8px;
  align-self: flex-start;
  margin-bottom: 4px;
  animation: ctSlideUp 1.2s var(--ease-out) forwards;
  transform: translateY(110%);
  opacity: 0;
  animation-delay: 0.1s;
}

.ct-hero__tz {
  font-size: clamp(12px, 1.4vw, 18px);
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.ct-hero__city {
  font-size: clamp(12px, 1.4vw, 18px);
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
}

/* ─── Copy email button — small, right-aligned below title ─── */
.ct-hero__copy {
  z-index: 2;
  background: var(--light);
  border: 1px solid transparent;
  color: var(--dark);
  padding: 6px 14px;
  font-family: var(--font-sans);
  font-size: 9px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  align-self: flex-end;
  transition: background var(--motion-base) var(--ease-standard),
              color var(--motion-base) var(--ease-standard),
              border-color var(--motion-base) var(--ease-standard),
              transform var(--motion-base) var(--ease-standard);
  animation: ctSlideUp 1.2s var(--ease-out) forwards;
  transform: translateY(110%);
  opacity: 0;
  animation-delay: 0.65s;
}

.ct-hero__copy:hover {
  background: transparent;
  color: var(--light);
  border-color: rgba(255,255,255,0.35);
}

/* ─── Bottom bar ─── */
.ct-hero__bottom {
  position: absolute;
  left: var(--page-pad);
  right: var(--page-pad);
  bottom: var(--page-pad);
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  animation: heroReveal 2.2s var(--ease-out) forwards;
  opacity: 0;
  animation-delay: 0.6s;
}

.ct-hero__brand {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ct-hero__brand-name {
  font-size: clamp(16px, 2vw, 24px);
  font-weight: var(--fw-semibold);
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--light);
}

.ct-hero__brand-handle {
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}

.ct-hero__social {
  display: flex;
  gap: clamp(32px, 6vw, 80px);
}

.ct-hero__social-link {
  font-size: clamp(14px, 1.8vw, 22px);
  font-weight: var(--fw-medium);
  color: rgba(255,255,255,0.6);
  text-decoration: none;
  transition: color var(--motion-fast) var(--ease-standard);
  font-style: normal;
}

.ct-hero__social-link:hover {
  color: var(--light);
  opacity: 1;
}

/* ═══════════════════════════════════════════════════════════════════════
   REACH US — light section
   ═══════════════════════════════════════════════════════════════════════ */
.ct-reach {
  background: var(--light);
  color: var(--dark);
  padding: 96px var(--page-pad) 120px;
}

/* ─── Top: heading + info row ─── */
.ct-reach__top {
  max-width: 1400px;
  margin: 0 auto 96px;
}

.ct-reach__title {
  font-size: clamp(60px, 10vw, 160px);
  line-height: 0.92;
  font-weight: var(--fw-medium);
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: var(--dark);
  margin: 0 0 40px;
}

.ct-reach__info {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--page-pad);
  align-items: start;
}

.ct-reach__body {
  font-size: 14px;
  line-height: 1.5;
  color: var(--dark);
  max-width: 42ch;
  margin: 0;
  font-weight: var(--fw-regular);
}

.ct-reach__address {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--dark);
}

.ct-reach__links {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ct-reach__links a {
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--dark);
  text-decoration: none;
  transition: opacity var(--motion-fast) var(--ease-standard);
}

.ct-reach__links a:hover {
  opacity: 0.5;
}

/* ─── Bottom: form + image ─── */
.ct-reach__bottom {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}

.ct-reach__img-col {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}

.ct-reach__img {
  width: 100%;
  max-width: 340px;
  aspect-ratio: 3 / 4;
  margin-left: auto;
}

.ct-reach__video {
  object-fit: cover;
  display: block;
}

/* ═══════════════════════════════════════════════════════════════════════
   CONTACT FORM
   ═══════════════════════════════════════════════════════════════════════ */
.ct-form {
  display: flex;
  flex-direction: column;
  gap: 28px;
  max-width: 520px;
}

.ct-form__group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ct-form__label {
  font-size: 10px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dark);
}

.ct-form__input {
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: var(--fw-regular);
  color: var(--dark);
  background: none;
  border: none;
  border-bottom: 1px solid rgba(0,0,0,0.2);
  padding: 10px 0;
  outline: none;
  transition: border-color var(--motion-base) var(--ease-standard);
  border-radius: 0;
  -webkit-appearance: none;
}

.ct-form__input::placeholder {
  color: rgba(0,0,0,0.3);
}

.ct-form__input:focus {
  border-color: var(--dark);
}

.ct-form__select {
  cursor: pointer;
}

.ct-form__textarea {
  resize: vertical;
  min-height: 100px;
}

.ct-form__submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: flex-start;
  margin-top: 8px;
  background: var(--dark);
  color: var(--light);
  border: none;
  padding: 14px 28px;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: opacity var(--motion-base) var(--ease-standard),
              transform var(--motion-base) var(--ease-standard);
}

.ct-form__submit:hover {
  opacity: 0.8;
  transform: translateY(-1px);
}

.ct-form__submit-arrow {
  font-size: 14px;
  transform: translateY(1px);
}

/* ═══════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .ct-reach__info {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .ct-reach__bottom {
    grid-template-columns: 1fr;
    gap: 64px;
  }

  .ct-reach__img-col {
    justify-content: flex-start;
  }

  .ct-reach__img {
    margin-left: 0;
    max-width: 100%;
  }

  .ct-hero__location {
    gap: 4px;
  }

  .ct-hero__social {
    gap: 24px;
  }
}

@media (max-width: 600px) {
  .ct-hero__display {
    font-size: clamp(32px, 12vw, 80px);
    line-height: 1;
  }

  .ct-hero__display-row {
    line-height: 1;
  }

  .ct-hero__location {
    gap: 6px;
  }

  .ct-hero__copy {
    align-self: flex-start;
  }

  .ct-hero__bottom {
    flex-direction: column;
    gap: 24px;
    align-items: flex-start;
  }
}
