/* ============================================================
   GLOBAL STYLES
   ============================================================ */

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

html,
body,
.page-wrapper {
  background: #0C0C0C;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Kanit', sans-serif;
  color: #D7E2EA;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.page-wrapper {
  overflow-x: clip;
  width: 100%;
}

img {
  display: block;
  max-width: 100%;
}

a {
  text-decoration: none;
  color: inherit;
}

/* Gradient heading text */
.hero-heading {
  background: linear-gradient(180deg, #646973 0%, #BBCCD7 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ----- FadeIn utility (driven by js/fadeIn.js) ----- */
.fade-in {
  opacity: 0;
  transform: translate(var(--fade-x, 0px), var(--fade-y, 30px));
  transition:
    opacity var(--fade-duration, 0.7s) cubic-bezier(0.25, 0.1, 0.25, 1),
    transform var(--fade-duration, 0.7s) cubic-bezier(0.25, 0.1, 0.25, 1);
  transition-delay: var(--fade-delay, 0s);
  will-change: opacity, transform;
}

.fade-in.is-visible {
  opacity: 1;
  transform: translate(0, 0);
}

@media (prefers-reduced-motion: reduce) {
  .fade-in {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
