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

:root {
  --bg: #0f0f0f;
  --fg: #e8e8e8;
  --accent: #e84674;
  --muted: #999;
  --font: 'Segoe UI', system-ui, -apple-system, sans-serif;
}

.la-belle-aurore-regular {
  font-family: "La Belle Aurore", cursive;
  font-weight: 400;
  font-style: normal;
}

html, body {
  height: 100%;
  overflow: hidden;
}

body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font);
  min-height: 100vh;
}

a {
  color: var(--accent);
}

#bg {
  position: fixed;
  inset: 0;
  z-index: -1;
  overflow: hidden;
}

#bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  pointer-events: none;
  -webkit-touch-callout: none;
  user-select: none;
  -webkit-user-select: none;
}

/* Hero: desktop — left-anchored, vertically centered in top half */
.hero {
  position: fixed;
  top: 30vh;
  left: 15vw;
  white-space: nowrap;
  backdrop-filter: blur(0.5px);
  -webkit-backdrop-filter: blur(0.5px);
  display: flex;
  flex-flow: column nowrap;
  align-items: start;
}
.hero .hero-items-hori-flex {
    display: flex;
    flex-flow: row;
    justify-content: center;
  }
.hero name {
  display: block;
  font-size: 3.5rem;
  line-height: 1;
}

.links {
  margin-top: 1rem;
  display: flex;
  gap: 1.5rem;
  justify-content: left;
  transform: translate(0rem, -1rem);
}

.links a {
  color: var(--accent);
  text-decoration: none;
  font-size: 1rem;
  letter-spacing: 0.02em;
  opacity: 0.85;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  border-bottom: 1px solid transparent;
  transition: opacity 0.2s, transform 0.2s, border-color 0.2s;
  cursor: pointer;
}

.links a:hover {
  opacity: 1;
  transform: scale(1.1);
  border-color: var(--accent);
  cursor: pointer;
}

.links a, 
.links a svg {
  cursor: pointer !important;
}
.links.hero-items-hori-flex {
  position: relative;
  z-index: 10;          /* Pulls the links above hidden overlapping layers */
  pointer-events: auto; /* Ensures mouse clicks are captured */
}

/* Caption: frosted box, bottom-right */
#caption {
  position: fixed;
  bottom: 1.25rem;
  right: 1.25rem;
  font-family: Arial, Helvetica, sans-serif;
  font-style: italic;
  font-size: 0.70rem;
  line-height: 1.3;
  color: #ffffffa1;
  text-align: right;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  padding: 0.3rem 0.5rem;
}

@media (max-width: 768px) {
  .hero {
    display: flex;
    flex-flow: column;
    left: 50%;
    transform: translate(-50%, -100%);
    white-space: normal;
    width: 90vw;
    align-items: center;
  }
  
  
  .hero name {
    font-size: clamp(3.5rem, 10vw, 2.5rem);
  }

  .links {
    transform: translate(0rem, 0rem);
  }

  #caption {
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    text-align: center;
    bottom: 1rem;
    font-size: 0.65rem;
    width: max-content;
    max-width: 90vw;
    background: transparent;
    border: none;
    color: var(--muted);
    position: fixed;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  #caption::before,
  #caption::after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 0.75rem;
    height: 1px;
    background: var(--muted);
  }

  #caption::before { left: 0; }
  #caption::after  { right: 0; }
}
