/* ============================================================
   PROJETO EU — Página EU EXPERIENCE
   Reutiliza tokens e componentes de styles.css
   ============================================================ */

/* ---------- HERO ---------- */
.xp-hero{ position:relative; width:100%; min-height:100svh; overflow:hidden; isolation:isolate; display:flex; }
.xp-hero-media{ position:absolute; inset:0; z-index:0; }
.xp-hero-media image-slot{ position:absolute; inset:0; width:100%; height:100%; }
/* slideshow de fotos do evento */
.xp-slide{ position:absolute; inset:0; opacity:0; transition:opacity 1.4s ease; will-change:opacity; }
.xp-slide.is-active{ opacity:1; }
.xp-hero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; opacity:0; transition:opacity .8s ease; }
.xp-hero-video.ready{ opacity:1; }
.xp-hero-media::after{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    radial-gradient(110% 80% at 72% 28%, rgba(225,6,0,.2), transparent 55%),
    linear-gradient(180deg, rgba(10,10,10,.62) 0%, rgba(10,10,10,.4) 38%, rgba(10,10,10,.94) 100%);
}
.xp-hero-inner{ position:relative; z-index:3; width:100%; align-self:flex-end; padding:clamp(120px,18vh,200px) var(--gut) clamp(48px,8vh,90px); }
/* variante centralizada: título + subtítulo no centro */
.xp-hero-centered{ align-self:center; text-align:center; display:flex; flex-direction:column; align-items:center; padding:clamp(60px,10vh,120px) var(--gut); }
.xp-hero-centered h1{ font-size:clamp(52px,11vw,168px); max-width:none; }
.xp-hero-centered .xp-hero-sub{ margin-left:auto; margin-right:auto; }
.xp-hero-eyebrow{ display:inline-flex; align-items:center; gap:14px; font-family:var(--font-sub); font-weight:700; font-size:13px; letter-spacing:.3em; text-transform:uppercase; color:var(--bone); margin-bottom:clamp(22px,3vw,34px); }
.xp-hero-eyebrow .tick{ width:42px; height:1px; background:var(--red); }
.xp-hero-eyebrow .red{ color:var(--red); }
.xp-hero h1{ font-family:var(--font-display); font-weight:400; text-transform:uppercase; color:#fff; letter-spacing:.004em; line-height:.86; font-size:clamp(56px,12vw,210px); text-shadow:0 6px 50px rgba(0,0,0,.5); }
.xp-hero h1 .red{ color:var(--red); }
.xp-hero-sub{ max-width:52ch; margin-top:clamp(24px,3vw,38px); color:var(--bone); font-size:clamp(16px,1.5vw,21px); line-height:1.55; opacity:.92; }
.xp-hero-scroll{ position:absolute; left:var(--gut); bottom:26px; z-index:3; display:flex; align-items:center; gap:12px; font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gray); }
.xp-hero-scroll .line{ width:46px; height:1px; background:var(--gray); position:relative; overflow:hidden; }
.xp-hero-scroll .line::after{ content:""; position:absolute; inset:0; background:var(--red); animation:scrollline 2.4s var(--ease) infinite; }

/* ---------- MANIFESTO line ---------- */
.xp-manifesto{ padding:clamp(70px,11vh,130px) var(--gut); background:var(--bone); }
.xp-manifesto p{ max-width:24ch; margin:0 auto; text-align:center; font-family:var(--font-display); text-transform:uppercase; font-size:clamp(30px,5vw,76px); line-height:.98; color:var(--ink); letter-spacing:.004em; }
.xp-manifesto p .red{ color:var(--red); }

/* ---------- NÚMEROS ---------- */
.xp-nums{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--gray-line); }
.xp-num{ padding:clamp(30px,4vw,56px) clamp(16px,2vw,34px); border-right:1px solid var(--gray-line); }
.xp-num:last-child{ border-right:0; }
.xp-num .n{ font-family:var(--font-display); font-size:clamp(46px,7vw,104px); line-height:.82; color:#fff; }
.xp-num .n .red{ color:var(--red); }
.xp-num .l{ font-family:var(--font-sub); font-weight:600; font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray); margin-top:16px; }
.xp-num .src{ font-size:11px; color:#555; margin-top:8px; letter-spacing:.04em; }
@media (max-width:760px){ .xp-nums{ grid-template-columns:1fr 1fr; } .xp-num:nth-child(2){ border-right:0; } .xp-num:nth-child(1),.xp-num:nth-child(2){ border-bottom:1px solid var(--gray-line); } }

/* ---------- CABEÇALHO EDIÇÕES ---------- */
.xp-edhead{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,70px); align-items:end; }
@media (max-width:820px){ .xp-edhead{ grid-template-columns:1fr; } }
.xp-edhead h2{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(48px,9vw,150px); line-height:.86; color:#fff; }
.xp-edhead h2 .red{ color:var(--red); }
.xp-edhead p{ color:var(--gray); font-size:clamp(16px,1.4vw,19px); line-height:1.6; max-width:42ch; }

/* ---------- EDIÇÃO ---------- */
.edicao{ border-top:1px solid var(--gray-line); position:relative; }
.edicao:first-of-type{ border-top:0; }
.ed-intro{ padding:clamp(56px,8vh,110px) var(--gut); display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.05fr); gap:clamp(32px,5vw,80px); align-items:center; max-width:var(--maxw); margin:0 auto; }
.edicao.flip .ed-media{ order:-1; }
@media (max-width:920px){ .ed-intro{ grid-template-columns:1fr; align-items:start; } .edicao.flip .ed-media{ order:0; } }

.ed-badge{ display:inline-flex; align-items:center; gap:12px; font-family:var(--font-sub); font-weight:800; font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--red); margin-bottom:20px; }
.ed-badge .dot{ width:8px; height:8px; border-radius:50%; background:var(--red); }
.ed-number{ font-family:var(--font-display); font-size:clamp(70px,11vw,180px); line-height:.8; color:#fff; letter-spacing:.01em; margin-bottom:6px; }
.ed-number .out{ color:transparent; -webkit-text-stroke:1.6px var(--red); }
.ed-meta{ display:flex; flex-direction:column; gap:6px; margin:18px 0 26px; padding:18px 0; border-top:1px solid var(--gray-line); border-bottom:1px solid var(--gray-line); }
.ed-meta .row{ display:flex; gap:12px; font-size:14.5px; }
.ed-meta .row .k{ font-family:var(--font-sub); font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:11px; color:var(--gray); min-width:64px; padding-top:2px; }
.ed-meta .row .v{ color:var(--bone); }
.ed-tagline{ font-family:var(--font-sub); font-weight:600; font-style:italic; font-size:clamp(17px,1.6vw,22px); line-height:1.45; color:#fff; padding-left:20px; border-left:3px solid var(--red); margin-bottom:24px; }
.ed-text{ display:flex; flex-direction:column; gap:14px; margin-bottom:26px; }
.ed-text p{ color:var(--gray); font-size:16px; line-height:1.7; max-width:52ch; }
.ed-text p strong{ color:var(--bone); font-weight:600; }
.ed-list-h{ font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--gray); margin-bottom:14px; }
.ed-list{ display:grid; grid-template-columns:1fr 1fr; gap:10px 22px; margin-bottom:30px; }
@media (max-width:520px){ .ed-list{ grid-template-columns:1fr; } }
.ed-list li{ list-style:none; display:flex; gap:11px; align-items:baseline; color:var(--bone); font-size:14.5px; line-height:1.4; }
.ed-list li::before{ content:""; width:7px; height:7px; flex-shrink:0; background:var(--red); transform:translateY(1px); }

/* media side (recap no intro) */
.ed-media{ display:flex; flex-direction:column; gap:clamp(12px,1.4vw,18px); }
.ed-recap{ position:relative; aspect-ratio:16/10; border-radius:6px; overflow:hidden; background:#0a0a0a; border:1px solid var(--gray-line); cursor:pointer; }
.ed-recap image-slot{ position:absolute; inset:0; width:100%; height:100%; transition:transform .6s var(--ease); }
.ed-recap:hover image-slot{ transform:scale(1.04); }
.ed-recap-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:3; opacity:0; transition:opacity .3s ease; pointer-events:none; background:#000; }
.ed-recap.playing .ed-recap-video{ opacity:1; pointer-events:auto; }
.ed-recap .scrim{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(10,10,10,.1), rgba(10,10,10,.6)); pointer-events:none; transition:opacity .3s ease; }
.ed-recap .play-btn{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2; transition:transform .25s ease, background .25s ease, opacity .3s ease; }
.ed-recap .play-btn:hover{ transform:translate(-50%,-50%) scale(1.07); background:var(--red-deep); }
.ed-recap .cap{ position:absolute; left:0; bottom:0; z-index:2; padding:clamp(16px,1.8vw,24px); font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:#fff; transition:opacity .3s ease; }
.ed-recap.playing .scrim, .ed-recap.playing .play-btn, .ed-recap.playing .cap{ opacity:0; pointer-events:none; }

/* ---------- GALERIA FIXADA (desliza no scroll) ---------- */
.ed-gallery{ position:relative; }
.ed-gallery-pin{ position:sticky; top:0; height:100svh; overflow:hidden; display:flex; flex-direction:column; justify-content:center; gap:clamp(18px,2.5vw,32px); background:var(--ink); }
.ed-gallery-head{ display:flex; align-items:baseline; justify-content:space-between; gap:20px; flex-wrap:wrap; padding:0 var(--gut); flex-shrink:0; }
.ghead-label{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(22px,3vw,46px); color:#fff; line-height:.95; }
.ghead-hint{ display:inline-flex; align-items:center; gap:12px; font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gray); }
.ghead-line{ width:40px; height:1px; background:var(--red); position:relative; overflow:hidden; }
.ghead-line::after{ content:""; position:absolute; inset:0; background:var(--bone); animation:scrollline 2.4s var(--ease) infinite; }
.ed-gtrack{ display:flex; gap:clamp(14px,1.6vw,22px); padding:0 var(--gut); align-items:stretch; will-change:transform; height:min(64vh,560px); }
.ed-gcard{ position:relative; flex:0 0 auto; width:clamp(260px,30vw,400px); border-radius:6px; overflow:hidden; background:#0a0a0a; border:1px solid var(--gray-line); }
.ed-gcard.wide{ width:clamp(420px,52vw,720px); }
.ed-gcard image-slot{ position:absolute; inset:0; width:100%; height:100%; }
body[data-duotone="on"] .ed-gcard image-slot{ filter:grayscale(1) contrast(1.1) brightness(.94); transition:filter .5s ease; }
body[data-duotone="on"] .ed-gcard:hover image-slot{ filter:none; }

/* fallback / mobile: swipe horizontal nativo */
.ed-gallery.no-pin .ed-gallery-pin{ position:static; height:auto; padding:clamp(48px,7vh,90px) 0; }
.ed-gallery.no-pin .ed-gtrack{ overflow-x:auto; scroll-snap-type:x mandatory; transform:none !important; height:clamp(320px,52vh,460px); -webkit-overflow-scrolling:touch; padding-bottom:16px; }
.ed-gallery.no-pin .ed-gtrack::-webkit-scrollbar{ height:4px; }
.ed-gallery.no-pin .ed-gtrack::-webkit-scrollbar-thumb{ background:var(--red-deep); }
.ed-gallery.no-pin .ed-gcard{ scroll-snap-align:center; }

/* EU KIDS highlight */
.eukids{ margin:6px 0 30px; padding:24px 26px; border:1px solid var(--gray-line); border-radius:6px; background:linear-gradient(180deg, rgba(225,6,0,.08), rgba(20,20,20,.4)); display:flex; gap:20px; align-items:flex-start; }
.eukids .badge{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(20px,2vw,30px); color:var(--red); line-height:.9; flex-shrink:0; }
.eukids p{ color:var(--bone); font-size:15px; line-height:1.6; opacity:.9; }

.ed-cta{ display:inline-flex; align-items:center; gap:12px; font-family:var(--font-sub); font-weight:700; font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:#fff; border:1px solid var(--gray-line); padding:15px 24px; border-radius:3px; transition:border-color .25s ease, background .25s ease; }
.ed-cta:hover{ border-color:var(--red); background:rgba(225,6,0,.1); }
.ed-cta .arr{ color:var(--red); transition:transform .25s var(--ease); }
.ed-cta:hover .arr{ transform:translateX(5px); }

/* recap embed do YouTube */
.ed-recap iframe.yt-embed{ position:absolute; inset:0; width:100%; height:100%; border:0; z-index:5; }

/* ---------- PALESTRANTES ---------- */
.speakers-carousel{ position:relative; }
.speakers-track{ display:flex; gap:var(--sgap,18px); overflow-x:auto; scroll-snap-type:none; -ms-overflow-style:none; scrollbar-width:none; padding-bottom:4px; }
.speakers-track::-webkit-scrollbar{ display:none; }
.speakers-track .speaker{ flex:0 0 calc((100% - 4 * var(--sgap,18px)) / 5); scroll-snap-align:start; }
.speakers-controls{ display:flex; gap:10px; margin-top:clamp(24px,3vw,38px); }
@media (max-width:980px){ .speakers-track .speaker{ flex:0 0 calc((100% - 2 * var(--sgap,18px)) / 3); } }
@media (max-width:620px){ .speakers-track .speaker{ flex:0 0 calc((100% - 1 * var(--sgap,18px)) / 2); } }
@media (max-width:420px){ .speakers-track .speaker{ flex:0 0 78%; } }
.speakers-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(14px,1.6vw,22px); }
@media (max-width:980px){ .speakers-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:720px){ .speakers-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:420px){ .speakers-grid{ grid-template-columns:1fr; } }
.speaker{ display:flex; flex-direction:column; }
.speaker-photo{ position:relative; aspect-ratio:3/4; border-radius:5px; overflow:hidden; background:#111; border:1px solid var(--gray-line); margin-bottom:16px; }
.speaker-photo image-slot{ position:absolute; inset:0; width:100%; height:100%; transition:transform .5s var(--ease); }
.speaker:hover .speaker-photo image-slot{ transform:scale(1.05); }
body[data-duotone="on"] .speaker-photo image-slot{ filter:grayscale(1) contrast(1.08) brightness(.95); transition:filter .4s ease, transform .5s var(--ease); }
body[data-duotone="on"] .speaker:hover .speaker-photo image-slot{ filter:grayscale(0) contrast(1) brightness(1); }
.speaker-photo .num{ position:absolute; top:12px; left:13px; z-index:2; font-family:var(--font-sub); font-weight:800; font-size:12px; letter-spacing:.1em; color:#fff; text-shadow:0 1px 6px rgba(0,0,0,.6); }
.speaker h3{ font-family:var(--font-sub); font-weight:700; font-size:16px; letter-spacing:.02em; color:#fff; line-height:1.15; margin-bottom:7px; }
.speaker p{ color:var(--gray); font-size:13.5px; line-height:1.45; }

/* ---------- FUNDADOR ---------- */
.xp-founder{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,80px); align-items:center; }
@media (max-width:880px){ .xp-founder{ grid-template-columns:1fr; } }
.xp-founder-photo{ position:relative; }
.xp-founder-clip{ position:relative; width:100%; aspect-ratio:4/5; border-radius:5px; overflow:hidden; }
.xp-founder-clip image-slot{ position:absolute; inset:0; width:100%; height:100%; }
.xp-founder-photo .badge{ position:absolute; bottom:-14px; left:-14px; background:var(--red); color:#fff; font-family:var(--font-display); text-transform:uppercase; font-size:clamp(16px,1.5vw,22px); padding:14px 22px; line-height:1; }
.xp-founder-photo .badge small{ display:block; font-family:var(--font-sub); font-weight:600; font-size:10px; letter-spacing:.18em; margin-top:6px; opacity:.85; }
.xp-founder-body .secnum{ margin-bottom:18px; }
.xp-founder-body h2{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(32px,4.5vw,72px); line-height:.92; color:#fff; margin-bottom:24px; }
.xp-founder-body h2 .red{ color:var(--red); }
.xp-founder-body p{ color:var(--bone); opacity:.86; font-size:16.5px; line-height:1.7; max-width:56ch; margin-bottom:16px; }
.xp-founder-quote{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(22px,2.4vw,36px); line-height:1; color:var(--red); margin-top:28px; max-width:22ch; }

/* ---------- CTA FINAL ---------- */
.xp-final{ text-align:center; padding:clamp(90px,16vh,200px) var(--gut); position:relative; overflow:hidden; }
.xp-final canvas{ position:absolute; inset:0; z-index:0; width:100%; height:100%; }
.xp-final .wrap{ position:relative; z-index:2; }
.xp-final .kicker{ color:var(--red); margin-bottom:24px; }
.xp-final h2{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(56px,13vw,220px); line-height:.84; color:#fff; text-shadow:0 4px 40px rgba(0,0,0,.6); }
.xp-final h2 .red{ color:var(--red); }
.xp-final p{ max-width:42ch; margin:28px auto 40px; color:var(--bone); opacity:.9; font-size:clamp(16px,1.5vw,20px); line-height:1.6; text-shadow:0 2px 24px rgba(0,0,0,.6); }

/* reveal helper already in styles.css */
