/* ============================================================
   TIX — Design Tokens & CSS Reset
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,700;1,900&family=Playfair+Display:ital,wght@0,700;0,900;1,700;1,900&family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

:root {
  --black: #080808;
  --black-2: #0f0f0f;
  --black-3: #151515;
  --surface: #1c1c1c;
  --surface-2: #242424;
  --border: rgba(255, 255, 255, 0.07);
  --border-hover: rgba(255, 255, 255, 0.18);

  --crimson: #8B0000;
  --crimson-mid: #A80000;
  --crimson-bright: #C0392B;
  --crimson-glow: rgba(139, 0, 0, 0.35);
  --crimson-subtle: rgba(139, 0, 0, 0.12);

  --white: #FFFFFF;
  --off-white: #F0EEE9;
  --muted: #999999;
  --muted-2: #5a5a5a;

  --font-display: 'Montserrat', sans-serif;
  --font-editorial: 'Playfair Display', serif;
  --font-body: 'Space Grotesk', sans-serif;

  --display-xl: clamp(3.2rem, 7.5vw, 7rem);
  --display-lg: clamp(2.5rem, 5.5vw, 5rem);
  --display-md: clamp(1.8rem, 3.5vw, 3rem);
  --display-sm: clamp(1.3rem, 2.5vw, 2rem);

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-inout: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  --nav-height: 68px;
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-pill: 999px;
  --container: 1340px;
}

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

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden
}

body {
  background: var(--black);
  color: var(--white);
  font-family: var(--font-body);
  line-height: 1.6;
  overflow-x: hidden
}

img,
video {
  display: block;
  max-width: 100%;
  height: auto
}

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

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit
}

ul,
ol {
  list-style: none
}

::selection {
  background: var(--crimson);
  color: var(--white)
}

::-webkit-scrollbar {
  width: 3px
}

::-webkit-scrollbar-track {
  background: var(--black)
}

::-webkit-scrollbar-thumb {
  background: var(--crimson);
  border-radius: 2px
}

.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(1.25rem, 4vw, 3.5rem)
}

/* Reveal system */
[data-reveal] {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity .8s var(--ease-out), transform .8s var(--ease-out)
}

[data-reveal="left"] {
  transform: translateX(-40px)
}

[data-reveal="right"] {
  transform: translateX(40px)
}

[data-reveal="scale"] {
  transform: scale(0.93)
}

[data-reveal="fade"] {
  transform: none
}

[data-reveal].is-visible {
  opacity: 1;
  transform: none
}

[data-stagger]>* {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s var(--ease-out), transform .7s var(--ease-out)
}

[data-stagger].is-visible>*:nth-child(1) {
  transition-delay: 0s
}

[data-stagger].is-visible>*:nth-child(2) {
  transition-delay: .08s
}

[data-stagger].is-visible>*:nth-child(3) {
  transition-delay: .16s
}

[data-stagger].is-visible>*:nth-child(4) {
  transition-delay: .24s
}

[data-stagger].is-visible>*:nth-child(5) {
  transition-delay: .32s
}

[data-stagger].is-visible>*:nth-child(6) {
  transition-delay: .40s
}

[data-stagger].is-visible>*:nth-child(7) {
  transition-delay: .48s
}

[data-stagger].is-visible>*:nth-child(8) {
  transition-delay: .56s
}

[data-stagger].is-visible>* {
  opacity: 1;
  transform: none
}

@media(prefers-reduced-motion:reduce) {

  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important
  }

  [data-reveal],
  [data-stagger]>* {
    opacity: 1 !important;
    transform: none !important
  }
}