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

:root {
  --bg: #080808;
  --fg: #f2ede8;
  --pink: #ff1a54;
  --yellow: #ffe600;
  --purple: #c026d3;
  --muted: rgba(242, 237, 232, 0.4);
}

html {
  background: var(--bg);
}

body {
  background: var(--bg);
  color: var(--fg);
  font-family: 'Space Grotesk', sans-serif;
  overflow-x: hidden;
  min-height: 100vh;
}

/* ── HERO ────────────────────────────────────── */

.hero {
  padding: clamp(40px, 7vw, 96px) clamp(24px, 5vw, 72px) 0;
}

h1 {
  font-family: 'Bebas Neue', sans-serif;
  line-height: 0.86;
  letter-spacing: -0.01em;
}

.name-first,
.name-last {
  display: block;
  font-size: clamp(96px, 19.5vw, 272px);
}

.name-first {
  color: transparent;
  -webkit-text-stroke: 2px var(--fg);
  paint-order: stroke fill;
}

.name-last {
  color: var(--pink);
}

.tagline {
  margin-top: clamp(10px, 1.5vw, 20px);
  padding-left: 5px;
  font-size: clamp(13px, 1.6vw, 21px);
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.1em;
  color: rgba(242, 237, 232, 0.65);
}

/* ── GALLERY ─────────────────────────────────── */

#gallery {
  position: relative;
  margin: clamp(48px, 7vw, 96px) clamp(24px, 5vw, 72px);
}

.photo-card {
  position: absolute;
  border-radius: 3px;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.3s ease, width 0.3s ease, height 0.3s ease;
  will-change: transform;
}

.photo-card:hover {
  transform: rotate(0deg) scale(1.06) !important;
  z-index: 100 !important;
}

.photo-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
}

.photo-card[data-location]::after {
  content: attr(data-location);
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 28px 10px 8px;
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.6));
  color: #fff;
  font-size: 11px;
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.07em;
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
}

.photo-card[data-location]:hover::after {
  opacity: 1;
}

.photo-card.is-swapping {
  animation: photo-swap 0.35s ease forwards;
}

@keyframes photo-swap {
  0%   { opacity: 1; transform: rotate(var(--rot)) scale(1); }
  45%  { opacity: 0; transform: rotate(var(--rot)) scale(0.88); }
  55%  { opacity: 0; transform: rotate(var(--rot)) scale(0.88); }
  100% { opacity: 1; transform: rotate(var(--rot)) scale(1); }
}

/* ── LINKS ───────────────────────────────────── */

.links {
  padding: 0 clamp(24px, 5vw, 72px) clamp(40px, 7vw, 80px);
}

.ig-link {
  font-size: clamp(24px, 4.5vw, 64px);
  font-weight: 700;
  color: var(--fg);
  text-decoration: none;
  display: inline-block;
  position: relative;
  transition: color 0.15s;
}

.ig-link::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: clamp(2px, 0.35vw, 4px);
  background: linear-gradient(90deg, var(--pink), var(--yellow));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}

.ig-link:hover {
  color: var(--pink);
}

.ig-link:hover::after {
  transform: scaleX(1);
}


/* ── MOBILE ──────────────────────────────────── */

@media (max-width: 640px) {
  #gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    height: auto !important;
  }

  .photo-card {
    position: relative;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 3 / 4;
  }

  .photo-card[data-location]::after {
    opacity: 1;
  }
}
