/* ============================================================
   Index loop — full-viewport fade slideshow
   ============================================================ */

/* Override body flex layout for this page */
.index-page {
  display: block;
  overflow: hidden;
}

/* Swiper fills the entire viewport */
.index-swiper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.index-swiper .swiper-slide {
  position: relative;
  background: var(--color-black);
  overflow: hidden;
  cursor: pointer;
}

/* ----------------------------------------------------------
   Top bar: logo + compliance note
   ---------------------------------------------------------- */
.index-topbar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 28px;
}

.index-logo {
  height: 24px;
  width: auto;
}

.index-compliance {
  font-size: 9px;
  color: var(--color-orange);
  font-family: Arial, Helvetica, sans-serif;
  text-align: right;
  max-width: 360px;
  line-height: 1.4;
}

/* ----------------------------------------------------------
   Eye image — large circular photo, shifted right of centre
   ---------------------------------------------------------- */
.index-eye {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -48%);
  width: 84vh;
  height: 84vh;
}

.index-eye img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
  max-width: none; /* override base.css img rule */
}

/* ----------------------------------------------------------
   Callout circle — orange gradient, overlaps left of eye
   ---------------------------------------------------------- */
.index-callout {
  position: absolute;
  top: 50%;
  left: 20vw;
  transform: translate(-50%, -50%);
  width: min(32vw, 48vh);
  height: min(32vw, 48vh);
  flex-shrink: 0;
  border-radius: 50%;
  overflow: hidden;
  background: var(--color-active-gradient);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 0 8vh 0 10vh;
  z-index: 10;
}

.index-label {
  font-size: 10px;
  font-family: Arial, Helvetica, sans-serif;
  color: rgba(255, 255, 255, 0.75);
  margin-bottom: 10px;
  letter-spacing: 0.03em;
}

.index-title {
  font-family: 'Noto Sans Extra Condensed', Arial, sans-serif;
  font-size: 3vh;
  font-weight: bold;
  color: var(--color-white);
  line-height: 1.2;
  margin-bottom: 18px;
}

.index-cta {
  display: inline-block;
  background: rgba(0, 0, 0, 0.25);
  color: var(--color-white);
  font-size: 10px;
  font-family: Arial, Helvetica, sans-serif;
  padding: 6px 18px;
  border-radius: 3px;
  letter-spacing: 0.02em;
}

/* ----------------------------------------------------------
   Quote — right-hand column text
   ---------------------------------------------------------- */
.index-quote {
  position: absolute;
  right: 4%;
  top: 50%;
  transform: translateY(-50%);
  width: 20%;
  z-index: 10;
  font-size: 1.9vh;
  line-height: 1.5;
  color: var(--color-white);
  font-family: Arial, Helvetica, sans-serif;
}

.index-quote-lead {
  color: var(--color-orange);
  font-weight: normal;
}

.index-quote sup {
  font-size: 0.65em;
  vertical-align: super;
}
