/* FDI Evento Landing - premium UI (no theme dependency) */
:root{
  --fdi-bg:#050814;
  --fdi-bg2:#070b1f;
  --fdi-gold:#D4AF37;
  --fdi-cyan:#2ED3FF;
  --fdi-white:#ffffff;
  --fdi-text:rgba(255,255,255,.92);
  --fdi-muted:rgba(255,255,255,.70);
  --fdi-border:rgba(255,255,255,.10);
  --fdi-shadow: 0 18px 60px rgba(0,0,0,.55);
  --fdi-radius: 18px;
  --fdi-radius-lg: 26px;
  --fdi-font: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
}

.fdi-event, .fdi-event *{ box-sizing:border-box; }
.fdi-event{
  font-family: var(--fdi-font);
  color: var(--fdi-text);
  background: radial-gradient(1200px 700px at 20% 10%, rgba(46,211,255,.14), transparent 55%),
              radial-gradient(1000px 600px at 80% 0%, rgba(212,175,55,.16), transparent 60%),
              linear-gradient(180deg, var(--fdi-bg), var(--fdi-bg2));
  position:relative;
  overflow:hidden;
  border-radius: 0;
}


/* Ensure headings/subtitles remain high-contrast even if theme/Elementor overrides */
.fdi-event h1, .fdi-event h2, .fdi-event h3{
  color: rgba(255,255,255,.98) !important;
}
.fdi-event p{
  color: var(--fdi-text);
}
.fdi-event .fdi-lead{
  color: rgba(255,255,255,.88) !important;
}
.fdi-event .fdi-h2{
  color: rgba(255,255,255,.98) !important;
}
.fdi-event .fdi-h3{
  color: rgba(255,255,255,.98) !important;
}
.fdi-event .fdi-muted{
  color: rgba(255,255,255,.82) !important;
}
.fdi-event .fdi-speaker__bio{
  color: rgba(255,255,255,.88) !important;
}
.fdi-bg-glow{
  position:absolute; inset:-200px -200px auto -200px;
  height:520px;
  background: radial-gradient(closest-side, rgba(46,211,255,.22), transparent 70%),
              radial-gradient(closest-side, rgba(212,175,55,.16), transparent 72%);
  filter: blur(6px);
  opacity:.9;
  pointer-events:none;
}

.fdi-container{
  width:min(1120px, 92vw);
  margin: 0 auto;
}

.fdi-hero{
  padding: clamp(44px, 5.5vw, 76px) 0 40px;
  position:relative;
}

.fdi-hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(18px, 3vw, 34px);
  align-items:stretch;
}

.fdi-title{
  font-size: clamp(34px, 4.6vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 12px 0 10px;
  text-transform: uppercase;
  background: linear-gradient(90deg, #fff, rgba(255,255,255,.90), rgba(46,211,255,.92));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

.fdi-subtitle{
  margin: 0 0 18px;
  color: var(--fdi-muted);
  font-size: 16px;
}

.fdi-badge{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(212,175,55,.38);
  background: linear-gradient(180deg, rgba(212,175,55,.16), rgba(46,211,255,.06));
  border-radius: 999px;
  box-shadow: 0 14px 40px rgba(0,0,0,.35);
}
.fdi-badge__label{
  font-weight: 800;
  color: rgba(255,255,255,.98);
}
.fdi-badge__code{ color: rgba(255,255,255,.85); }

.fdi-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  margin: 18px 0 18px;
}

.fdi-btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid var(--fdi-border);
  text-decoration:none;
  color: rgba(255,255,255,.95);
  font-weight: 700;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
  outline: none;
}
.fdi-btn:focus-visible{
  box-shadow: 0 0 0 3px rgba(46,211,255,.35);
}
.fdi-btn--primary{
  background: linear-gradient(135deg, rgba(212,175,55,.95), rgba(46,211,255,.70));
  border-color: rgba(46,211,255,.25);
  color: #071018;
  text-shadow: none;
  box-shadow: 0 18px 50px rgba(46,211,255,.12);
}
.fdi-btn--primary:hover{ transform: translateY(-2px); box-shadow: 0 22px 60px rgba(46,211,255,.20); }
.fdi-btn--ghost{
  background: rgba(255,255,255,.04);
}
.fdi-btn--ghost:hover{ transform: translateY(-2px); border-color: rgba(255,255,255,.18); }
.fdi-btn--full{ width: 100%; }

.fdi-btn-glow{
  position:absolute;
  inset:-2px;
  border-radius: 14px;
  background: radial-gradient(400px 120px at 30% 30%, rgba(255,255,255,.40), transparent 60%),
              radial-gradient(360px 120px at 70% 70%, rgba(46,211,255,.32), transparent 60%);
  opacity: .45;
  filter: blur(10px);
  z-index: -1;
  animation: fdiGlow 2.8s ease-in-out infinite;
}
@keyframes fdiGlow{
  0%,100%{ opacity:.42; transform: translateY(0); }
  50%{ opacity:.60; transform: translateY(-1px); }
}

.fdi-trust{
  display:flex;
  flex-wrap:wrap;
  gap: 10px 14px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.10);
}
.fdi-trust-item{
  display:flex;
  align-items:center;
  gap: 8px;
  color: rgba(255,255,255,.80);
  font-size: 13.5px;
}
.fdi-ico{
  width:18px; height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 999px;
  background: rgba(46,211,255,.14);
  border: 1px solid rgba(46,211,255,.20);
  color: rgba(255,255,255,.95);
  font-weight: 900;
  line-height:1;
}

.fdi-mini-contact{ margin-top: 14px; }
.fdi-link{
  color: rgba(255,255,255,.96);
  text-decoration: underline;
  text-decoration-color: rgba(46,211,255,.85);
  text-underline-offset: 3px;
  font-weight: 750;
  text-shadow: 0 0 14px rgba(46,211,255,.18);
}
.fdi-link:hover{ text-decoration:underline; }

.fdi-hero-card{
  border-radius: var(--fdi-radius-lg);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--fdi-shadow);
  padding: 16px;
  position:relative;
  overflow:hidden;
}
.fdi-hero-card::before{
  content:"";
  position:absolute; inset:-1px;
  background: radial-gradient(600px 240px at 20% 20%, rgba(212,175,55,.22), transparent 60%),
              radial-gradient(500px 220px at 90% 40%, rgba(46,211,255,.18), transparent 60%);
  opacity:.9;
  pointer-events:none;
  filter: blur(10px);
}
.fdi-hero-card > *{ position:relative; z-index:1; }

.fdi-hero-card__top{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  justify-content:flex-start;
  margin-bottom: 14px;
}

.fdi-pill{
  display:inline-flex;
  align-items:center;
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 12.5px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.92);
}
.fdi-pill--alt{
  border-color: rgba(212,175,55,.30);
  background: rgba(212,175,55,.10);
}

.fdi-countdown{
  padding: 14px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.fdi-countdown__label{
  font-weight: 900;
  letter-spacing:.02em;
  color: rgba(255,255,255,.86);
  margin-bottom: 10px;
  text-transform: uppercase;
  font-size: 12px;
}
.fdi-countdown__grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.fdi-time{
  border-radius: 14px;
  border: 1px solid rgba(46,211,255,.16);
  background: linear-gradient(180deg, rgba(46,211,255,.10), rgba(255,255,255,.03));
  padding: 10px 8px;
  text-align:center;
}
.fdi-time__num{
  font-size: 26px;
  font-weight: 900;
  letter-spacing:.02em;
  color: rgba(255,255,255,.96);
  text-shadow: 0 0 18px rgba(46,211,255,.18);
}
.fdi-time__lbl{
  font-size: 11px;
  letter-spacing:.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
  margin-top: 4px;
}
.fdi-countdown__note{
  margin-top: 10px;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  min-height: 18px;
}

.fdi-hero-card__cta{ margin-top: 12px; }
.fdi-small{ color: rgba(255,255,255,.70); font-size: 13px; margin-top: 10px; }

.fdi-section{
  padding: 56px 0;
  position:relative;
}
.fdi-section--alt{
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.00));
  border-top: 1px solid rgba(255,255,255,.07);
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.fdi-section-head{ margin-bottom: 22px; }
.fdi-h2{
  font-size: clamp(24px, 2.8vw, 34px);
  margin: 0 0 8px;
  letter-spacing: -0.02em;
}
.fdi-lead{ margin:0; color: rgba(255,255,255,.84); font-size: 16px; line-height:1.55; font-size: 15.5px; line-height:1.5; }

.fdi-speakers{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.fdi-speaker{
  border-radius: var(--fdi-radius);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: 0 18px 50px rgba(0,0,0,.38);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height: 100%;
}
.fdi-speaker__photo{
  /*
    Keep the photo wrapper IN FLOW across themes/Elementor
    and ensure the image never appears "cropped".
  */
  position: relative !important;
  flex: 0 0 auto !important;
  z-index: 1;
  overflow: hidden;
  padding: 14px;
  box-sizing: border-box;

  /* Responsive photo area */
  aspect-ratio: 4 / 3;              /* stable in desktop/tablet */
  min-height: 340px;                /* ensures enough space for full-body */
  height: auto;                     /* let aspect-ratio drive the height */

  display: flex;
  align-items: center;
  justify-content: center;

  background: radial-gradient(420px 220px at 30% 30%, rgba(46,211,255,.14), transparent 60%),
              radial-gradient(420px 240px at 70% 80%, rgba(212,175,55,.14), transparent 60%),
              rgba(0,0,0,.20);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.fdi-speaker__photo img{
  position: relative;
  z-index: 1;
  /* Force contain even if theme sets cover */
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  display: block;
  filter: drop-shadow(0 22px 40px rgba(0,0,0,.45));
}
@media (max-width: 980px){
  .fdi-speaker__photo{ min-height: 320px; aspect-ratio: 16 / 11; }
}
@media (max-width: 560px){
  .fdi-speaker__photo{ min-height: 300px; aspect-ratio: 1 / 1; }
}
.fdi-speaker__body{
  position: relative !important;
  flex: 1 1 auto !important;
  z-index: 2;
  padding: 14px 14px 16px;
}
.fdi-h3{
  margin: 0 0 6px;
  font-size: 18px;
  letter-spacing: -0.01em;
}
.fdi-muted{ margin: 0; color: rgba(255,255,255,.82); font-size: 14.5px; line-height:1.55; font-size: 14px; line-height:1.5; }

.fdi-mini-btn{
  margin-top: 12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(46,211,255,.38);
  background: linear-gradient(180deg, rgba(46,211,255,.18), rgba(46,211,255,.06));
  color: rgba(255,255,255,.96);
  font-weight: 850;
  cursor:pointer;
  transition: transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease;
}
.fdi-mini-btn:hover{ transform: translateY(-1px); border-color: rgba(46,211,255,.55); box-shadow: 0 16px 40px rgba(46,211,255,.12); }
.fdi-mini-btn:focus-visible{ box-shadow: 0 0 0 3px rgba(46,211,255,.30); outline:none; }

.fdi-accordion-panel{
  margin-top: 10px;
  border-top: 1px solid rgba(255,255,255,.10);
  padding-top: 10px;
}
.fdi-bullets{ margin:0; padding-left: 18px; color: rgba(255,255,255,.82); }
.fdi-bullets li{ margin: 6px 0; }

.fdi-learn-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items:stretch;
}

.fdi-card{
  border-radius: var(--fdi-radius);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
  padding: 18px;
}
.fdi-card--highlight{
  background: radial-gradient(600px 260px at 20% 10%, rgba(212,175,55,.18), transparent 60%),
              radial-gradient(560px 240px at 80% 80%, rgba(46,211,255,.14), transparent 60%),
              linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}

.fdi-checklist{
  margin:0;
  padding:0;
  list-style:none;
}
.fdi-checklist li{
  position:relative;
  padding-left: 30px;
  margin: 14px 0;
  color: rgba(255,255,255,.86);
  line-height:1.55;
}
.fdi-checklist li::before{
  content:"✓";
  position:absolute;
  left:0; top:0;
  width: 22px; height: 22px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(212,175,55,.14);
  border: 1px solid rgba(212,175,55,.30);
  color: rgba(255,255,255,.95);
  font-weight: 900;
}

.fdi-highlight__title{
  font-weight: 900;
  font-size: 18px;
  margin-bottom: 8px;
}
.fdi-pill-row{ display:flex; flex-wrap:wrap; gap: 8px; margin: 14px 0 16px; }

.fdi-cta-mini{ margin-top: 12px; display:grid; gap: 10px; }
.fdi-code-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 10px;
  border-radius: 14px;
  border: 1px dashed rgba(212,175,55,.35);
  background: rgba(0,0,0,.18);
}
.fdi-code-box--big{ margin-top: 12px; max-width: 420px; }
.fdi-code-pill{
  font-weight: 900;
  letter-spacing:.14em;
  text-transform: uppercase;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(212,175,55,.12);
  border: 1px solid rgba(212,175,55,.28);
  color: rgba(255,255,255,.96);
  user-select: all;
}

.fdi-cta-slab{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  align-items:center;
  padding: 22px;
  border-radius: var(--fdi-radius-lg);
  border: 1px solid rgba(255,255,255,.10);
  background: radial-gradient(700px 260px at 20% 20%, rgba(46,211,255,.14), transparent 60%),
              radial-gradient(700px 300px at 80% 80%, rgba(212,175,55,.14), transparent 60%),
              linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: var(--fdi-shadow);
}
.fdi-cta-slab__right{ display:grid; gap: 10px; }

.fdi-faq{ display:grid; gap: 10px; }
.fdi-faq-item{
  border-radius: var(--fdi-radius);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  overflow:hidden;
}
.fdi-faq-q{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 14px;
  background: transparent;
  border: 0;
  color: rgba(255,255,255,.94);
  font-weight: 900;
  cursor:pointer;
  text-align:left;
}
.fdi-faq-q:focus-visible{ outline:none; box-shadow: 0 0 0 3px rgba(46,211,255,.30); }
.fdi-faq-icon{
  width: 28px; height: 28px;
  border-radius: 999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(46,211,255,.22);
  background: rgba(46,211,255,.08);
  font-size: 18px;
  line-height:1;
}
.fdi-faq-a{
  padding: 0 14px 14px;
  color: rgba(255,255,255,.76);
  line-height: 1.6;
}
.fdi-faq-a p{ margin: 10px 0 0; }

.fdi-footer{
  padding: 34px 0 20px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.fdi-footer-grid{
  display:flex;
  gap: 16px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
}
.fdi-footer-title{
  font-weight: 900;
  font-size: 16px;
  letter-spacing: -0.01em;
}
.fdi-footer-cta{ display:grid; gap: 8px; align-items:flex-start; }
.fdi-legal{
  margin-top: 16px;
  color: rgba(255,255,255,.55);
  font-size: 12.5px;
}

.fdi-sticky{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 10px 12px calc(env(safe-area-inset-bottom) + 10px);
  background: rgba(5,8,20,.75);
  backdrop-filter: blur(10px);
  border-top: 1px solid rgba(255,255,255,.10);
  display:none;
  z-index: 9999;
}
.fdi-sticky__inner{
  width:min(1120px, 96vw);
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.fdi-sticky__text{
  font-weight: 900;
  color: rgba(255,255,255,.92);
  font-size: 12.5px;
}
.fdi-sticky__code{
  letter-spacing:.12em;
  text-transform: uppercase;
}
.fdi-sticky__btn{
  text-decoration:none;
  color:#071018;
  font-weight: 900;
  padding: 10px 12px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(212,175,55,.95), rgba(46,211,255,.70));
  border: 1px solid rgba(46,211,255,.25);
  box-shadow: 0 16px 40px rgba(0,0,0,.25);
}

/* Animations */
.fdi-animate{
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .55s ease, transform .55s ease;
  will-change: opacity, transform;
}
.fdi-animate.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 940px){
  .fdi-hero-grid{ grid-template-columns: 1fr; }
  .fdi-hero-card{ max-width: 560px; }
  .fdi-speakers{ grid-template-columns: 1fr; }
  .fdi-speaker__photo{ height: 420px; }
  .fdi-learn-grid{ grid-template-columns: 1fr; }
  .fdi-cta-slab{ grid-template-columns: 1fr; }
  .fdi-sticky{ display:block; }
  .fdi-countdown__grid{ grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 420px){
  .fdi-speaker__photo{ height: 360px; }
  .fdi-countdown__grid{ grid-template-columns: repeat(2, 1fr); }
  .fdi-time__num{ font-size: 24px; }
  .fdi-badge{ flex-wrap:wrap; border-radius: 18px; }
}

/* Ensure full-page endpoint looks correct */
body.fdi-landing-body{
  margin:0 !important;
  background: var(--fdi-bg) !important;
}
.fdi-landing-root{ min-height: 100vh; }


/* Speaker extra info */
.fdi-speaker__bio{
  margin: 8px 0 0;
  color: rgba(255,255,255,.78);
  font-size: 14.25px;
  line-height: 1.55;
}


/* Embedded checkout (Eventbrite) */
.fdi-section--checkout .fdi-lead{ max-width: 820px; }
.fdi-eb{
  margin-top: 18px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  padding: 16px;
}
.fdi-eb__frame{
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.25);
  min-height: 425px;
}
.fdi-eb__note{
  margin-top: 10px;
  color: rgba(255,255,255,.70);
}


/* Lead Gate Modal */
.fdi-lead-modal{position:fixed;inset:0;display:none;z-index:99999}
.fdi-lead-modal.is-open{display:block}
.fdi-lead-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.68);backdrop-filter: blur(6px)}
.fdi-lead-modal__dialog{position:relative;max-width:520px;margin:6vh auto;background:linear-gradient(180deg, rgba(10,14,30,.96), rgba(5,8,20,.96));
border:1px solid rgba(212,175,55,.18);border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.55);padding:22px 18px}
@media(min-width:768px){.fdi-lead-modal__dialog{padding:26px 26px}}
.fdi-lead-modal__close{position:absolute;top:10px;right:12px;width:40px;height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.14);
background:rgba(255,255,255,.06);color:#fff;font-size:22px;cursor:pointer}
.fdi-lead-modal__close:focus{outline:2px solid rgba(46,211,255,.7);outline-offset:2px}
#fdi-lead-title{margin:0 0 6px 0;color:#fff;font-size:22px;letter-spacing:.2px}
.fdi-lead-sub{margin:0 0 14px 0;color:rgba(255,255,255,.82)}
.fdi-lead-form label{display:block;margin:10px 0}
.fdi-lead-form span{display:block;font-size:13px;color:rgba(255,255,255,.8);margin:0 0 6px}
.fdi-lead-form input{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
color:#fff;border-radius:14px;padding:12px 12px;font-size:15px}
.fdi-lead-form input:focus{outline:none;border-color:rgba(46,211,255,.6);box-shadow:0 0 0 4px rgba(46,211,255,.14)}
.fdi-lead-actions{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.fdi-lead-note{font-size:12px;color:rgba(255,255,255,.7)}
.fdi-lead-error{margin-top:8px;padding:10px 12px;border-radius:12px;background:rgba(255,70,70,.12);border:1px solid rgba(255,70,70,.25);color:#fff}
