/* ==== GIIAS 2026 — Countdown ==== */
.gi-page {
  --gi-gold: #ba9456;
  --gi-blue: #70b8ff;
  background: #000;
  color: #fff;
  font-family: 'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  overflow: hidden;
}
.gi-page *,
.gi-page *::before,
.gi-page *::after { box-sizing: border-box; }

/* ---- Key visual (top banner) ---- */
.gi-kv {
  position: relative;
  display: block;
  line-height: 0;
}
.gi-kv__img {
  display: block;
  width: 100%;
  height: auto;
}
/* STAY TUNED button overlaid on the KV (bottom-center) */
.gi-kv__cta {
  position: absolute;
  left: 50%;
  bottom: clamp(36px, 9%, 120px);
  transform: translateX(-50%);
  z-index: 2;
  line-height: normal;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: clamp(13px, 1.15vw, 19px) clamp(42px, 4.4vw, 72px);
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(6,7,9,.82), rgba(6,7,9,.82)) padding-box,
    linear-gradient(180deg, #f2dfb0 0%, #c39e60 46%, #6f5631 100%) border-box;
  box-shadow:
    0 0 24px 2px rgba(186,148,86,.22),
    inset 0 1px 8px rgba(242,223,176,.12);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  text-decoration: none;
  cursor: pointer;
  transition: box-shadow .3s ease, transform .3s ease, filter .3s ease;
}
.gi-kv__cta-text {
  font-family: 'Outfit', sans-serif;
  font-weight: 500;
  font-size: clamp(13px, 1.05vw, 18px);
  letter-spacing: .38em;
  text-indent: .38em;
  text-transform: uppercase;
  background: linear-gradient(180deg, #f7e8c0 0%, #e2c789 50%, #b08f54 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.gi-kv__cta:hover {
  transform: translateX(-50%) translateY(-2px);
  filter: brightness(1.08);
  box-shadow:
    0 6px 30px 4px rgba(186,148,86,.4),
    inset 0 1px 10px rgba(242,223,176,.2);
}
.gi-kv__cta:active { transform: translateX(-50%) translateY(0); }

/* ---- Section ---- */
.gi-countdown {
  position: relative;
  overflow: hidden;
}
/* full-bleed background image — section height follows the image */
.gi-countdown__bg {
  display: block;
  width: 100%;
  height: auto;
}
/* blue radial glow behind content */
.gi-countdown__glow {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 1100px;
  height: 600px;
  max-width: 120%;
  border-radius: 50%;
  background: radial-gradient(ellipse 50% 50% at 50% 50%, rgba(7,61,124,.5) 0%, rgba(2,14,41,.25) 45%, transparent 72%);
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
}

/* ---- Content overlay (absolute over the image) ---- */
.gi-countdown__inner {
  position: absolute;
  inset: 0;
  z-index: 1;
  top: -66px;
}

/* headline group sits just above the glow line (image vertical center) */
.gi-countdown__head {
  position: absolute;
  left: 50%;
  bottom: 50.5%;
  transform: translateX(-50%);
  width: 100%;
  padding: 0 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(10px, 1.4vw, 22px);
}
/* date + timer group sits below the glow line */
.gi-countdown__foot {
  position: absolute;
  left: 50%;
  top: 60%;
  transform: translateX(-50%);
  width: 100%;
  padding: 0 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(22px, 3.4vw, 56px);
}

/* ---- Label ---- */
.gi-countdown__label {
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  font-size: clamp(12px, 1.15vw, 19px);
  letter-spacing: .5em;
  text-indent: .5em;
  color: #fff;
  text-transform: uppercase;
  margin: 0;
}

/* ---- Title ---- */
.gi-countdown__title {
  font-family: 'Outfit', sans-serif;
  font-weight: 200;
  font-size: clamp(44px, 3.4vw, 110px);
  line-height: 1;
  letter-spacing: .22em;
  text-indent: .22em;
  color: #cdd2d8;          /* flat silver */
  text-transform: uppercase;
  margin: 0;
}
/* the emphasized word — heavy weight + metallic gradient (gradient set below) */
.gi-countdown__title-bold,
.gi-countdown__subtitle-bold {
  font-weight: 900;
}

/* ---- Subtitle (same size as the label) ---- */
.gi-countdown__subtitle {
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  font-size: clamp(12px, 1.15vw, 19px);
  letter-spacing: .04em;
  color: #cdd2d8;          /* flat silver */
  margin: 0;
}

/* ---- Date row (line — text — line) ---- */
.gi-countdown__date-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(14px, 1.8vw, 30px);
}
.gi-countdown__date-line {
  width: clamp(70px, 11vw, 240px);
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.6));
}
.gi-countdown__date-row .gi-countdown__date-line:last-child {
  background: linear-gradient(90deg, rgba(255,255,255,.6), rgba(255,255,255,0));
}
.gi-countdown__date {
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  font-size: clamp(13px, 1.35vw, 22px);
  letter-spacing: .32em;
  text-indent: .32em;
  color: #fff;
  margin: 0;
  white-space: nowrap;
}

/* ---- Timer ---- */
.gi-countdown__timer {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: clamp(16px, 2.6vw, 48px);
}
.gi-countdown__unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(6px, 0.8vw, 14px);
}
.gi-countdown__num {
  font-family: 'Outfit', sans-serif;
  font-weight: 200;
  font-size: clamp(40px, 5.4vw, 92px);
  line-height: 1;
  letter-spacing: .06em;
  color: #fff;
  font-variant-numeric: tabular-nums;
  display: inline-block;
}
.gi-countdown__cap {
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  font-size: clamp(9px, 0.85vw, 13px);
  letter-spacing: .28em;
  text-indent: .28em;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
}
/* thin vertical divider between units — matches number height */
.gi-countdown__divider {
  flex-shrink: 0;
  width: 1px;
  height: clamp(40px, 5.4vw, 92px);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.4) 50%, rgba(255,255,255,.04));
}

/* ---- Done state ---- */
.gi-countdown__done {
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  font-size: clamp(22px, 3vw, 44px);
  letter-spacing: .18em;
  text-indent: .18em;
  color: #fff;
  text-transform: uppercase;
  margin: 0;
}

/* ---- Chrome / silver metallic text (with a subtle dark band) ---- */
.gi-countdown__num,
.gi-countdown__done,
.gi-countdown__title-bold,
.gi-countdown__subtitle-bold {
  background: linear-gradient(
    180deg,
    #ffffff 0%,
    #e6eaee 16%,
    #aab1b8 38%,
    #565b61 52%,   /* slight black gradation */
    #9aa1a8 60%,
    #e9edf0 82%,
    #ffffff 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.45));
}
/* labels/caps: dimmer silver to keep hierarchy */
.gi-countdown__cap {
  background: linear-gradient(180deg, #d2d6da 0%, #8d939a 55%, #c3c8cd 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ---- Entrance initial states (Motion animates to visible) ---- */
.gi-countdown__label,
.gi-countdown__title,
.gi-countdown__subtitle,
.gi-countdown__date-row,
.gi-countdown__unit { opacity: 0; }

@media (prefers-reduced-motion: reduce) {
  .gi-countdown__label,
  .gi-countdown__title,
  .gi-countdown__subtitle,
  .gi-countdown__date-row,
  .gi-countdown__unit { opacity: 1; }
}

/* ============================================================
   INFO SECTION — Join us at GIIAS 2026
   ============================================================ */
.gi-info {
  position: relative;
  overflow: hidden;
}
/* full-bleed background image — section height follows the image */
.gi-info__bg {
  display: block;
  width: 100%;
  height: auto;
}
.gi-info__inner {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 5% 24px 4%;
  gap: clamp(12px, 1.5vw, 24px);
}

/* ---- Label ---- */
.gi-info__label {
  font-family: 'Outfit', sans-serif;
  font-weight: 500;
  font-size: clamp(11px, 1.05vw, 17px);
  letter-spacing: .5em;
  text-indent: .5em;
  color: var(--gi-blue);
  text-transform: uppercase;
  margin: 0;
}

/* ---- Title ---- */
.gi-info__title {
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  font-size: clamp(36px, 5vw, 86px);
  line-height: 1;
  letter-spacing: .12em;
  text-indent: .12em;
  color: #fff;
  text-transform: uppercase;
  margin: 0;
}
.gi-info__title-grad {
  background: linear-gradient(181.5deg, #70b8ff 6%, #ffffff 104%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ---- Separator ---- */
.gi-info__sep {
  width: clamp(44px, 4vw, 70px);
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(112,184,255,0), #cbddfa 50%, rgba(112,184,255,0));
  box-shadow: 0 0 14px 1px rgba(112,184,255,.7);
}

/* ---- Tagline ---- */
.gi-info__tagline {
  font-family: 'Hanken Grotesk', sans-serif;
  font-weight: 400;
  font-style: italic;
  font-size: clamp(15px, 1.3vw, 20px);
  line-height: 1.6;
  letter-spacing: .01em;
  color: rgba(255,255,255,.9);
  margin: 0;
}

/* ---- Meta row (date | place | hall) ---- */
.gi-info__meta {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: clamp(14px, 1.8vw, 28px);
  margin-top: clamp(14px, 2.2vw, 40px);
}
.gi-info__meta-item {
  display: inline-flex;
  align-items: center;
  gap: clamp(7px, 0.7vw, 12px);
  font-family: 'Hanken Grotesk', sans-serif;
  font-weight: 500;
  font-size: clamp(13px, 1.05vw, 17px);
  letter-spacing: .02em;
  color: #fff;
  white-space: nowrap;
}
.gi-info__icon {
  flex-shrink: 0;
  display: inline-flex;
  color: var(--gi-blue);
}
.gi-info__icon svg {
  width: clamp(20px, 1.7vw, 26px);
  height: clamp(20px, 1.7vw, 26px);
  display: block;
}
.gi-info__meta-div {
  width: 1px;
  height: clamp(14px, 1.3vw, 20px);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.45) 50%, rgba(255,255,255,.05));
}

/* ---- Entrance initial states ---- */
.gi-info__label,
.gi-info__title,
.gi-info__sep,
.gi-info__tagline,
.gi-info__meta-item { opacity: 0; }

@media (prefers-reduced-motion: reduce) {
  .gi-info__label,
  .gi-info__title,
  .gi-info__sep,
  .gi-info__tagline,
  .gi-info__meta-item { opacity: 1; }
}

/* ---- Responsive ---- */
@media (max-width: 600px) {
  .gi-countdown__title { letter-spacing: .14em; text-indent: .14em; }
  .gi-countdown__head { bottom: 51%; }
  .gi-countdown__foot { top: 55%; gap: clamp(16px, 4vw, 32px); }

  .gi-info__inner { gap: clamp(10px, 3vw, 18px); padding: 7% 18px; }
  .gi-info__meta { gap: 8px 14px; }
  .gi-info__meta-div { display: none; }
  .gi-info__meta-item { flex-basis: 100%; text-align: center; }
}

/* ============================================================
   FOOTER (mirrors catch-the-code footer)
   ============================================================ */
.gi-footer {
  background: #181815;
  padding: 20px 100px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.gi-footer__copy {
  font-family: 'Outfit', sans-serif;
  font-size: 12px;
  letter-spacing: 0.12em;
  color: #fff;
  margin: 0;
}
.gi-footer__privacy {
  font-family: 'Outfit', sans-serif;
  font-size: 12px;
  letter-spacing: 0.167em;
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 3px;
  white-space: nowrap;
}
.gi-footer__privacy:hover { opacity: .75; }

@media (max-width: 800px) {
  .gi-footer { padding: 16px 24px; flex-direction: column; gap: 8px; text-align: center; }
}
