/* ═══════════════════════════════════════════════════
   SAROVERSE — PUBLIC WEBSITE
   Style A: Dark Organic
═══════════════════════════════════════════════════ */

/* ── TOKENS ──────────────────────────────────────── */
:root {
  --color-bg:        #080806;
  --color-surface:   #111109;
  --color-text:      #e8dcc8;
  --color-text-dim:  #9a8f7a;
  --color-amber:     #c87832;
  --color-violet:    #7040a0;
  --color-teal:      #40c8b0;
  --color-glow:      rgba(112, 64, 160, 0.25);

  --font-title: 'Cormorant Garamond', Georgia, serif;
  --font-body:  'Inter', system-ui, sans-serif;

  --transition-slow: 1000ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-med:  600ms  cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── RESET ───────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-weight: 300;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
a { color: inherit; text-decoration: none; }



/* ═══════════════════════════════════════════════════
   SECTION 1 — HERO
═══════════════════════════════════════════════════ */
#hero {
  position: relative;
  width: 100vw;
  height: 100dvh;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

#hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

/* Static fallback on small/no-video devices */
@media (max-width: 768px), (prefers-reduced-motion: reduce) {
  #hero-video { display: none; }
  #hero { background: url('../assets/hero-fallback.png') center center / cover no-repeat; }
}

#hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(8, 8, 6, 0.15) 0%,
    rgba(8, 8, 6, 0.45) 70%,
    rgba(8, 8, 6, 0.85) 100%
  );
  z-index: 1;
}

#hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1200ms ease, transform 1200ms ease;
}
#hero-content.visible {
  opacity: 1;
  transform: translateY(0);
}

#wordmark {
  font-family: var(--font-title);
  font-size: clamp(3.5rem, 10vw, 9rem);
  font-weight: 300;
  letter-spacing: 0.25em;
  color: var(--color-text);
  text-shadow: 0 0 80px rgba(200, 120, 50, 0.3), 0 0 160px rgba(112, 64, 160, 0.2);
  line-height: 1;
}

#tagline {
  margin-top: 1.2rem;
  font-family: var(--font-title);
  font-style: italic;
  font-size: clamp(1rem, 2.5vw, 1.5rem);
  font-weight: 300;
  color: var(--color-text-dim);
  letter-spacing: 0.12em;
  opacity: 0;
  transition: opacity 1000ms ease 600ms;
}
#hero-content.visible #tagline { opacity: 1; }

#scroll-hint {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  opacity: 0;
  transition: opacity 800ms ease;
}
#scroll-hint.visible { opacity: 1; }
#scroll-hint span {
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  color: var(--color-text-dim);
}
#scroll-arrow {
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, var(--color-text-dim), transparent);
  animation: scroll-pulse 2s ease-in-out infinite;
}
@keyframes scroll-pulse {
  0%, 100% { opacity: 0.4; transform: scaleY(1); }
  50%       { opacity: 1;   transform: scaleY(1.2); }
}


/* ═══════════════════════════════════════════════════
   WORLD SECTIONS (full-bleed image panels)
═══════════════════════════════════════════════════ */
.world-section {
  position: relative;
  width: 100%;
  height: 100dvh;
  display: flex;
  align-items: flex-end;
  background-image: var(--bg-image);
  background-size: cover;
  background-position: center;
  background-attachment: fixed; /* parallax on desktop */
  overflow: hidden;
}

@media (max-width: 768px) {
  .world-section { background-attachment: scroll; } /* fixed breaks on iOS */
}

.world-section__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(8, 8, 6, 0.88) 0%,
    rgba(8, 8, 6, 0.4)  40%,
    rgba(8, 8, 6, 0.15) 100%
  );
}

.world-section__content {
  position: relative;
  z-index: 1;
  padding: 4rem 6vw;
  max-width: 600px;
}
.world-section__content.reveal--right {
  margin-left: auto;
  text-align: right;
}

/* ── Section typography ── */
.section-label {
  display: block;
  font-size: 0.65rem;
  letter-spacing: 0.35em;
  color: var(--color-amber);
  margin-bottom: 0.75rem;
  font-weight: 400;
}
.section-title {
  font-family: var(--font-title);
  font-size: clamp(2.5rem, 6vw, 5rem);
  font-weight: 300;
  letter-spacing: 0.06em;
  line-height: 1.05;
  color: var(--color-text);
}
.section-body {
  margin-top: 1rem;
  font-size: clamp(0.9rem, 1.5vw, 1.1rem);
  line-height: 1.7;
  color: var(--color-text-dim);
  max-width: 42ch;
}
.world-section__content.reveal--right .section-body { margin-left: auto; }


/* ═══════════════════════════════════════════════════
   SECTION 4 — TRIBES
═══════════════════════════════════════════════════ */
#section-tribes {
  padding: 7rem 6vw;
  background: var(--color-bg);
}

.section-header {
  text-align: center;
  margin-bottom: 5rem;
}
.section-header .section-body { margin: 1rem auto 0; }

.tribes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
}

.tribe-card {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: var(--color-surface);
  overflow: hidden;
  transition: transform var(--transition-med), box-shadow var(--transition-med);
}
.tribe-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 0 40px var(--glow-color, var(--color-glow));
}

.tribe-card__image {
  width: 100%;
  aspect-ratio: 3 / 4;
  background-image: var(--tribe-img);
  background-size: cover;
  background-position: center top;
  transition: transform 800ms ease;
}
.tribe-card:hover .tribe-card__image { transform: scale(1.04); }

.tribe-card__body {
  padding: 1.25rem 1.25rem 1.5rem;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.tribe-card__name {
  font-family: var(--font-title);
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  color: var(--color-text);
  margin-bottom: 0.4rem;
}
.tribe-card__desc {
  font-size: 0.8rem;
  line-height: 1.55;
  color: var(--color-text-dim);
}


/* tribes → characters button */
.tribes-cta {
  text-align: center;
  padding-top: 4rem;
}
.cta-button--characters {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 3rem;
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  border-color: rgba(200, 120, 50, 0.4);
  color: var(--color-amber);
  position: relative;
  overflow: hidden;
}
.cta-button--characters::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(200, 120, 50, 0.06), transparent);
  transform: translateX(-100%);
  transition: transform 700ms ease;
}
.cta-button--characters:hover::before { transform: translateX(100%); }
.cta-button--characters:hover {
  border-color: var(--color-amber);
  box-shadow: 0 0 40px rgba(200, 120, 50, 0.12), inset 0 0 20px rgba(200, 120, 50, 0.04);
}
.cta-arrow {
  display: inline-block;
  transition: transform var(--transition-med);
}
.cta-button--characters:hover .cta-arrow { transform: translateX(5px); }

/* ═══════════════════════════════════════════════════
   SECTION 5 — CHARACTERS
═══════════════════════════════════════════════════ */
#section-characters {
  padding: 7rem 6vw 9rem;
  background: var(--color-bg);
}
#section-characters .section-header {
  margin-bottom: 4rem;
}

.characters-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  max-width: 1000px;
  margin: 0 auto;
}
@media (max-width: 640px) {
  .characters-grid { grid-template-columns: 1fr; gap: 1.5rem; }
}

.character-card {
  position: relative;
  overflow: hidden;
  cursor: default;
}

.character-card__image {
  width: 100%;
  aspect-ratio: 2 / 3;
  background-image: var(--char-img);
  background-size: cover;
  background-position: center top;
  transition: transform 1000ms cubic-bezier(0.4, 0, 0.2, 1);
}
.character-card:hover .character-card__image {
  transform: scale(1.04);
}

/* gradient fade at bottom over image */
.character-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 55%;
  background: linear-gradient(to top, rgba(8,8,6,0.95) 0%, rgba(8,8,6,0.6) 50%, transparent 100%);
  pointer-events: none;
}

.character-card__body {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 2rem 2.2rem 2.2rem;
  z-index: 1;
}
.character-card__tribe {
  display: block;
  font-size: 0.62rem;
  letter-spacing: 0.35em;
  color: var(--color-amber);
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}
.character-card__name {
  font-family: var(--font-title);
  font-size: clamp(2.8rem, 5vw, 4.2rem);
  font-weight: 300;
  letter-spacing: 0.08em;
  color: var(--color-text);
  line-height: 1;
  transition: letter-spacing var(--transition-slow);
}
.character-card:hover .character-card__name {
  letter-spacing: 0.12em;
}

/* ═══════════════════════════════════════════════════
   SECTION — MAP TEASER
═══════════════════════════════════════════════════ */
#section-map {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-bg);
  background-image:
    /* Vignette focused on Drakonis Swamp area (right-center, slightly below) */
    radial-gradient(ellipse 48% 52% at 63% 52%,
      rgba(8,8,6,0.05) 0%,
      rgba(8,8,6,0.40) 42%,
      rgba(8,8,6,0.80) 65%,
      var(--color-bg) 86%
    ),
    url('../assets/images/world-map.png');
  background-size: auto, 88%;
  background-position: center, center;
  background-repeat: no-repeat, no-repeat;
  overflow: hidden;
}

/* Fade into adjacent sections */
#section-map::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, var(--color-bg) 0%, transparent 12%, transparent 88%, var(--color-bg) 100%);
  pointer-events: none;
  z-index: 1;
}

.map-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 4rem;
}

.map-survey {
  display: block;
  font-size: 0.55rem;
  letter-spacing: 0.3em;
  color: var(--color-text-dim);
  opacity: 0.4;
  margin-top: 2rem;
}

/* ── Location pins ─────────────────────────────── */
.map-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  z-index: 3;
  cursor: default;
}

.map-pin__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--pin-color, var(--color-amber));
  box-shadow: 0 0 12px var(--pin-glow, rgba(200,120,50,1.0)),
              0 0 36px var(--pin-glow, rgba(200,120,50,0.65)),
              0 0 80px var(--pin-glow, rgba(200,120,50,0.25));
  outline: 1px solid var(--pin-color, var(--color-amber));
  outline-offset: 6px;
}

.map-pin__ring {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 1.5px solid var(--pin-color, var(--color-amber));
  opacity: 0;
  transform: translate(-50%, -50%);
  animation: pin-pulse 2.6s ease-out infinite;
  pointer-events: none;
}
.map-pin__ring:nth-child(2) { animation-delay: 1.3s; }

@keyframes pin-pulse {
  0%   { width: 12px; height: 12px; opacity: 0.85; }
  100% { width: 72px; height: 72px; opacity: 0;    }
}

/* Tooltip label — appears above pin on hover */
.map-pin__label {
  position: absolute;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%) translateY(5px);
  padding: 0.55rem 1rem 0.5rem;
  background: rgba(8, 8, 6, 0.92);
  border: 1px solid var(--pin-border, rgba(200,120,50,0.28));
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 300ms ease, transform 300ms ease;
}
.map-pin:hover .map-pin__label {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* Thin line from label to dot */
.map-pin__label::after {
  content: '';
  position: absolute;
  bottom: -9px;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 8px;
  background: var(--pin-color, var(--color-amber));
  opacity: 0.45;
}

.map-pin__name {
  display: block;
  font-size: 0.58rem;
  letter-spacing: 0.32em;
  color: var(--pin-color, var(--color-amber));
  margin-bottom: 0.22rem;
}
.map-pin__desc {
  display: block;
  font-size: 0.5rem;
  letter-spacing: 0.18em;
  color: var(--color-text-dim);
  opacity: 0.75;
}

/* Technicians pin — teal */
.map-pin--tech {
  --pin-color:  var(--color-teal);
  --pin-glow:   rgba(64,200,176,0.8);
  --pin-border: rgba(64,200,176,0.28);
}

/* ═══════════════════════════════════════════════════
   SECTION 6 — GALLERY CTA
═══════════════════════════════════════════════════ */
#section-gallery-cta {
  padding: 8rem 6vw;
  text-align: center;
  background: var(--color-surface);
  border-top: 1px solid rgba(255,255,255,0.05);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
#section-gallery-cta .section-body { margin: 1rem auto 2.5rem; }


/* ═══════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════ */
.cta-button {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.85rem 2.2rem;
  border: 1px solid rgba(200, 120, 50, 0.5);
  color: var(--color-amber);
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  background: transparent;
  transition: background var(--transition-med), border-color var(--transition-med), color var(--transition-med), box-shadow var(--transition-med);
}
.cta-button:hover {
  background: rgba(200, 120, 50, 0.1);
  border-color: var(--color-amber);
  box-shadow: 0 0 30px rgba(200, 120, 50, 0.15);
}
.cta-button--instagram {
  color: var(--color-text-dim);
  border-color: rgba(255,255,255,0.15);
  margin-top: 2rem;
}
.cta-button--instagram:hover {
  color: var(--color-text);
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.3);
  box-shadow: none;
}


/* ═══════════════════════════════════════════════════
   SECTION 6 — CLOSING CTA
═══════════════════════════════════════════════════ */
#section-cta {
  padding: 10rem 6vw 5rem;
  text-align: center;
  background: var(--color-bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}
.cta-more {
  font-family: var(--font-title);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 300;
  font-style: italic;
  color: var(--color-text);
  letter-spacing: 0.05em;
}
#footer-wordmark {
  margin-top: 6rem;
  font-family: var(--font-title);
  font-size: clamp(0.9rem, 2vw, 1.2rem);
  letter-spacing: 0.4em;
  color: rgba(255,255,255,0.12);
  padding-bottom: 3rem;
}


/* ═══════════════════════════════════════════════════
   GALLERY OVERLAY
═══════════════════════════════════════════════════ */
#gallery-overlay {
  position: fixed;
  inset: 0;
  background: #000;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 500ms ease;
}
#gallery-overlay.open {
  opacity: 1;
  pointer-events: all;
}

#gallery-img-wrap {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 5rem;
}
#gallery-img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  user-select: none;
  transition: opacity 300ms ease;
}
#gallery-img.fading { opacity: 0; }

#gallery-close,
#gallery-prev,
#gallery-next {
  position: absolute;
  background: rgba(8, 8, 6, 0.6);
  color: var(--color-text-dim);
  font-size: 1.1rem;
  padding: 0.8rem 1rem;
  transition: color var(--transition-med), background var(--transition-med);
  z-index: 2;
  line-height: 1;
}
#gallery-close:hover,
#gallery-prev:hover,
#gallery-next:hover {
  color: var(--color-text);
  background: rgba(8, 8, 6, 0.9);
}

#gallery-close { top: 1.5rem; right: 1.5rem; font-size: 1rem; letter-spacing: 0.05em; }
#gallery-prev  { left: 1rem;  top: 50%; transform: translateY(-50%); font-size: 1.4rem; padding: 1.2rem; }
#gallery-next  { right: 1rem; top: 50%; transform: translateY(-50%); font-size: 1.4rem; padding: 1.2rem; }

#gallery-caption {
  position: absolute;
  bottom: 3rem;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  color: rgba(255,255,255,0.35);
  white-space: nowrap;
}
#gallery-counter {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  color: rgba(255,255,255,0.2);
}


/* ═══════════════════════════════════════════════════
   SCROLL REVEAL ANIMATIONS
═══════════════════════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 900ms ease, transform 900ms ease;
}
.reveal--right {
  transform: translateY(28px) translateX(20px);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0) translateX(0);
}

/* Stagger tribe cards */
.tribe-card:nth-child(1) { transition-delay: 0ms;   }
.tribe-card:nth-child(2) { transition-delay: 80ms;  }
.tribe-card:nth-child(3) { transition-delay: 160ms; }
.tribe-card:nth-child(4) { transition-delay: 240ms; }
.tribe-card:nth-child(5) { transition-delay: 320ms; }


/* ═══════════════════════════════════════════════════
   FULLSCREEN BUTTON
═══════════════════════════════════════════════════ */
#fullscreen-btn {
  position: fixed;
  bottom: 1.6rem;
  right: 1.6rem;
  z-index: 900;
  width: 2.4rem;
  height: 2.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(8, 8, 6, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--color-text-dim);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: color var(--transition-med), border-color var(--transition-med), background var(--transition-med);
  cursor: pointer;
}
#fullscreen-btn:hover {
  color: var(--color-text);
  border-color: rgba(255, 255, 255, 0.25);
  background: rgba(8, 8, 6, 0.8);
}
/* Hide on devices that don't support fullscreen (iOS Safari) */
@media (max-width: 768px) {
  #fullscreen-btn { display: none; }
}

/* ═══════════════════════════════════════════════════
   UTILITY
═══════════════════════════════════════════════════ */
::selection {
  background: var(--color-violet);
  color: var(--color-text);
}
:focus-visible {
  outline: 1px solid var(--color-amber);
  outline-offset: 3px;
}
