@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500&family=Outfit:wght@400;500;600;700&display=swap');

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.125rem);
}

/* Responsive type scale overrides Tailwind CDN utilities loaded before this file. */
.text-xs {
  font-size: clamp(0.75rem, 0.72rem + 0.15vw, 0.875rem);
}

.text-sm {
  font-size: clamp(0.875rem, 0.84rem + 0.18vw, 1rem);
}

.text-base {
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.125rem);
}

.text-lg,
button {
  font-size: clamp(1.0625rem, 1rem + 0.32vw, 1.25rem);
}

.text-xl {
  font-size: clamp(1.1875rem, 1.08rem + 0.55vw, 1.5rem);
}

.text-2xl {
  font-size: clamp(1.375rem, 1.18rem + 0.95vw, 2rem);
}

.text-3xl {
  font-size: clamp(1.625rem, 1.34rem + 1.43vw, 2.5rem);
}

.text-4xl {
  font-size: clamp(2rem, 1.55rem + 2.25vw, 3.25rem);
}

.text-5xl {
  font-size: clamp(2.35rem, 1.7rem + 3.25vw, 4.5rem);
}

.text-6xl {
  font-size: clamp(2.75rem, 1.88rem + 4.35vw, 5.5rem);
}

.text-7xl {
  font-size: clamp(3.125rem, 2rem + 5.65vw, 6.5rem);
}

.btn-primary,
.btn-secondary {
  font-size: clamp(1.0625rem, 1rem + 0.32vw, 1.25rem);
}

@media (min-width: 768px) {
  .md\:text-sm {
    font-size: clamp(0.875rem, 0.84rem + 0.18vw, 1rem);
  }

  .md\:text-base {
    font-size: clamp(1rem, 0.96rem + 0.2vw, 1.125rem);
  }

  .md\:text-xl {
    font-size: clamp(1.1875rem, 1.08rem + 0.55vw, 1.5rem);
  }

  .md\:text-3xl {
    font-size: clamp(1.625rem, 1.34rem + 1.43vw, 2.5rem);
  }

  .md\:text-4xl {
    font-size: clamp(2rem, 1.55rem + 2.25vw, 3.25rem);
  }

  .md\:text-5xl {
    font-size: clamp(2.35rem, 1.7rem + 3.25vw, 4.5rem);
  }

  .md\:text-6xl {
    font-size: clamp(2.75rem, 1.88rem + 4.35vw, 5.5rem);
  }

  .md\:text-7xl {
    font-size: clamp(3.125rem, 2rem + 5.65vw, 6.5rem);
  }
}

@media (min-width: 1024px) {
  .lg\:text-2xl {
    font-size: clamp(1.375rem, 1.18rem + 0.95vw, 2rem);
  }

  .lg\:text-5xl {
    font-size: clamp(2.35rem, 1.7rem + 3.25vw, 4.5rem);
  }

  .lg\:text-6xl {
    font-size: clamp(2.75rem, 1.88rem + 4.35vw, 5.5rem);
  }

  .lg\:text-7xl {
    font-size: clamp(3.125rem, 2rem + 5.65vw, 6.5rem);
  }
}

/* Custom Overrides */
.text-outline {
  -webkit-text-stroke: 1px rgba(255,255,255,0.2);
  color: transparent;
}

/* Image zoom effect wrapper */
.img-wrap {
  overflow: hidden;
}

.img-wrap img {
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.group:hover .img-wrap img {
  transform: scale(1.05);
}

.project-card-visible {
  opacity: 1 !important;
  transform: translate(0, 0) !important;
  visibility: visible !important;
}

#mainHeader nav a:not([aria-label]) {
  position: relative;
  padding-bottom: 0.25rem;
  border-bottom-color: transparent;
}

#mainHeader nav a:not([aria-label])::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 220ms ease;
}

#mainHeader nav a:not([aria-label]):hover::after,
#mainHeader nav a:not([aria-label]):focus-visible::after,
#mainHeader nav a.active-link::after {
  transform: scaleX(1);
}

#mainHeader nav a.active-link {
  color: #3F5A4A;
}

#mobileMenu a.active-link {
  color: #A06A43;
  text-decoration: underline;
  text-underline-offset: 0.35em;
}

#mobileMenu {
  width: 100vw;
  min-height: 100vh;
  min-height: 100dvh;
  z-index: 70;
  background: #ffffff;
  color: #2B241F;
  opacity: 0;
  transform: translateY(-12px);
  pointer-events: none;
  transition:
    opacity 260ms ease,
    transform 260ms ease;
}

#mobileMenu.mobile-menu-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

#mobileMenu > a {
  transform: translateY(10px);
  transition:
    color 180ms ease,
    transform 260ms ease;
}

#mobileMenu.mobile-menu-visible > a {
  transform: translateY(0);
}

.mobile-menu-close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  color: currentColor;
  border: 1px solid currentColor;
  border-radius: 9999px;
  opacity: 0.85;
  transition:
    opacity 180ms ease,
    transform 180ms ease;
}

.mobile-menu-close:hover {
  opacity: 1;
  transform: scale(1.04);
}

.mobile-menu-close:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 4px;
}

body.mobile-menu-locked {
  overflow: hidden;
}
