/* ===================== MIST 2026 — styles ===================== */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: #07151a;
  color: #eef5f6;
  font-family: 'Saira', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
::selection { background: #79c7cf; color: #07151a; }
img { display: block; }

/* ---------- keyframes ---------- */
@keyframes mistMarquee { from { transform: translateX(0) } to { transform: translateX(-50%) } }
@keyframes mistSpin { to { transform: rotate(360deg) } }
@keyframes mistFogA { 0% { transform: translate3d(0,0,0) } 100% { transform: translate3d(-22%,-3%,0) } }
@keyframes mistFogB { 0% { transform: translate3d(-18%,0,0) } 100% { transform: translate3d(4%,4%,0) } }
@keyframes mistFloat { 0%,100% { transform: translateY(0) } 50% { transform: translateY(-16px) } }
@keyframes mistSlogan { from { opacity: 0; transform: translateY(14px); filter: blur(6px) } to { opacity: 1; transform: none; filter: none } }
@keyframes mistGlow {
  0%,100% { box-shadow: 0 10px 36px rgba(121,199,207,.32), 0 0 0 1px rgba(191,233,236,.25) inset }
  50%     { box-shadow: 0 10px 54px rgba(121,199,207,.6),  0 0 0 1px rgba(191,233,236,.5) inset }
}
@keyframes mistEnter { from { opacity: 0; transform: translateY(28px) } to { opacity: 1; transform: none } }

/* ---------- layout root ---------- */
.page {
  position: relative;
  min-height: 100vh;
  background: radial-gradient(130% 90% at 50% -10%, #123640 0%, #0c2630 38%, #07151a 78%);
}

.reveal { animation: mistEnter .9s cubic-bezier(.2,.7,.2,1) both; }

/* ---------- fog ---------- */
.fog { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.fog-a {
  position: absolute; top: 0; left: -30%; width: 160%; height: 100%;
  mix-blend-mode: screen; opacity: .38;
  animation: mistFogA 34s ease-in-out infinite alternate;
}
.fog-b {
  position: absolute; top: -10%; left: -30%; width: 170%; height: 120%;
  mix-blend-mode: screen; opacity: .22;
  animation: mistFogB 48s ease-in-out infinite alternate;
}

/* ---------- shared kicker / headings ---------- */
.kicker {
  font-family: 'Saira Condensed', sans-serif;
  font-size: clamp(12px,1.5vw,14px); font-weight: 600;
  letter-spacing: .3em; text-transform: uppercase; color: #79c7cf;
  margin-bottom: 16px;
}
.h2-grad {
  margin: 0; font-family: 'Unbounded', sans-serif; font-weight: 800;
  line-height: 1.04; letter-spacing: -.01em;
  background: linear-gradient(160deg,#f2f9fa 0%,#bcd9de 60%,#6d97a0 115%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.h2-plain {
  margin: 0; font-family: 'Unbounded', sans-serif; font-weight: 800;
  line-height: 1.04; letter-spacing: -.01em; color: #eef5f6;
}
.hl-1 { color: #cfeef0; }
.hl-2 { color: #9fc3cb; }
.hl-3 { color: #79c7cf; }

/* ---------- buttons ---------- */
.btn-primary {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 34px; border-radius: 999px;
  background: linear-gradient(100deg,#cfeef0,#79c7cf);
  color: #07151a; font-family: 'Saira Condensed', sans-serif;
  font-weight: 700; font-size: clamp(15px,1.8vw,18px);
  letter-spacing: .06em; text-transform: uppercase; text-decoration: none;
  animation: mistGlow 3.6s ease-in-out infinite;
  transition: transform .25s ease;
}
.btn-primary:hover { transform: translateY(-3px) scale(1.03); }
.btn-primary .arrow { font-size: 1.05em; }
.btn-primary-lg {
  margin-top: clamp(26px,4vw,36px);
  padding: 18px 42px; font-size: clamp(16px,2vw,19px); letter-spacing: .08em;
}
.btn-secondary {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 30px; border-radius: 999px;
  background: rgba(180,210,216,.05); border: 1px solid rgba(180,210,216,.28);
  color: #eef5f6; font-family: 'Saira Condensed', sans-serif;
  font-weight: 600; font-size: clamp(15px,1.8vw,18px);
  letter-spacing: .06em; text-transform: uppercase; text-decoration: none;
  transition: border-color .25s, background .25s;
}
.btn-secondary:hover { border-color: #79c7cf; background: rgba(121,199,207,.1); }

/* ===================== HERO ===================== */
.hero {
  position: relative; z-index: 2; min-height: 100svh;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  text-align: center;
  padding: clamp(64px,8vw,88px) clamp(20px,5vw,64px) clamp(128px,16vw,160px);
  overflow: hidden;
}
/* Десктоп: верхній блок Hero максимально вгору (на мобільному — без змін) */
@media (min-width: 768px) {
  .hero-content { justify-content: flex-start; }
  .hero { padding-top: clamp(16px,2vw,24px); }
  .hero-cta { margin-top: auto; }
  /* центр відео трохи нижче центру (тільки на ПК) */
  .hero-video { object-position: center 46%; }
}
.hero-bg { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-bg-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(7,21,26,.2) 0%, rgba(7,21,26,.55) 60%, #07151a 100%);
}
.slot-badge {
  position: absolute; left: 50%; top: clamp(22px,5vw,40px); transform: translateX(-50%);
  display: flex; align-items: center; gap: 9px; padding: 8px 15px;
  border: 1px dashed rgba(180,210,216,.3); border-radius: 999px;
  font-family: 'Saira Condensed', sans-serif; font-size: 11px; letter-spacing: .24em;
  text-transform: uppercase; color: rgba(220,238,240,.6);
  background: rgba(7,21,26,.4); backdrop-filter: blur(4px);
}
.slot-badge-play {
  display: inline-flex; width: 16px; height: 16px; border-radius: 50%;
  background: #79c7cf; align-items: center; justify-content: center;
}
.slot-badge-play span {
  border-style: solid; border-width: 3.5px 0 3.5px 6px;
  border-color: transparent transparent transparent #07151a; margin-left: 2px;
}

.hero-content {
  position: relative; z-index: 3;
  display: flex; flex-direction: column; align-items: center;
  justify-content: space-between;
  flex: 1; gap: clamp(24px,5vw,48px); width: 100%; max-width: 1180px;
}
.hero-top {
  display: flex; flex-direction: column; align-items: center;
  gap: clamp(14px,2.4vw,26px);
}
.kicker-line {
  display: flex; align-items: center; gap: 13px;
  font-family: 'Saira Condensed', sans-serif; font-size: clamp(11px,1.5vw,14px);
  font-weight: 600; letter-spacing: .34em; text-transform: uppercase; color: #9fc3cb;
}
.kicker-line .line { width: 26px; height: 1px; background: #79c7cf; }

.wordmark {
  margin: 0; font-family: 'Titan One', cursive; font-weight: 400;
  line-height: .86; letter-spacing: .01em; font-size: clamp(78px,21vw,260px);
  background: linear-gradient(180deg,#f2f9fa 0%,#bcd9de 52%,#7ba2ab 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 70px rgba(121,199,207,.28);
}

.hero-banner {
  display: flex; align-items: center; justify-content: center;
  gap: clamp(18px,5vw,64px); flex-wrap: wrap; margin-top: clamp(2px,1vw,8px);
}
.hero-meta { text-align: center; min-width: 96px; }
.hero-meta-big {
  font-family: 'Saira Condensed', sans-serif; font-weight: 700;
  font-size: clamp(28px,5vw,54px); line-height: .95; color: #eef5f6;
}
.hero-meta-sub {
  font-family: 'Saira Condensed', sans-serif; font-weight: 600;
  font-size: clamp(13px,1.8vw,18px); letter-spacing: .28em;
  text-transform: uppercase; color: #9fc3cb; margin-top: 3px;
}
.hero-logo {
  position: relative; width: clamp(190px,40vw,360px); height: clamp(190px,40vw,360px); flex: none;
}
.hero-logo-halo {
  position: absolute; inset: -18%; border-radius: 50%;
  background: radial-gradient(circle, rgba(150,195,203,.5) 0%, rgba(150,195,203,0) 66%);
  filter: blur(12px); animation: mistFloat 9s ease-in-out infinite;
}
.hero-logo-img {
  position: relative; width: 100%; height: 100%; object-fit: cover; border-radius: 50%;
  animation: mistSpin 70s linear infinite; opacity: .96;
  filter: drop-shadow(0 0 30px rgba(121,199,207,.35));
}

.slogan {
  margin: clamp(8px,2vw,18px) 0 0; min-height: clamp(48px,7vw,76px);
  max-width: 720px; font-size: clamp(17px,2.5vw,28px); font-weight: 500;
  line-height: 1.34; color: #e7f1f2;
  animation: mistSlogan .7s cubic-bezier(.2,.7,.2,1) both; text-wrap: balance;
}
.hero-cta {
  display: flex; flex-wrap: wrap; gap: 14px; justify-content: center;
  margin-top: clamp(8px,1.6vw,16px);
}

/* ===================== MARQUEE ===================== */
.marquee {
  position: relative; z-index: 2; overflow: hidden; background: #0a1f26;
  border-top: 1px solid rgba(180,210,216,.12); border-bottom: 1px solid rgba(180,210,216,.12);
}
.perforation {
  height: 9px;
  background: repeating-linear-gradient(90deg, transparent 0 10px, rgba(180,210,216,.16) 10px 20px);
}
.marquee-track-wrap { overflow: hidden; padding: clamp(13px,1.8vw,18px) 0; }
.marquee-track {
  display: flex; width: max-content; white-space: nowrap;
  animation: mistMarquee 30s linear infinite;
  font-family: 'Unbounded', sans-serif; font-weight: 700; font-size: clamp(16px,2.6vw,28px);
  color: transparent; -webkit-text-stroke: 1px rgba(180,210,216,.4);
}
.marquee-track span { padding: 0 26px; }

/* ===================== ABOUT ===================== */
.about {
  position: relative; z-index: 2; max-width: 1180px; margin: 0 auto;
  padding: clamp(90px,13vw,170px) clamp(20px,5vw,64px);
}
.about-head .h2-grad { font-size: clamp(46px,11vw,140px); }
.about-lead {
  max-width: 760px; margin: clamp(24px,3vw,38px) 0 0;
  font-size: clamp(17px,2.3vw,25px); line-height: 1.55; color: #d4e4e6; text-wrap: pretty;
}
.about-bullets {
  list-style: none; margin: clamp(30px,4vw,48px) 0 0; padding: 0;
  max-width: 880px; display: grid; gap: clamp(22px,3vw,34px);
}
.about-bullets li {
  padding-left: clamp(16px,2vw,22px);
  border-left: 2px solid rgba(121,199,207,.5);
}
.bullet-title {
  display: block;
  font-family: 'Unbounded', sans-serif; font-weight: 800; letter-spacing: -.01em;
  font-size: clamp(24px,4vw,44px); line-height: 1.05; color: #eef5f6;
}
.bullet-desc {
  display: block; margin-top: clamp(7px,1vw,11px);
  font-size: clamp(15px,1.9vw,18px); line-height: 1.5; color: #aec6ca;
  max-width: 56ch; text-wrap: pretty;
}
.feature-grid {
  margin-top: clamp(40px,6vw,72px); display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,300px),1fr));
  gap: clamp(14px,2vw,22px);
}
.feature-card {
  padding: clamp(22px,2.6vw,30px); border-radius: 18px;
  background: linear-gradient(165deg,rgba(146,185,193,.08),rgba(146,185,193,.02));
  border: 1px solid rgba(180,210,216,.14);
  transition: border-color .3s, transform .3s;
}
.feature-card:hover { border-color: rgba(121,199,207,.55); transform: translateY(-4px); }
.feature-num { font-family: 'Titan One', cursive; font-size: clamp(22px,2.6vw,30px); color: rgba(121,199,207,.55); }
.feature-title {
  font-family: 'Saira Condensed', sans-serif; font-weight: 700;
  font-size: clamp(18px,2.3vw,24px); text-transform: uppercase; letter-spacing: .02em;
  margin: 10px 0 8px; color: #eef5f6;
}
.feature-desc { font-size: clamp(15px,1.8vw,17px); line-height: 1.5; color: #aec6ca; }

/* ===================== GALLERY ===================== */
.gallery {
  position: relative; z-index: 2; max-width: 1280px; margin: 0 auto;
  padding: 0 clamp(20px,5vw,64px) clamp(16px,3vw,40px);
}
.gallery-inner { display: flex; flex-direction: column; gap: 13px; }
.gallery-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,260px),1fr)); gap: 13px; }
.media-slot {
  position: relative; border-radius: 14px; overflow: hidden;
  background: linear-gradient(135deg,#0e2a32,#091a20);
  border: 1px solid rgba(180,210,216,.14);
  display: flex; align-items: center; justify-content: center;
}
.media-slot-wide { width: 100%; aspect-ratio: 21/8; }
.media-slot-photo { aspect-ratio: 4/5; }
.media-slot-video { aspect-ratio: 9/16; }
.media-slot-label {
  font-family: 'Saira Condensed', sans-serif; font-size: 12px; letter-spacing: .14em;
  text-transform: uppercase; color: rgba(220,238,240,.42); text-align: center; padding: 12px;
}
.media-slot img, .media-slot video { width: 100%; height: 100%; object-fit: cover; }

/* ===================== LINEUP ===================== */
.lineup {
  position: relative; z-index: 2; max-width: 1180px; margin: 0 auto;
  padding: clamp(80px,12vw,150px) clamp(20px,5vw,64px);
}
.lineup-head { text-align: center; margin-bottom: clamp(32px,5vw,52px); }
.lineup-head .kicker { margin-bottom: 14px; }
.lineup-head .h2-plain { font-size: clamp(40px,8vw,104px); }

.day-tabs { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: clamp(34px,5vw,56px); }
.day-tab {
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
  padding: 15px 28px; border-radius: 16px;
  border: 1px solid rgba(180,210,216,.16); background: rgba(180,210,216,.03);
  color: rgba(220,238,240,.55); cursor: pointer;
  transition: color .25s, border-color .25s, background .25s, box-shadow .25s;
}
.day-tab:hover { color: #eef5f6; border-color: rgba(180,210,216,.45); }
.day-tab.is-active {
  border-color: #79c7cf; background: rgba(121,199,207,.14);
  color: #eef5f6; box-shadow: 0 0 28px rgba(121,199,207,.22);
}
.day-tab-num {
  font-family: 'Saira Condensed', sans-serif; font-size: 10px; font-weight: 600;
  letter-spacing: .24em; text-transform: uppercase; opacity: .65;
}
.day-tab-date { font-family: 'Saira Condensed', sans-serif; font-weight: 700; font-size: clamp(16px,2vw,20px); }

.day-content {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,330px),1fr));
  gap: clamp(28px,5vw,60px); align-items: start;
}
.day-left-head { display: flex; align-items: center; gap: 16px; }
.day-emblem { flex: none; }
.day-datenum {
  font-family: 'Titan One', cursive; font-size: clamp(40px,9vw,80px);
  line-height: .9; color: #eef5f6; text-shadow: 0 0 40px rgba(121,199,207,.28);
}
.day-title {
  font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase;
  letter-spacing: .01em; font-size: clamp(22px,3.6vw,38px); margin-top: 14px;
  color: #cfeef0; text-wrap: balance;
}
.day-desc {
  margin: clamp(16px,2.4vw,24px) 0 0; font-size: clamp(15px,1.9vw,19px);
  line-height: 1.6; color: #bcd2d6; max-width: 46ch; text-wrap: pretty;
}
.day-groups { display: flex; flex-direction: column; gap: clamp(22px,3vw,32px); }
.group-head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.group-dot { width: 7px; height: 7px; border-radius: 50%; background: #79c7cf; box-shadow: 0 0 12px #79c7cf; }
.group-name {
  font-family: 'Saira Condensed', sans-serif; font-weight: 700; font-size: clamp(13px,1.7vw,17px);
  letter-spacing: .16em; text-transform: uppercase; color: #79c7cf;
}
.group-line { flex: 1; height: 1px; background: rgba(180,210,216,.14); }
.chips { display: flex; flex-wrap: wrap; gap: 8px 10px; }
.chip {
  font-family: 'Saira Condensed', sans-serif; font-weight: 600; font-size: clamp(15px,1.9vw,20px);
  text-transform: uppercase; letter-spacing: .02em; color: #e7f1f2;
  padding: 6px 13px; border-radius: 9px;
  background: rgba(146,185,193,.06); border: 1px solid rgba(180,210,216,.1);
  transition: border-color .2s, color .2s, transform .2s;
}
.chip:hover { border-color: #79c7cf; color: #cfeef0; transform: translateY(-2px); }
.chip-more {
  font-family: 'Saira Condensed', sans-serif; font-size: clamp(13px,1.6vw,16px);
  letter-spacing: .06em; text-transform: uppercase; color: rgba(220,238,240,.4);
  align-self: center; padding-left: 4px;
}

/* ===================== TICKETS / FOMO ===================== */
.tickets {
  position: relative; z-index: 2;
  padding: clamp(20px,4vw,48px) clamp(20px,5vw,64px) clamp(60px,9vw,110px);
}
.tickets-card {
  max-width: 1080px; margin: 0 auto; position: relative; overflow: hidden;
  border-radius: clamp(20px,3vw,32px); border: 1px solid rgba(180,210,216,.18);
  background: radial-gradient(120% 120% at 80% -10%, #14333d 0%, #0a1f26 55%, #081a20 100%);
  padding: clamp(40px,6vw,80px) clamp(24px,5vw,72px);
}
.tickets-logo {
  position: absolute; right: -8%; bottom: -30%; width: 46%; max-width: 420px;
  aspect-ratio: 1; opacity: .12; animation: mistSpin 90s linear infinite;
}
.tickets-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.tickets-body { position: relative; z-index: 2; max-width: 680px; }
.tickets-h2 { font-size: clamp(34px,6vw,68px); line-height: .96; text-wrap: balance; }
.tickets-sub {
  margin: 18px 0 clamp(28px,4vw,40px); font-size: clamp(16px,2.1vw,22px);
  line-height: 1.45; color: #c4dadd; max-width: 48ch; text-wrap: pretty;
}
.price-note {
  margin-bottom: clamp(28px,4vw,40px); font-size: clamp(14px,1.7vw,16px);
  line-height: 1.5; color: #aec6ca;
}

/* ===================== FOOTER ===================== */
.footer {
  position: relative; z-index: 2; border-top: 1px solid rgba(180,210,216,.12);
  background: linear-gradient(180deg,rgba(7,21,26,0),#061216 45%);
}
.footer-inner {
  max-width: 1080px; margin: 0 auto; text-align: center;
  padding: clamp(80px,12vw,150px) clamp(20px,5vw,64px) clamp(42px,5vw,64px);
}
.footer-logo {
  width: clamp(72px,10vw,108px); height: clamp(72px,10vw,108px); object-fit: cover;
  border-radius: 50%; opacity: .95; margin: 0 auto clamp(20px,3vw,30px);
  filter: drop-shadow(0 0 22px rgba(121,199,207,.3));
}
.footer-h2 {
  font-size: clamp(30px,5.5vw,66px); line-height: 1;
  background: linear-gradient(120deg,#f2f9fa,#bcd9de 60%,#79c7cf);
  -webkit-background-clip: text; background-clip: text; color: transparent; text-wrap: balance;
}
.footer-socials { display: flex; justify-content: center; gap: 16px; margin-top: clamp(30px,5vw,44px); }
.social-btn {
  display: inline-flex; align-items: center; gap: 10px; padding: 14px 24px;
  border-radius: 14px; border: 1px solid rgba(180,210,216,.18); background: rgba(146,185,193,.04);
  color: #eef5f6; font-family: 'Saira Condensed', sans-serif; font-weight: 600; font-size: 15px;
  letter-spacing: .1em; text-transform: uppercase; text-decoration: none;
  transition: transform .25s, border-color .25s, color .25s;
}
.social-btn:hover { transform: translateY(-3px); border-color: #79c7cf; color: #cfeef0; }
.footer-bottom {
  margin-top: clamp(44px,6vw,64px); padding-top: 26px;
  border-top: 1px solid rgba(180,210,216,.1);
  display: flex; flex-wrap: wrap; gap: 14px 28px; justify-content: center; align-items: center;
  font-family: 'Saira Condensed', sans-serif; font-size: 14px; letter-spacing: .06em;
  text-transform: uppercase; color: rgba(220,238,240,.5);
}
.footer-brand { color: rgba(220,238,240,.82); font-weight: 700; }
.footer-link { color: rgba(220,238,240,.5); text-decoration: none; transition: color .2s; }
.footer-link:hover { color: #cfeef0; }

/* ===================== FLOATING SOCIALS ===================== */
.float-socials {
  position: fixed; right: clamp(12px,2vw,22px); top: 50%; transform: translateY(-50%);
  z-index: 40; display: flex; flex-direction: column; gap: 12px;
}
.float-social {
  display: inline-flex; align-items: center; justify-content: center;
  width: 61px; height: 61px; border-radius: 16px;
  background: rgba(8,22,28,.72); backdrop-filter: blur(8px);
  border: 1px solid rgba(180,210,216,.18); color: #eef5f6;
  transition: transform .25s, color .25s, border-color .25s;
}
.float-social svg { width: 27px; height: 27px; }
.float-social:hover { transform: scale(1.1); color: #79c7cf; border-color: #79c7cf; }

/* ===================== STICKY BUY ===================== */
.sticky-buy {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 45;
  display: flex; justify-content: center; padding: 0 0 clamp(14px,2vw,22px);
  pointer-events: none;
}
.sticky-buy-btn {
  pointer-events: auto; padding: 15px clamp(28px,5vw,44px);
  background: linear-gradient(100deg,#dff4f5,#79c7cf);
  box-shadow: 0 12px 40px rgba(121,199,207,.5), 0 0 0 1px rgba(255,255,255,.2) inset;
}
.sticky-dot { display: inline-flex; width: 8px; height: 8px; border-radius: 50%; background: #07151a; }

/* ===================== REDUCED MOTION ===================== */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; }
  .fog { display: none; }
}
