/* ============================================================
   PRORESTO — стилі лендингу
   Стек: чистий HTML/CSS/JS (як lipshe.site)
   ============================================================ */

/* ===== TOKENS ===== */
:root{
  /* палітра — стримана редакційна гастро-тема */
  --bg:#15120E;            /* теплий чорнильний — основний фон */
  --bg-2:#1C1813;          /* секції-чергування */
  --bg-3:#221D17;          /* картки */
  --line:#332C24;          /* розділювачі / бордери */

  --cream:#ECE4D6;         /* основний текст (кістка) */
  --muted:#9E9484;         /* приглушений текст */
  --muted-2:#6F6657;       /* дрібний текст / мета */

  /* СЕЗОННИЙ АКЦЕНТ — змінюється раз на сезон в одному місці.
     Поточний сезон: помаранчевий бренд-колір PRORESTO. */
  --accent:#FD8000;        /* фірмовий помаранчевий #FD8000 */
  --accent-soft:#FF9526;   /* hover */
  --accent-2:#651C85;      /* фірмовий фіолетовий (другий бренд-колір) */
  --gold:#C9A24B;          /* золото (сезонна альтернатива) */
  --lime:#C2EA4B;          /* салатовий — графічний акцент (квадратні дужки) */

  /* аліаси для зворотної сумісності зі стилями нижче */
  --clay:var(--accent);
  --clay-soft:var(--accent-soft);

  --max:1160px;
  --pad:48px;

  --font-text:'Onest',system-ui,sans-serif;
  --font-display:'Unbounded','Onest',sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-text);
  background:var(--bg);
  color:var(--cream);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

::selection{background:var(--clay);color:#fff;}

.accent{color:var(--clay);}

/* ===== SCROLL REVEAL ===== */
.reveal{
  opacity:0;transform:translateY(26px);
  transition:opacity .7s cubic-bezier(.2,.6,.2,1), transform .7s cubic-bezier(.2,.6,.2,1);
  will-change:opacity,transform;
}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none;}
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:600;font-size:15px;letter-spacing:0.01em;
  padding:16px 34px;border-radius:100px;position:relative;
  transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s;
  cursor:pointer;border:1.5px solid transparent;white-space:nowrap;
}

/* бігучий вогник по контуру кнопки (як іскра по шнуру) */
@property --beam{syntax:"<angle>";inherits:false;initial-value:0deg;}
.btn::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  padding:1.6px;
  background:conic-gradient(from var(--beam),
    rgba(44,196,180,0) 235deg,
    rgba(44,196,180,.32) 312deg,
    rgba(140,240,225,.7) 350deg,
    rgba(44,196,180,0) 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask-composite:exclude;
  filter:blur(1px);opacity:.8;
  animation:beamRun 4.2s linear infinite;
}
@keyframes beamRun{to{--beam:360deg;}}
/* розкид фази, щоб іскри на різних кнопках не співпадали */
.btn-ghost::before{animation-delay:-1.4s;}
.btn-primary::before{animation-delay:-2.7s;}
.ticket-btn::before{animation-delay:-0.8s;}
.btn-megogo::before{animation-delay:-3.4s;}
@media (prefers-reduced-motion: reduce){ .btn::before{animation:none;opacity:0;} }
.btn-primary{background:var(--accent);color:#fff;overflow:hidden;}
.btn-primary:hover{background:var(--accent-soft);transform:translateY(-2px);}
/* на заливній кнопці — не іскра по контуру, а глянцевий проблиск */
.btn-primary::before{
  inset:auto;top:-20%;left:-80%;width:55%;height:140%;
  padding:0;border-radius:0;filter:none;
  -webkit-mask:none;mask:none;
  background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.52) 50%,transparent 100%);
  transform:skewX(-16deg);
  animation:btnSweep 4s ease-in-out infinite;
}
@keyframes btnSweep{0%{left:-80%;}55%,100%{left:135%;}}
@media (prefers-reduced-motion: reduce){ .btn-primary::before{animation:none;opacity:0;} }
.btn-ghost{background:transparent;color:var(--cream);border-color:var(--line);}
.btn-ghost:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px);}
.btn-text{
  background:none;border:none;color:var(--cream);padding:15px 8px;
  position:relative;
}
.btn-text:hover{color:var(--clay);}
.btn-lg{font-size:16px;padding:18px 36px;}
.btn-megogo{gap:10px;}
.btn-megogo-logo{height:22px;width:auto;display:inline-block;vertical-align:middle;}
.btn-megogo:hover{background:rgba(44,196,180,.10);border-color:#2CC4B4;color:var(--cream);transform:translateY(-2px);}

/* ===== NAV ===== */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--pad);
  background:rgba(14,14,16,0);
  border-bottom:1px solid transparent;
  transition:background .3s ease, border-color .3s ease, padding .3s ease;
}
#nav.scrolled{
  background:rgba(14,14,16,0.82);
  backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
  padding:14px var(--pad);
}
.nav-logo{display:flex;align-items:center;}
.nav-logo-img{height:30px;width:auto;display:block;transition:height .3s ease;}
#nav.scrolled .nav-logo-img{height:26px;}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--muted);
  letter-spacing:0.01em;transition:color .2s;
}
.nav-links a:hover{color:var(--cream);}
.nav-cta{
  background:transparent;color:var(--cream);border:1.5px solid var(--line);
  padding:10px 24px;border-radius:100px;
  font-size:14px;font-weight:600;transition:background .2s, border-color .2s, color .2s;
}
.nav-cta:hover{background:var(--accent);border-color:var(--accent);color:#fff;}

/* burger */
.nav-burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:30px;height:24px;background:none;border:none;cursor:pointer;z-index:101;
}
.nav-burger span{display:block;height:2px;width:100%;background:var(--cream);border-radius:2px;transition:transform .3s, opacity .3s;}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-menu{
  position:fixed;inset:0;z-index:90;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  opacity:0;visibility:hidden;transition:opacity .32s ease, visibility .32s ease;
}
.mobile-menu.open{opacity:1;visibility:visible;}
.mobile-menu a{
  font-family:var(--font-display);font-weight:500;font-size:clamp(34px,10vw,52px);
  color:var(--cream);padding:6px 0;transition:color .2s;letter-spacing:-0.01em;
}
.mobile-menu a:hover{color:var(--clay);}
.mobile-menu .mobile-menu-cta{
  margin-top:26px;font-family:var(--font-text);font-size:16px;font-weight:600;
  background:var(--accent);color:#fff;padding:16px 40px;border-radius:100px;
}
@media(min-width:901px){ .mobile-menu{display:none;} }

/* ===== HERO ===== */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:160px var(--pad) 64px;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(140% 100% at 100% 0%, rgba(194,105,63,0.10), transparent 60%),
    var(--bg);
}
.hero-mark{
  position:absolute;z-index:0;pointer-events:none;
  right:-3vw;top:0;bottom:0;width:min(48vw,580px);
  display:flex;align-items:center;
  transition:transform .35s ease;
}
.hero-mark-inner{
  width:100%;aspect-ratio:1/1;opacity:0.16;rotate:-4deg;
  background:var(--accent);
  -webkit-mask:url('../assets/img/fork-textured.png') center/contain no-repeat;
          mask:url('../assets/img/fork-textured.png') center/contain no-repeat;
  animation:forkFloat 9s ease-in-out infinite;
}
@keyframes forkFloat{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-16px);}
}
@media (prefers-reduced-motion: reduce){ .hero-mark-inner{animation:none;} }
.hero-inner{position:relative;z-index:1;width:100%;max-width:var(--max);margin:0 auto;}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-text);
  font-size:12px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--muted);margin-bottom:28px;
}
.hero-eyebrow::before{
  content:"[";color:var(--lime);font-weight:700;display:inline-block;
  animation:ebOpenL 1s cubic-bezier(.2,.85,.25,1) .25s both;
}
.hero-eyebrow::after{
  content:"]";color:var(--lime);font-weight:700;display:inline-block;
  animation:ebOpenR 1s cubic-bezier(.2,.85,.25,1) .25s both;
}
.hero-eyebrow .eb-in{
  display:inline-flex;align-items:center;gap:10px;
  opacity:0;filter:blur(3px);
  animation:ebReveal .7s ease .6s forwards;
}
@keyframes ebOpenL{from{transform:translateX(135px);}to{transform:translateX(0);}}
@keyframes ebOpenR{from{transform:translateX(-135px);}to{transform:translateX(0);}}
@keyframes ebReveal{to{opacity:1;filter:blur(0);}}
@media (prefers-reduced-motion: reduce){
  .hero-eyebrow::before,.hero-eyebrow::after{animation:none;}
  .hero-eyebrow .eb-in{opacity:1;filter:none;animation:none;}
}
.hero-eyebrow .dot{
  width:7px;height:7px;border-radius:50%;background:var(--accent);
  animation:dotPulse 2.4s ease-in-out infinite;
}
@keyframes dotPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(253,128,0,.5);}
  70%{box-shadow:0 0 0 9px rgba(253,128,0,0);}
}
@media (prefers-reduced-motion: reduce){ .hero-eyebrow .dot{animation:none;} }

.hero-title{
  font-family:var(--font-display);font-weight:800;text-transform:uppercase;
  font-size:clamp(42px,8.4vw,118px);line-height:0.94;letter-spacing:-0.03em;
  margin-bottom:34px;
}
.hero-title .line{display:block;overflow:hidden;padding-top:.1em;margin-top:-.1em;}
.hero-title .line > span{display:block;transform:translateY(115%);}
.hero-title .accent{color:var(--accent);}
/* послідовний вхід рядків заголовка */
.hero-title .line:nth-child(1) > span{animation:lineUp .85s cubic-bezier(.16,.84,.3,1) .15s forwards;}
.hero-title .line:nth-child(2) > span{animation:lineUp .85s cubic-bezier(.16,.84,.3,1) .27s forwards;}
.hero-title .line:nth-child(3) > span{animation:lineUp .85s cubic-bezier(.16,.84,.3,1) .39s forwards;}
@keyframes lineUp{to{transform:translateY(0);}}
@media (prefers-reduced-motion: reduce){
  .hero-title .line > span{transform:none;animation:none;}
}
.hero-lead{
  max-width:520px;font-size:clamp(16px,2vw,19px);color:var(--muted);
  margin-bottom:42px;line-height:1.6;
}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:80px;}

.hero-meta{
  display:flex;gap:64px;flex-wrap:wrap;
  padding-top:30px;border-top:1px solid var(--line);
}
.hero-meta div{display:flex;flex-direction:column;gap:8px;}
.hero-meta dt{
  font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--muted-2);
}
.hero-meta dd{
  font-size:16px;font-weight:600;color:var(--cream);letter-spacing:0.01em;
}

/* ===== TICKER ===== */
.ticker{
  overflow:hidden;white-space:nowrap;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--accent);
}
.ticker-track{
  display:inline-flex;align-items:center;gap:28px;
  padding:16px 0;
  animation:tickerScroll 28s linear infinite;
}
.ticker-track span{
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:15px;letter-spacing:0.02em;color:#1A1206;
}
.ticker-track i{color:#1A1206;font-style:normal;font-size:13px;opacity:.7;}
@keyframes tickerScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media (prefers-reduced-motion: reduce){ .ticker-track{animation:none;} }

/* ===== SECTIONS (reusable) ===== */
.section{padding:120px var(--pad);}
.section--alt{background:var(--bg-2);}
.container{max-width:var(--max);margin:0 auto;}

.section-head{
  display:flex;align-items:center;gap:14px;margin-bottom:48px;
  font-family:var(--font-text);
}
.section-num{display:none;}
.section-label{
  font-size:12px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--muted);
}
.section-label::before{content:"[";color:var(--lime);font-weight:700;margin-right:9px;}
.section-label::after{content:"]";color:var(--lime);font-weight:700;margin-left:9px;}
.section-title{
  font-family:var(--font-display);font-weight:800;text-transform:uppercase;
  font-size:clamp(30px,4.4vw,58px);line-height:0.98;letter-spacing:-0.02em;
  color:var(--cream);
}

/* WHAT AWAITS — 6 tiles */
.awaits-grid{
  list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  margin-top:52px;background:var(--line);border:1px solid var(--line);border-radius:14px;
  overflow:hidden;
}
.awaits-grid li{
  background:var(--bg);padding:36px 32px;transition:background .25s;
}
.awaits-grid li:hover{background:var(--bg-3);}
.awaits-num{
  font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--accent);
  letter-spacing:0.04em;
}
.awaits-grid h3{
  font-family:var(--font-display);font-weight:700;font-size:20px;text-transform:uppercase;
  letter-spacing:-0.01em;color:var(--cream);margin:14px 0 12px;line-height:1.05;
}
.awaits-grid p{font-size:15px;color:var(--muted);line-height:1.55;}

/* STATS BAND (count-up) */
.stats-band{
  padding:96px var(--pad);background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.stats-band .section-label{display:block;margin-bottom:24px;}
.stats-title{
  font-family:var(--font-display);font-weight:800;text-transform:uppercase;
  font-size:clamp(28px,4vw,52px);line-height:0.98;letter-spacing:-0.02em;
  color:var(--cream);margin-bottom:56px;
}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;}
.stat{border-top:2px solid var(--accent);padding-top:22px;}
.stat-num{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(46px,6vw,80px);line-height:0.95;color:var(--cream);
  display:block;font-variant-numeric:tabular-nums;
}
.stat span{display:block;margin-top:12px;font-size:15px;color:var(--muted);}

/* ABOUT */
.about-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:start;
  padding-bottom:72px;border-bottom:1px solid var(--line);
}
.about-body p{color:var(--muted);font-size:17px;line-height:1.65;margin-bottom:18px;}
.about-body p:last-child{margin-bottom:0;}

.feature-row{
  list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
  margin-top:64px;
}
.feature-row li{border-top:2px solid var(--accent);padding-top:22px;}
.feature-row h3{
  font-family:var(--font-display);font-weight:700;font-size:19px;
  text-transform:uppercase;letter-spacing:-0.01em;margin-bottom:12px;color:var(--cream);
}
.feature-row p{color:var(--muted);font-size:15px;line-height:1.6;}

/* SPEAKERS — slider */
.speakers-top{
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;
  margin-bottom:40px;
}
.slider-nav{display:flex;gap:10px;flex:none;}
.slider-arrow{
  width:52px;height:52px;border-radius:50%;
  border:1.5px solid var(--line);background:transparent;color:var(--cream);
  font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s, border-color .2s, color .2s, opacity .2s;
}
.slider-arrow:hover{background:var(--accent);border-color:var(--accent);color:#fff;}
.slider-arrow:disabled{opacity:.28;cursor:default;}
.slider-arrow:disabled:hover{background:transparent;border-color:var(--line);color:var(--cream);}

.speakers-track{
  display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:6px;scrollbar-width:none;cursor:grab;
}
.speakers-track::-webkit-scrollbar{display:none;}
.speakers-track.dragging{cursor:grabbing;scroll-snap-type:none;}
.speakers-track.dragging a{pointer-events:none;}
.speaker-card{flex:0 0 300px;scroll-snap-align:start;display:flex;flex-direction:column;}

/* SHORTS slider */
.shorts-track{
  display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:6px;scrollbar-width:none;cursor:grab;margin-top:8px;
}
.shorts-track::-webkit-scrollbar{display:none;}
.shorts-track.dragging{cursor:grabbing;scroll-snap-type:none;}
.shorts-track.dragging *{pointer-events:none;}
.short{
  flex:0 0 232px;scroll-snap-align:start;aspect-ratio:9/16;position:relative;
  border:1px solid var(--line);border-radius:14px;overflow:hidden;
  background:var(--bg-3);cursor:pointer;padding:0;display:block;
}
.short-thumb{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .35s ease, opacity .2s;}
.short:hover .short-thumb{transform:scale(1.05);opacity:.85;}
.short-play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:16px;padding-left:3px;transition:transform .2s;
  box-shadow:0 6px 20px rgba(0,0,0,.35);
}
.short:hover .short-play{transform:translate(-50%,-50%) scale(1.1);}
.short iframe{width:100%;height:100%;border:0;display:block;}
.speaker-photo{
  position:relative;aspect-ratio:4/5;border-radius:8px;overflow:hidden;
  background:var(--bg-3);margin-bottom:20px;
  display:flex;align-items:center;justify-content:center;
  background-size:cover;background-position:center;
}
.speaker-photo::after{
  content:attr(data-initials);
  font-family:var(--font-display);font-weight:800;font-size:46px;
  color:var(--line);letter-spacing:0.02em;
}
.speaker-card h3{
  font-family:var(--font-display);font-weight:700;font-size:20px;
  letter-spacing:-0.01em;color:var(--cream);margin-bottom:6px;
}
.speaker-role{font-size:13px;color:var(--accent);margin-bottom:12px;font-weight:600;}
.speaker-topic{font-size:14px;color:var(--muted);line-height:1.5;}

.speaker-card--more{
  background:var(--bg-3);border-radius:8px;
}
.speaker-more{
  flex:1;display:flex;flex-direction:column;justify-content:center;
  padding:32px;gap:6px;
}
.speaker-more-num{
  font-family:var(--font-display);font-weight:800;font-size:56px;
  line-height:1;color:var(--accent);
}
.speaker-more-label{font-size:15px;color:var(--muted);margin-bottom:16px;}
.speaker-more-link{font-weight:600;color:var(--cream);transition:color .2s;}
.speaker-more-link:hover{color:var(--accent);}

.inline-cta{
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  margin-top:40px;padding-top:32px;border-top:1px solid var(--line);
}
.inline-cta p{font-size:clamp(17px,2.2vw,22px);font-weight:600;color:var(--cream);}
.split-btn{margin-top:26px;}

/* MEGOGO block */
.megogo-cta{
  display:inline-flex;align-items:center;gap:14px;margin-top:22px;
  padding:13px 22px;border:1px solid var(--line);border-radius:100px;
  transition:border-color .2s, background .2s;
}
.megogo-cta:hover{border-color:#2CC4B4;background:rgba(44,196,180,.07);}
.megogo-cta-text{font-size:15px;font-weight:600;color:var(--muted);}
.megogo-logo{height:21px;width:auto;display:block;}
.megogo-cta-arrow{color:#2CC4B4;font-size:16px;}

/* MISSION */
.mission{max-width:920px;}
.mission .section-label{display:block;margin-bottom:32px;}
.mission-text{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(26px,3.4vw,46px);line-height:1.18;letter-spacing:-0.01em;
  color:var(--cream);
}

/* AUDIENCE */
.audience-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:56px;align-items:start;}
.audience-list{list-style:none;}
.audience-list li{
  font-family:var(--font-display);font-weight:500;text-transform:uppercase;
  font-size:clamp(20px,2.6vw,30px);letter-spacing:-0.01em;color:var(--cream);
  padding:22px 0;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:18px;transition:color .2s, padding-left .2s;
}
.audience-list li::before{
  content:"";width:9px;height:9px;border-radius:50%;background:var(--accent);
  flex:none;
}
.audience-list li:hover{color:var(--accent);padding-left:8px;}
.audience-list li:first-child{border-top:1px solid var(--line);}

/* PANELS */
.panels-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:52px;}
.panel-card{
  background:var(--bg-2);border:1px solid var(--line);border-radius:12px;
  padding:40px;
}
.panel-tag{
  font-family:var(--font-display);font-weight:700;font-size:12px;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);
}
.panel-card h3{
  font-family:var(--font-display);font-weight:700;font-size:clamp(22px,2.4vw,28px);
  text-transform:uppercase;letter-spacing:-0.01em;color:var(--cream);
  margin:16px 0 24px;line-height:1.05;
}
.panel-card ul{list-style:none;}
.panel-card li{
  font-size:15px;color:var(--muted);line-height:1.5;padding:12px 0 12px 26px;
  position:relative;border-top:1px solid var(--line);
}
.panel-card li::before{content:"—";position:absolute;left:0;color:var(--accent);}

/* TICKETS */
#tickets .section-head{justify-content:center;}
#tickets .section-title{text-align:center;}
.tickets-intro{
  max-width:640px;margin:24px auto 0;text-align:center;
  font-size:17px;line-height:1.6;color:var(--muted);
}
.tickets-intro b{color:var(--cream);font-weight:600;}
.tickets-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin:44px auto 0;max-width:800px;}
.ticket{
  background:var(--bg);border:1px solid var(--line);border-radius:14px;
  padding:36px 32px;display:flex;flex-direction:column;position:relative;
}
.ticket--featured{
  background:var(--bg-3);border-color:var(--accent);
}
.ticket-badge{
  position:absolute;top:-12px;left:32px;
  background:var(--accent);color:#1A1206;
  font-size:12px;font-weight:700;letter-spacing:0.04em;
  padding:6px 14px;border-radius:100px;text-transform:uppercase;
}
.ticket-badge--warn{background:var(--gold);}
.ticket-badge--ghost{background:transparent;border:1px solid var(--line);color:var(--muted);}
.ticket-note{
  font-size:13px;color:var(--accent);font-weight:600;margin:-16px 0 22px;
}
.ticket--featured .ticket-note{color:var(--gold);}
/* стан «продано» — додайте клас .ticket--soldout до картки */
.ticket--soldout{opacity:.55;}
.ticket--soldout .ticket-btn{pointer-events:none;background:var(--bg-3);
  color:var(--muted-2);border-color:var(--line);}
.ticket--soldout .ticket-badge{background:var(--muted-2);color:var(--bg);}
.ticket-name{
  font-family:var(--font-display);font-weight:700;font-size:22px;
  text-transform:uppercase;letter-spacing:-0.01em;color:var(--cream);margin-bottom:18px;
}
.ticket-price{display:flex;align-items:baseline;gap:8px;margin-bottom:28px;}
.ticket-price b{
  font-family:var(--font-display);font-weight:800;font-size:44px;
  line-height:1;color:var(--cream);
}
.ticket-price span{font-size:15px;color:var(--muted);font-weight:600;}
.ticket-feats{list-style:none;margin-bottom:32px;flex:1;}
.ticket-feats li{
  font-size:15px;color:var(--muted);line-height:1.4;padding:11px 0 11px 28px;
  position:relative;border-top:1px solid var(--line);
}
.ticket-feats li::before{
  content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700;
}
.ticket-btn{width:100%;}
.tickets-promo{
  margin-top:28px;text-align:center;font-size:15px;color:var(--muted);
}
.tickets-promo b{color:var(--cream);font-family:var(--font-text);
  background:var(--bg-3);padding:3px 10px;border-radius:6px;font-weight:600;
  border:1px solid transparent;animation:promoGlow 2.6s ease-in-out infinite;}
.tickets-promo b:nth-of-type(2){animation-delay:1.3s;}
@keyframes promoGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(253,128,0,0);border-color:rgba(253,128,0,.15);color:var(--cream);}
  50%{box-shadow:0 0 16px 1px rgba(253,128,0,.5);border-color:rgba(253,128,0,.65);color:#fff;}
}
@media (prefers-reduced-motion: reduce){
  .tickets-promo b{animation:none;border-color:rgba(253,128,0,.3);}
}

/* SPLIT (pop-up / gastro) */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  padding:48px 0;border-bottom:1px solid var(--line);
}
.split--rev .split-text{order:2;}
.split-text .section-title{margin-bottom:22px;}
.split-text p{color:var(--muted);font-size:17px;line-height:1.65;max-width:480px;}
.split-media{
  aspect-ratio:4/3;border-radius:12px;background:var(--bg-3);
  display:flex;align-items:center;justify-content:center;position:relative;
}
.split-media::after{
  content:attr(data-label);
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:18px;color:var(--line);letter-spacing:0.04em;
}

.auction{margin-top:64px;max-width:880px;}
.auction .section-label{display:block;margin-bottom:24px;}
.auction-text{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(22px,2.8vw,36px);line-height:1.25;color:var(--cream);
  letter-spacing:-0.01em;
}

/* TIMELINE */
.timeline{list-style:none;margin-top:48px;border-top:1px solid var(--line);}
.timeline li{
  display:grid;grid-template-columns:120px 1fr;gap:28px;align-items:baseline;
  padding:22px 0;border-bottom:1px solid var(--line);transition:padding-left .2s;
}
.timeline li:hover{padding-left:8px;}
.t-time{
  font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--accent);
}
.t-desc{font-size:17px;color:var(--cream);}

/* PARTNERS */
.partners-block{margin-top:44px;}
.partners-cat{
  font-size:12px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--muted-2);display:block;margin-bottom:20px;
}
.partners-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
.partners-grid--lg{grid-template-columns:repeat(2,1fr);}
.partner-logo{
  display:flex;align-items:center;justify-content:center;
  height:96px;border:1px solid var(--line);border-radius:10px;
  font-family:var(--font-display);font-weight:700;font-size:18px;
  color:var(--muted);background:var(--bg-2);
  transition:color .2s, border-color .2s;text-align:center;padding:10px;
}
.partner-logo:hover{color:var(--cream);border-color:var(--muted-2);}
.partners-grid--lg .partner-logo{height:120px;font-size:26px;}

/* партнери — бігуча стрічка (приглушена, на відміну від яскравого тікера) */
.logo-marquee{
  overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.logo-marquee-track{
  display:flex;gap:14px;width:max-content;
  animation:logoScroll 45s linear infinite;
}
.logo-marquee--rev .logo-marquee-track{animation-direction:reverse;}
.logo-marquee:hover .logo-marquee-track{animation-play-state:paused;}
.logo-marquee .partner-logo{flex:0 0 200px;}
@keyframes logoScroll{to{transform:translateX(-50%);}}
@media (prefers-reduced-motion: reduce){
  .logo-marquee-track{animation:none;flex-wrap:wrap;}
}
.partners-cta{
  margin-top:56px;padding-top:40px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.partners-cta p{font-size:clamp(18px,2.4vw,26px);font-weight:600;color:var(--cream);}

/* ORGANIZERS */
.org-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:52px;}
.org-photo{
  aspect-ratio:1/1;border-radius:50%;background:var(--bg-3);margin-bottom:18px;
  display:flex;align-items:center;justify-content:center;
  background-size:cover;background-position:center;
}
.org-photo::after{
  content:attr(data-initials);
  font-family:var(--font-display);font-weight:800;font-size:34px;color:var(--line);
}
.org-card h3{
  font-family:var(--font-display);font-weight:700;font-size:18px;
  color:var(--cream);margin-bottom:5px;letter-spacing:-0.01em;
}
.org-card p{font-size:14px;color:var(--muted);}

/* FAQ */
.faq{margin-top:48px;border-top:1px solid var(--line);}
.faq-item{border-bottom:1px solid var(--line);}
.faq-item summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:26px 0;
  font-family:var(--font-display);font-weight:500;font-size:clamp(18px,2.1vw,24px);
  color:var(--cream);transition:color .2s;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary:hover{color:var(--accent);}
.faq-item summary::after{
  content:"+";flex:none;font-family:var(--font-text);font-weight:400;
  font-size:28px;line-height:1;color:var(--accent);transition:transform .25s;
}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-a{padding:0 0 26px;max-width:760px;}
.faq-a p{color:var(--muted);font-size:16px;line-height:1.65;}
.faq-a b{color:var(--cream);background:var(--bg-3);padding:2px 8px;border-radius:5px;font-weight:600;}

/* FOOTER */
.footer{background:var(--bg);border-top:1px solid var(--line);padding:72px var(--pad) 36px;}
.footer-top{
  display:flex;justify-content:space-between;gap:48px;flex-wrap:wrap;
  padding-bottom:48px;border-bottom:1px solid var(--line);
}
.footer-logo{height:30px;width:auto;margin-bottom:18px;}
.footer-brand p{color:var(--muted);font-size:15px;max-width:280px;}
.footer-cols{display:flex;gap:72px;flex-wrap:wrap;}
.footer-col{display:flex;flex-direction:column;gap:12px;}
.footer-col-h{
  font-size:12px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--muted-2);margin-bottom:6px;
}
.footer-col a{color:var(--muted);font-size:15px;transition:color .2s;}
.footer-col a:hover{color:var(--accent);}
.footer-bottom{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding-top:28px;font-size:14px;color:var(--muted-2);
}
.footer-bottom a{color:var(--muted-2);transition:color .2s;}
.footer-bottom a:hover{color:var(--cream);}

/* MODAL + APPLY FORM */
.modal{
  position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  padding:24px;opacity:0;visibility:hidden;transition:opacity .25s ease, visibility .25s ease;
}
.modal.open{opacity:1;visibility:visible;}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.66);backdrop-filter:blur(4px);}
.modal-card{
  position:relative;z-index:1;width:100%;max-width:520px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:16px;
  padding:40px;max-height:90vh;overflow-y:auto;
  transform:translateY(14px) scale(.98);transition:transform .28s cubic-bezier(.2,.8,.2,1);
}
.modal.open .modal-card{transform:none;}
.modal-close{
  position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;
  background:transparent;border:1px solid var(--line);color:var(--cream);cursor:pointer;
  font-size:15px;transition:background .2s,border-color .2s;
}
.modal-close:hover{background:var(--bg-3);border-color:var(--muted-2);}
.modal-title{
  font-family:var(--font-display);font-weight:800;text-transform:uppercase;
  font-size:clamp(26px,3.4vw,36px);line-height:1;letter-spacing:-0.02em;
  color:var(--cream);margin:14px 0 8px;
}
.modal-sub{color:var(--muted);font-size:15px;margin-bottom:26px;}

.apply-form{display:flex;flex-direction:column;gap:16px;}
.apply-form .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;}
.apply-form label{
  display:block;
  font-size:13px;font-weight:600;letter-spacing:0.02em;color:var(--muted);
}
.apply-form .req{color:var(--accent);}
.apply-form input,.apply-form select,.apply-form textarea{
  display:block;margin-top:8px;
  font-family:var(--font-text);font-size:15px;color:var(--cream);
  background:var(--bg);border:1px solid var(--line);border-radius:10px;
  padding:13px 15px;transition:border-color .2s;width:100%;
}
.apply-form textarea{resize:vertical;min-height:70px;}
.apply-form input:focus,.apply-form select:focus,.apply-form textarea:focus{
  outline:none;border-color:var(--accent);
}
.apply-form select{appearance:none;cursor:pointer;}
.apply-submit{width:100%;margin-top:6px;}
.apply-submit:disabled{opacity:.6;cursor:default;}
.apply-status{font-size:14px;text-align:center;min-height:18px;margin:0;}
.apply-status.ok{color:var(--lime);}
.apply-status.err{color:#ff6a4d;}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  :root{ --pad:22px; }
  .nav-links, .nav-cta{ display:none; }
  .nav-burger{ display:flex; }
  .hero{ padding-top:130px; }
  .hero-stats{ gap:32px; }
  .section{ padding:72px var(--pad); }
  .about-grid{ grid-template-columns:1fr; gap:28px; padding-bottom:48px; }
  .feature-row{ grid-template-columns:1fr; gap:24px; margin-top:44px; }
  .awaits-grid{ grid-template-columns:1fr; }
  .stats-row{ grid-template-columns:1fr 1fr; gap:24px 18px; }
  .stats-band{ padding:64px var(--pad); }
  .audience-grid{ grid-template-columns:1fr; gap:28px; }
  .panels-grid{ grid-template-columns:1fr; gap:18px; }
  .panel-card{ padding:28px; }
  .tickets-grid{ grid-template-columns:1fr; gap:18px; }
  .split{ grid-template-columns:1fr; gap:24px; padding:32px 0; }
  .split--rev .split-text{ order:0; }
  .timeline li{ grid-template-columns:84px 1fr; gap:16px; }
  .partners-grid{ grid-template-columns:repeat(2,1fr); }
  .org-grid{ grid-template-columns:1fr 1fr; gap:18px; }
}
@media(max-width:560px){
  .speaker-card{ flex-basis:80vw; }
  .speakers-top{ align-items:flex-start; flex-direction:column; }
  .hero-title{ font-size:clamp(26px,8.6vw,48px); letter-spacing:-0.03em; }
  .hero{ min-height:auto; padding-bottom:56px; }
  .hero-meta{ gap:28px 40px; }
  .org-grid{ gap:16px; }
}
