/* ===== RESET & BASE ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeSpeed}
body{font-family:'DM Sans',sans-serif;background:#fff;overflow-x:clip;width:100%;max-width:100vw}

/* ===== LACES (site-wide SVG background curves) ===== */
.laces{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55}
.lc{fill:none;stroke-linecap:round}
.lc1{stroke:rgba(124,58,237,.12);stroke-width:1.3;stroke-dasharray:500 200;animation:lc-d1 18s linear infinite}
.lc2{stroke:rgba(168,85,247,.08);stroke-width:.9;stroke-dasharray:400 250;animation:lc-d2 22s linear infinite}
.lc3{stroke:rgba(192,132,252,.10);stroke-width:1.1;stroke-dasharray:450 180;animation:lc-d3 20s linear infinite}
@keyframes lc-d1{to{stroke-dashoffset:-1400}}
@keyframes lc-d2{to{stroke-dashoffset:1300}}
@keyframes lc-d3{to{stroke-dashoffset:-1200}}

/* ===== PERF — render below-fold sections lazily ===== */
.phrase-section,.events-section,.steps-section,.brands-section,.proof-section,
.partners-section,.faq-section,.final-cta{
  content-visibility:auto;contain-intrinsic-size:auto 600px;
}

/* ===== SHELL ===== */
.shell{
  padding:0 20px 20px;
  min-height:100dvh;
  display:flex;flex-direction:column;
  position:relative;z-index:1;
}

/* ===== BACKGROUND — ANIMATED CURVES (pass over all blocks) ===== */
.bg-canvas{
  position:fixed;inset:0;z-index:10;pointer-events:none;overflow:hidden;
  -webkit-transform:translateZ(0);transform:translateZ(0);
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
}
.bg-canvas svg{position:absolute;inset:0;width:100%;height:100%}
.curve{fill:none;stroke-linecap:round;will-change:opacity,stroke-width}
.curve{animation:curveGlow 6s ease-in-out infinite alternate}
.curve:nth-child(2n){animation-delay:-3s;animation-duration:8s}
.curve:nth-child(3n){animation-delay:-1.5s;animation-duration:7s}
@keyframes curveGlow{
  0%{opacity:.7;stroke-width:1}
  50%{opacity:1;stroke-width:1.8}
  100%{opacity:.7;stroke-width:1}
}

/* ===== NAV ===== */
.nav{
  position:sticky;top:0;z-index:100;
  padding:.6rem 1rem;
  display:flex;align-items:center;gap:.6rem;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  animation:fd .7s cubic-bezier(.16,1,.3,1) both;
  border-bottom:1px solid rgba(168,85,247,.04);
}

/* Burger — mobile only */
.burger{
  display:flex;flex-direction:column;gap:4px;
  width:28px;height:28px;
  align-items:center;justify-content:center;
  background:none;border:none;cursor:pointer;
  padding:4px;flex-shrink:0;order:0;
}
.burger span{
  display:block;width:18px;height:2px;
  background:#220a33;border-radius:2px;
  transition:all .3s cubic-bezier(.16,1,.3,1);
}
.burger.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* Logo */
.brand{
  font-family:'Outfit',sans-serif;font-weight:800;font-size:1.1rem;
  letter-spacing:-.04em;color:#220a33;
  display:flex;align-items:center;gap:.35rem;
  text-decoration:none;flex-shrink:0;cursor:pointer;
  order:1;
}
.brand-dot{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  box-shadow:0 0 0 0 rgba(168,85,247,.4);
  animation:logoPulse 2.5s ease-in-out infinite;
}
@keyframes logoPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(168,85,247,.4);transform:scale(1)}
  50%{box-shadow:0 0 0 6px rgba(168,85,247,0);transform:scale(1.2)}
}
.brand span{
  background:linear-gradient(135deg,#7c3aed 0%,#a855f7 50%,#c084fc 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

/* Search bar — full width on mobile */
.nav-search{
  position:relative;left:auto;top:auto;transform:none;
  flex:1;min-width:0;order:2;
}
.nav-search form{position:relative}
.nav-search input{
  width:100%;
  font-family:'DM Sans',sans-serif;font-size:.84rem;
  padding:.5rem 1rem .5rem 2.3rem;
  background:#f3eef8;border:1.5px solid transparent;
  border-radius:11px;outline:none;color:#220a33;
  transition:all .3s cubic-bezier(.16,1,.3,1);
}
.nav-search input::placeholder{color:rgba(34,10,51,.3)}
.nav-search input:focus{
  background:#fff;
  border-color:rgba(168,85,247,.2);
  box-shadow:0 0 0 3px rgba(168,85,247,.08),0 4px 16px rgba(34,10,51,.05);
}
.nav-search-icon{
  position:absolute;left:.75rem;top:50%;transform:translateY(-50%);
  width:14px;height:14px;color:rgba(34,10,51,.3);
  pointer-events:none;transition:color .3s;
}
.nav-search input:focus ~ .nav-search-icon{color:#a855f7}

/* Nav links — hidden on mobile */
.nav-links{
  display:none;
  align-items:center;gap:.15rem;
  padding:3px;border-radius:12px;
  background:rgba(168,85,247,.04);
  margin-left:1.5rem;
}
.nav-links a{
  font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;
  text-decoration:none;color:rgba(34,10,51,.45);
  padding:.45rem 1.1rem;border-radius:9px;
  transition:all .3s cubic-bezier(.16,1,.3,1);
  white-space:nowrap;
}
.nav-links a:hover{color:#220a33}
.nav-links a.active{
  color:#7c3aed;background:#fff;
  box-shadow:0 1px 4px rgba(34,10,51,.06);
}
/* CDM 2026 special nav button */
.nav-links a.nav-cdm{
  color:#fff;
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  font-weight:700;
  box-shadow:0 2px 10px rgba(124,58,237,.3);
  border-radius:20px;padding:.35rem 1rem;
  transition:all .3s;
  display:inline-flex;align-items:center;gap:5px;
}
.nav-links a.nav-cdm:hover{box-shadow:0 4px 16px rgba(124,58,237,.4);transform:translateY(-1px)}
.nav-links a.nav-cdm.active{color:#fff;background:linear-gradient(135deg,#6d28d9,#7c3aed)}
.nav-cdm img{width:18px;height:18px;object-fit:contain;border-radius:0}
/* Mobile CDM button */
.mobile-cdm{
  display:inline-flex;align-items:center;gap:6px;margin:8px 0;padding:10px 20px;border-radius:25px;
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:.92rem;
  color:#fff !important;text-decoration:none;
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  box-shadow:0 2px 12px rgba(124,58,237,.3);
  text-align:center;
}
.mobile-cdm img{width:20px;height:20px;object-fit:contain;border-radius:0}

/* Right side — hidden on mobile */
.nav-right{
  margin-left:auto;
  display:none;align-items:center;gap:.6rem;flex-shrink:0;
}
.nav-btn{
  font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:600;
  text-decoration:none;padding:.55rem 1.2rem;border-radius:10px;
  transition:all .3s cubic-bezier(.16,1,.3,1);cursor:pointer;
}
.nav-btn-ghost{
  color:rgba(34,10,51,.5);background:transparent;border:none;
}
.nav-btn-ghost:hover{color:#220a33;background:rgba(168,85,247,.06)}
.nav-btn-primary{
  color:#fff;border:none;
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  box-shadow:0 2px 8px rgba(124,58,237,.2);
}
.nav-btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(124,58,237,.3);
}

/* ===== MOBILE MENU OVERLAY ===== */
.mobile-menu{
  position:fixed;top:0;left:0;right:0;bottom:0;
  z-index:200;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:5rem 2rem 2rem;
  gap:.4rem;
  display:none !important;
  flex-direction:column;
  visibility:hidden;
  opacity:0;
  pointer-events:none;
}
.mobile-menu.open{
  display:flex !important;
  visibility:visible;
  opacity:1;
  pointer-events:auto;
}
.mobile-menu a{
  font-family:'DM Sans',sans-serif;font-size:1.3rem;font-weight:600;
  text-decoration:none;color:#220a33;
  padding:1rem 0;border-bottom:1px solid rgba(168,85,247,.06);
  transition:color .2s;
}
.mobile-menu a.active{color:#7c3aed}
.mobile-menu a:hover{color:#7c3aed}
.mobile-menu-btns{
  display:flex;gap:.6rem;margin-top:1.5rem;
}
.mobile-menu-btns .nav-btn{font-size:1rem;padding:.7rem 1.6rem}

/* ===== HERO — opaque gradient, curves pass over via bg-canvas z-index ===== */
.hero{
  position:relative;flex:none;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:2.5rem 1rem 2rem;
  overflow:visible;border-radius:18px;
  background:
    radial-gradient(ellipse 90% 70% at 50% 110%, rgba(124,58,237,.07) 0%, transparent 50%),
    radial-gradient(ellipse 50% 40% at 15% 20%, rgba(168,85,247,.05) 0%, transparent 50%),
    radial-gradient(ellipse 40% 35% at 85% 15%, rgba(192,132,252,.04) 0%, transparent 50%),
    linear-gradient(170deg, #fefcff 0%, #f8f4fc 35%, #f3eef8 65%, #ede5f5 100%);
  border:none;
}

/* No hero-specific laces — site bg-canvas curves show through */
.hero-laces{display:none}

/* ===== HERO CONTENT ===== */
.hero-content{position:relative;z-index:2;text-align:center;max-width:920px;width:100%;padding:0 .5rem}

/* Badge */
.hero-badge{
  display:inline-flex;align-items:center;gap:7px;
  font-weight:600;font-size:.72rem;color:#7c3aed;
  background:rgba(124,58,237,.06);border:1px solid rgba(124,58,237,.08);
  padding:6px 16px;border-radius:40px;margin-bottom:1.5rem;
  animation:fu .6s cubic-bezier(.16,1,.3,1) .1s both;
}
.badge-dot{width:7px;height:7px;background:#22c55e;border-radius:50%;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 2px rgba(34,197,94,.15)}50%{box-shadow:0 0 0 6px rgba(34,197,94,.04)}}

/* Headline */
.headline{
  font-family:'Outfit',sans-serif;font-weight:900;
  font-size:clamp(2.4rem,7vw,6rem);
  line-height:1.04;color:#1a0e2e;margin-bottom:12px;
  animation:fu .7s cubic-bezier(.16,1,.3,1) .15s both;
}

/* Ticket wrap */
.tk-wrap{display:inline-block;position:relative;margin-top:6px}
.tk-border{
  display:inline-block;position:relative;
  transform:rotate(-2.5deg);
  animation:tkIn .9s cubic-bezier(.16,1,.3,1) .35s both;
}
.ticket{
  position:relative;display:inline-flex;align-items:center;
  background:linear-gradient(135deg,#7c3aed 0%,#a855f7 50%,#c084fc 100%);
  color:#fff;font-family:'Outfit',sans-serif;font-weight:900;
  font-size:clamp(2.2rem,6.5vw,5.6rem);
  padding:10px 50px 10px 42px;border-radius:16px;
  cursor:default;white-space:nowrap;line-height:1.08;
  box-shadow:0 16px 50px rgba(124,58,237,.22),0 4px 14px rgba(124,58,237,.1),inset 0 1px 0 rgba(255,255,255,.15);
}
/* Right notch */
.ticket::after{
  content:'';position:absolute;top:50%;right:-11px;transform:translateY(-50%);
  width:22px;height:22px;background:#f3eef8;border-radius:50%;
  box-shadow:inset 0 2px 4px rgba(0,0,0,.06);
}
/* Left notch */
.tk-notch{
  position:absolute;top:50%;left:-11px;transform:translateY(-50%);
  width:22px;height:22px;background:#f3eef8;border-radius:50%;
  box-shadow:inset 0 2px 4px rgba(0,0,0,.06);z-index:3;
}
.tk-perf{position:absolute;left:28px;top:10px;bottom:10px;border-left:2px dashed rgba(255,255,255,.22)}
.tk-bar{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;gap:1.5px;opacity:.18}
.tk-bar i{display:block;width:2px;background:#fff;border-radius:1px}
.tk-text{position:relative;z-index:2}
.tk-lbl{
  position:absolute;top:-12px;right:14px;z-index:4;
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:.52rem;
  text-transform:uppercase;letter-spacing:.14em;
  color:#7c3aed;background:#fff;
  padding:3px 10px;border-radius:20px;
  box-shadow:0 2px 8px rgba(0,0,0,.06);transform:rotate(-2.5deg);
  display:none;
}
.tk-meta{
  position:absolute;bottom:-12px;left:50%;transform:translateX(-50%) rotate(-2.5deg);z-index:4;
  display:none;gap:10px;
  font-family:'DM Sans',sans-serif;font-size:.48rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;color:rgba(124,58,237,.35);
  background:#fff;padding:3px 12px;border-radius:20px;
  box-shadow:0 2px 8px rgba(0,0,0,.04);white-space:nowrap;
}
.tk-meta em{font-style:normal;color:#7c3aed}
/* Shine sweep */
.tk-shine{position:absolute;inset:0;border-radius:16px;overflow:hidden;pointer-events:none;z-index:2}
.tk-shine::after{
  content:'';position:absolute;top:0;left:-120%;
  width:50%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  transform:skewX(-20deg);animation:shine 7s ease-in-out 2s infinite;
}
@keyframes shine{0%{left:-120%}25%{left:160%}100%{left:160%}}
@keyframes tkIn{from{opacity:0;transform:rotate(-8deg) translateY(40px) scale(.85)}to{opacity:1;transform:rotate(-2.5deg) translateY(0) scale(1)}}

/* Subtitle */
.subtitle{
  font-family:'DM Sans',sans-serif;
  font-size:clamp(.88rem,1.4vw,1.05rem);font-weight:400;
  color:#9a8aad;max-width:780px;margin:28px auto 0;
  line-height:1.8;letter-spacing:.015em;text-align:center;
  animation:fu .7s cubic-bezier(.16,1,.3,1) .45s both;
}
.subtitle strong{color:#5a4a6b;font-weight:500}

/* CTA zone — search bar */
.cta-zone{
  margin-top:32px;display:flex;flex-direction:column;align-items:center;gap:14px;
  animation:fu .7s cubic-bezier(.16,1,.3,1) .55s both;
}
.search-bar{
  display:flex;align-items:center;
  background:#fff;border:2px solid rgba(124,58,237,.07);
  border-radius:60px;padding:4px 4px 4px 20px;
  width:100%;max-width:560px;
  box-shadow:0 6px 28px rgba(0,0,0,.04);
  transition:all .3s cubic-bezier(.16,1,.3,1);
}
.search-bar:focus-within{border-color:rgba(124,58,237,.18);box-shadow:0 8px 36px rgba(124,58,237,.08),0 4px 16px rgba(0,0,0,.03)}
.s-ico{flex-shrink:0;width:20px;height:20px;stroke:#9a8aad;fill:none;stroke-width:2;stroke-linecap:round;margin-right:10px;transition:stroke .3s}
.search-bar:focus-within .s-ico{stroke:#7c3aed}
.search-bar input{
  flex:1;min-width:0;border:none;outline:none;background:transparent;
  font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:500;
  padding:12px 0;color:#1a0e2e;
}
.search-bar input::placeholder{color:rgba(26,14,46,.22);font-size:.82rem}
.search-bar button{
  flex-shrink:0;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:700;
  color:#fff;background:linear-gradient(135deg,#7c3aed,#9333ea);
  padding:12px 26px;border-radius:54px;border:none;cursor:pointer;
  box-shadow:0 4px 16px rgba(124,58,237,.22);transition:all .25s;white-space:nowrap;
}
.search-bar button:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(124,58,237,.32)}

/* Popular tags */
.popular{display:flex;align-items:center;gap:7px;flex-wrap:wrap;justify-content:center}
.pop-lbl{font-size:.72rem;color:#9a8aad;font-weight:500}
.pop-t{
  font-size:.7rem;font-weight:600;color:#7c3aed;
  background:rgba(124,58,237,.05);padding:5px 12px;border-radius:18px;
  border:none;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .2s;
}
.pop-t:hover{background:rgba(124,58,237,.1)}

/* Trust bar */
.trust{
  margin-top:2.5rem;display:flex;align-items:center;justify-content:center;
  gap:22px;flex-wrap:wrap;
  animation:fu .6s cubic-bezier(.16,1,.3,1) .75s both;
}
.tr{display:flex;align-items:center;gap:5px;font-size:.76rem;color:#8a7a9a;font-weight:500}
.tr svg{width:13px;height:13px;stroke:#7c3aed;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
/* Legacy trust classes */
.trust-item{display:flex;align-items:center;gap:5px;font-size:.72rem;color:#8a7a9a;font-weight:500}
.trust-icon{width:14px;height:14px;stroke:#7c3aed;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* Floating cards — hidden on mobile, shown on desktop */
.fl{
  position:absolute;z-index:3;
  background:rgba(255,255,255,.8);backdrop-filter:blur(12px);
  border:1px solid rgba(124,58,237,.05);border-radius:12px;
  padding:10px 14px;box-shadow:0 6px 22px rgba(0,0,0,.04);
  pointer-events:none;font-size:.68rem;color:#5a4a6b;
  opacity:.7;display:none;
}
.fl strong{display:block;font-size:.75rem;color:#1a0e2e;margin-bottom:1px;font-weight:700}
.fl .ft{display:inline-block;margin-top:3px;font-size:.52rem;font-weight:700;padding:2px 7px;border-radius:16px}
.ft-g{background:rgba(34,197,94,.08);color:#16a34a}
.ft-o{background:rgba(249,115,22,.08);color:#ea580c}
.ft-b{background:rgba(59,130,246,.08);color:#2563eb}
.f1{top:14%;left:4%;transform:rotate(-4deg)}
.f4{bottom:16%;right:4%;transform:rotate(-3deg)}

/* Old hero elements — hide */
.bg-mesh,.grain,.center,.ribbon,.form-card,.under,.proof,.stats,.float-card,.notif-toast,.notif-icon,.notif-text,.notif-time,.orb,.orb-a,.orb-b,.hero-laces,.btn-main,.btn-alt,.cta-row,.ticket-line,.sparkles,.sp,.ticket-label,.ticket-meta,.ticket-perf,.ticket-barcode{display:none}
h1 em{font-style:normal;background:linear-gradient(135deg,#a855f7 0%,#c084fc 40%,#e9d5ff 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
h1 span{display:block}

.desc{
  font-family:'DM Sans',sans-serif;
  font-size:clamp(1rem,1.6vw,1.15rem);line-height:1.8;font-weight:400;
  color:rgba(255,255,255,.5);max-width:640px;margin:0 auto 1.5rem;
  animation:fu .6s cubic-bezier(.16,1,.3,1) .4s both;letter-spacing:.01em;
}
.desc strong{font-weight:600;color:rgba(255,255,255,.75)}

/* ===== FORM ===== */
.form-card{
  display:inline-flex;align-items:stretch;flex-direction:column;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:4px;gap:0;max-width:680px;width:100%;
  animation:fu .6s cubic-bezier(.16,1,.3,1) .55s both;
  transition:border-color .3s,box-shadow .3s;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 4px 24px rgba(0,0,0,.15);
}
.form-card:focus-within{
  border-color:rgba(168,85,247,.4);
  box-shadow:0 0 0 3px rgba(168,85,247,.15),0 8px 30px rgba(0,0,0,.2);
}
.form-card input{
  flex:1;min-width:0;font-family:'DM Sans',sans-serif;font-size:1rem;
  padding:.85rem 1rem;background:transparent;border:none;outline:none;color:#fff;
}
.form-card input::placeholder{color:rgba(255,255,255,.3)}
.form-card button{
  font-family:'DM Sans',sans-serif;font-size:.92rem;font-weight:700;
  padding:.85rem;white-space:nowrap;
  background:linear-gradient(135deg,#7c3aed 0%,#a855f7 50%,#c084fc 100%);
  color:#fff;border:none;border-radius:14px;cursor:pointer;
  transition:all .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;
  box-shadow:0 3px 16px rgba(124,58,237,.4);
}
.form-card button:hover{transform:translateY(-1px);box-shadow:0 6px 28px rgba(124,58,237,.55)}
.form-card button:active{transform:scale(.97)}

.under{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;
  margin-top:1.4rem;animation:fu .6s cubic-bezier(.16,1,.3,1) .68s both;
}
.under a{
  font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:600;
  color:#c084fc;text-decoration:none;display:inline-flex;align-items:center;gap:.35rem;
  transition:all .3s cubic-bezier(.16,1,.3,1);
}
.under a:hover{color:#fff}
.under a svg{transition:transform .3s cubic-bezier(.16,1,.3,1)}
.under a:hover svg{transform:translateX(3px)}
.under small{font-size:.88rem;color:rgba(255,255,255,.35)}
.dot-sep{display:none}

/* ===== SOCIAL PROOF ===== */
.proof{
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;
  margin-top:3rem;animation:fu .6s cubic-bezier(.16,1,.3,1) .82s both;
}
.avatars{display:flex}
.avatars span{
  width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.15);
  margin-left:-8px;display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:600;color:#fff;
}
.avatars span:first-child{margin-left:0}
.av1{background:linear-gradient(135deg,#a855f7,#7c3aed)}
.av2{background:linear-gradient(135deg,#c084fc,#a855f7)}
.av3{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}
.av4{background:rgba(255,255,255,.1);color:rgba(255,255,255,.5)!important;font-size:.62rem!important}
.proof p{font-size:1rem;color:rgba(255,255,255,.45)}
.proof p strong{color:#fff;font-weight:700}

/* ===== STATS ===== */
.stats{
  position:relative;z-index:3;
  display:none;justify-content:center;gap:1.5rem;flex-wrap:wrap;
  margin-top:4.5rem;animation:fu .6s cubic-bezier(.16,1,.3,1) .95s both;
}
.st{text-align:center;min-width:30%}
.st-n{
  font-family:'Outfit',sans-serif;font-size:clamp(2.2rem,3.8vw,3rem);
  font-weight:800;letter-spacing:-.03em;color:#fff;line-height:1;
}
.st-n em{font-style:normal;color:#c084fc}
.st-l{font-size:.88rem;color:rgba(255,255,255,.35);margin-top:.5rem;font-weight:400;letter-spacing:.02em}

/* ===== KEYFRAMES ===== */
@keyframes fu{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fd{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes bk{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.65)}}

/* ===== SCROLL REVEAL ===== */
.rv{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.rv.vis{opacity:1;transform:translateY(0)}
.rv-d1{transition-delay:.1s}
.rv-d2{transition-delay:.2s}
.rv-d3{transition-delay:.3s}

/* ===== PHRASE SECTION ===== */
.phrase-section{text-align:center;padding:4rem 1rem 1rem}
.phrase-label{
  font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:600;
  color:#a855f7;letter-spacing:.06em;text-transform:uppercase;margin-bottom:1.2rem;
}
.phrase-section h2{
  font-family:'Outfit',sans-serif;font-size:clamp(2.6rem,6vw,4.5rem);
  font-weight:800;line-height:1.05;letter-spacing:-.045em;color:#220a33;max-width:800px;margin:0 auto;
}
.phrase-section h2 em{
  font-style:normal;
  background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

/* ===== FEATURE GRID ===== */
.feat-grid{
  display:grid;grid-template-columns:1fr;gap:1.5rem;
  max-width:1100px;margin:0 auto;padding:1.5rem 1rem 3.5rem;
}
.feat-visual{
  position:relative;border-radius:20px;overflow:hidden;aspect-ratio:5/4;
}
.feat-visual-inner{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:2rem;
}
.feat-visual.grad-1{
  background:
    radial-gradient(ellipse 60% 70% at 20% 80%,rgba(168,85,247,.25) 0%,transparent 70%),
    radial-gradient(ellipse 50% 60% at 80% 30%,rgba(192,132,252,.2) 0%,transparent 70%),
    radial-gradient(ellipse 70% 50% at 50% 50%,rgba(216,180,254,.2) 0%,transparent 60%),
    #f3eef8;
}
.feat-visual.grad-2{
  background:
    radial-gradient(ellipse 55% 65% at 75% 75%,rgba(255,96,240,.15) 0%,transparent 70%),
    radial-gradient(ellipse 60% 55% at 25% 35%,rgba(200,82,255,.18) 0%,transparent 65%),
    radial-gradient(ellipse 50% 50% at 55% 20%,rgba(168,85,247,.12) 0%,transparent 60%),
    #f5eef8;
}

/* Mock email */
.mock-email{
  background:#fff;border-radius:12px;
  box-shadow:0 12px 48px rgba(34,10,51,.1),0 1px 3px rgba(34,10,51,.06);
  width:100%;max-width:380px;overflow:hidden;
  animation:emailSlideIn 1s cubic-bezier(.16,1,.3,1) .3s both;
}
@keyframes emailSlideIn{from{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.mock-email-bar{display:flex;align-items:center;gap:.5rem;padding:.55rem 1rem;background:#f8f8f8;border-bottom:1px solid #eee}
.mock-email-dots{display:flex;gap:5px}
.mock-email-dots span{width:8px;height:8px;border-radius:50%}
.mock-email-dots span:nth-child(1){background:#ff5f57}
.mock-email-dots span:nth-child(2){background:#ffbd2e}
.mock-email-dots span:nth-child(3){background:#28c840}
.mock-email-bar small{font-family:'DM Sans',sans-serif;font-size:.6rem;color:rgba(0,0,0,.3);margin-left:auto}
.mock-email-header{padding:1rem 1.2rem .6rem;border-bottom:1px solid #f0f0f0}
.mock-email-subject{font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:700;color:#1a1a1a;margin-bottom:.4rem}
.mock-email-meta{display:flex;align-items:center;gap:.45rem}
.mock-email-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#a855f7,#7c3aed);display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-size:.55rem;font-weight:800;color:#fff;flex-shrink:0}
.mock-email-from{font-family:'DM Sans',sans-serif;font-size:.7rem;color:#888}
.mock-email-from strong{color:#1a1a1a}
.mock-email-body{padding:.8rem 1.2rem 1rem}
.mock-email-body p{font-family:'DM Sans',sans-serif;font-size:.75rem;color:#555;line-height:1.6;margin-bottom:.6rem}
.mock-email-cta{
  display:inline-block;font-family:'DM Sans',sans-serif;font-size:.7rem;font-weight:600;
  background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;
  padding:.45rem 1.1rem;border-radius:8px;text-decoration:none;
}

/* Notification toast */
.notif-toast{
  position:absolute;top:1.2rem;right:1.2rem;
  background:#fff;border-radius:12px;padding:.6rem .8rem;
  box-shadow:0 8px 32px rgba(34,10,51,.12),0 1px 3px rgba(34,10,51,.08);
  display:flex;align-items:center;gap:.5rem;
  animation:toastIn .5s cubic-bezier(.16,1,.3,1) 1.2s both,toastPulse 2s ease-in-out 1.7s infinite;z-index:5;
}
.notif-toast-icon{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#a855f7,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:.7rem;flex-shrink:0}
.notif-toast-text{font-family:'DM Sans',sans-serif;font-size:.6rem;color:#220a33;font-weight:600;line-height:1.3}
.notif-toast-text small{display:block;font-weight:400;color:#999;font-size:.5rem;margin-top:1px}
.notif-toast-time{font-family:'DM Sans',sans-serif;font-size:.5rem;color:#a855f7;font-weight:600;white-space:nowrap}
@keyframes toastIn{from{opacity:0;transform:translateX(20px) scale(.9)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes toastPulse{0%,100%{box-shadow:0 8px 32px rgba(34,10,51,.12)}50%{box-shadow:0 8px 32px rgba(168,85,247,.2)}}

/* Timer badge */
.timer-badge{
  position:absolute;bottom:1.2rem;right:1.2rem;
  background:rgba(255,255,255,.95);border-radius:10px;padding:.5rem .75rem;
  box-shadow:0 4px 20px rgba(34,10,51,.08);display:flex;align-items:center;gap:.4rem;
  animation:emailSlideIn .6s cubic-bezier(.16,1,.3,1) 1.6s both;z-index:5;
}
.timer-badge-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:bk 1s ease-in-out infinite}
.timer-badge span{font-family:'Outfit',sans-serif;font-size:.75rem;font-weight:700;color:#220a33}

/* Mock dashboard */
.mock-dash{
  background:#fff;border-radius:14px;
  box-shadow:0 12px 48px rgba(34,10,51,.1),0 1px 3px rgba(34,10,51,.06);
  width:100%;max-width:360px;overflow:hidden;
  animation:emailSlideIn 1s cubic-bezier(.16,1,.3,1) .3s both;
}
.mock-dash-header{padding:.8rem 1.1rem;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between}
.mock-dash-header strong{font-family:'DM Sans',sans-serif;font-size:.75rem;color:#220a33}
.mock-dash-live{display:flex;align-items:center;gap:.3rem;font-family:'DM Sans',sans-serif;font-size:.6rem;font-weight:600;color:#22c55e}
.mock-dash-live span{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:bk 1.6s ease-in-out infinite}
.mock-dash-progress{height:2px;background:#f3eef8;position:relative;overflow:hidden}
.mock-dash-progress::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,#7c3aed,#a855f7,#c084fc);
  animation:scanBar 3s ease-in-out infinite;transform-origin:left;
}
@keyframes scanBar{0%{transform:scaleX(0);opacity:1}50%{transform:scaleX(1);opacity:1}51%{transform:scaleX(1);opacity:0}100%{transform:scaleX(0);opacity:0}}
.mock-dash-body{padding:.8rem 1rem}
.mock-dash-row{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;border-bottom:1px solid #f5f2f8;animation:rowFade .5s cubic-bezier(.16,1,.3,1) both}
.mock-dash-row:nth-child(1){animation-delay:.6s}
.mock-dash-row:nth-child(2){animation-delay:1.2s}
.mock-dash-row:nth-child(3){animation-delay:1.8s}
.mock-dash-row:last-child{border-bottom:none}
@keyframes rowFade{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}
.mock-dash-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0}
.mock-dash-icon.ic-1{background:#f3eef8;color:#a855f7}
.mock-dash-icon.ic-2{background:#edf5f0;color:#22c55e}
.mock-dash-icon.ic-3{background:#fff4ee;color:#f97316}
.mock-dash-info{flex:1;min-width:0}
.mock-dash-info strong{font-family:'DM Sans',sans-serif;font-size:.65rem;font-weight:600;color:#220a33;display:block}
.mock-dash-info small{font-family:'DM Sans',sans-serif;font-size:.52rem;color:#999}
.mock-dash-badge{font-family:'DM Sans',sans-serif;font-size:.5rem;font-weight:600;padding:.2rem .5rem;border-radius:99px}
.badge-ok{background:#edfcf2;color:#16a34a}
.badge-scan{background:#f3eef8;color:#a855f7;animation:badgePulse 1.5s ease-in-out infinite}
@keyframes badgePulse{0%,100%{opacity:1}50%{opacity:.4}}
.badge-found{background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;animation:badgeFound .4s cubic-bezier(.16,1,.3,1) both}
@keyframes badgeFound{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.mock-dash-footer{padding:.6rem 1.1rem;border-top:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between}
.mock-dash-footer small{font-family:'DM Sans',sans-serif;font-size:.55rem;color:#bbb}
.mock-dash-footer strong{font-family:'Outfit',sans-serif;font-size:.8rem;font-weight:700;color:#a855f7}
.scan-counter{
  position:absolute;top:1.2rem;right:1.2rem;
  background:#fff;border-radius:10px;padding:.5rem .8rem;
  box-shadow:0 6px 24px rgba(34,10,51,.1);display:flex;align-items:center;gap:.4rem;
  animation:toastIn .5s cubic-bezier(.16,1,.3,1) 2.4s both;z-index:5;
}
.scan-counter span{font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:800;color:#a855f7}
.scan-counter small{font-family:'DM Sans',sans-serif;font-size:.5rem;color:#999;line-height:1.2}

.feat-text{padding:1.2rem .2rem .5rem}
.feat-text h3{font-family:'Outfit',sans-serif;font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:#220a33;line-height:1.2;margin-bottom:.4rem}
.feat-text p{font-family:'DM Sans',sans-serif;font-size:.95rem;line-height:1.6;font-weight:400;color:rgba(34,10,51,.45);max-width:460px}

/* ===== EVENTS SECTION ===== */
.events-section{padding:3rem 0 4rem;max-width:1260px;margin:0 auto;position:relative}
.events-section::before{
  content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:80%;height:1px;background:linear-gradient(90deg,transparent,rgba(168,85,247,.15),transparent);
}
.events-header{text-align:center;margin-bottom:2.5rem;padding:0 2rem}
.events-header .phrase-label{margin-bottom:1.2rem}
.events-header h2{
  font-family:'Outfit',sans-serif;font-size:clamp(2.8rem,6.5vw,4.8rem);
  font-weight:800;line-height:1;letter-spacing:-.05em;color:#220a33;margin-bottom:1.2rem;
}
.events-header h2 em{
  font-style:normal;
  background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.events-header p{font-family:'DM Sans',sans-serif;font-size:1.1rem;line-height:1.7;color:rgba(34,10,51,.45);max-width:540px;margin:0 auto}

/* Link reset for event cards */
a.ev-card-big,a.ev-card{display:flex;text-decoration:none;color:inherit}
a.ev-card-big{display:block}

/* Featured hero card */
.ev-featured{margin:0 1rem 1rem}
.ev-card-big{
  position:relative;border-radius:24px;overflow:hidden;height:280px;cursor:pointer;
  transition:all .5s cubic-bezier(.16,1,.3,1);
}
.ev-card-big:hover{transform:translateY(-4px);box-shadow:0 24px 64px rgba(124,58,237,.18)}
.ev-card-big img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.ev-card-big:hover img{transform:scale(1.04)}
.ev-card-big::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(34,10,51,.75) 0%,rgba(34,10,51,.15) 40%,transparent 70%);
}
.ev-card-big .ev-big-content{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  padding:1.5rem;display:flex;flex-direction:column;align-items:flex-start;gap:1rem;
}
.ev-big-left{flex:1}
.ev-big-badges{display:flex;gap:.5rem;margin-bottom:.8rem}
.ev-big-badges span{font-family:'DM Sans',sans-serif;font-size:.65rem;font-weight:700;padding:.35rem .75rem;border-radius:99px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.ev-badge{font-family:'DM Sans',sans-serif;font-size:.6rem;font-weight:700;padding:.3rem .65rem;border-radius:99px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.ev-badge-live{background:rgba(34,197,94,.2);color:#22c55e;border:1px solid rgba(34,197,94,.25)}
.ev-badge-soon{background:rgba(168,85,247,.2);color:#a855f7;border:1px solid rgba(168,85,247,.25)}
.ev-badge-cat{font-family:'DM Sans',sans-serif;font-size:.6rem;font-weight:600;padding:.3rem .65rem;border-radius:99px;background:rgba(255,255,255,.18);color:#fff;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.ev-big-title{font-family:'Outfit',sans-serif;font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.03em;line-height:1.1;margin-bottom:.5rem}
.ev-big-info{display:flex;align-items:center;gap:1.2rem;font-family:'DM Sans',sans-serif;font-size:.85rem;color:rgba(255,255,255,.7)}
.ev-big-info span{display:flex;align-items:center;gap:.3rem}
.ev-big-info svg{width:14px;height:14px;opacity:.7}
.ev-big-right{display:flex;align-items:flex-start;gap:.6rem}
.ev-big-price{font-family:'Outfit',sans-serif;font-size:2rem;font-weight:800;color:#fff;line-height:1}
.ev-big-price small{font-size:.7rem;font-weight:400;opacity:.6;display:block}
.ev-big-hype{display:flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.12);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:.4rem .7rem;border-radius:99px}
.ev-big-hype-bar{width:80px;height:6px;border-radius:99px;background:rgba(255,255,255,.15);overflow:hidden}
.ev-big-hype-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,#7c3aed,#a855f7,#c084fc)}
.ev-big-hype small{font-family:'DM Sans',sans-serif;font-size:.6rem;font-weight:700;color:rgba(255,255,255,.8)}

/* MOBILE: compact event list */
.events-grid{
  display:flex;flex-direction:column;gap:.8rem;
  margin:0;padding:0 1rem;
}
.ev-card{
  position:relative;border-radius:14px;overflow:hidden;background:#fff;
  border:1px solid rgba(168,85,247,.06);
  transition:all .45s cubic-bezier(.16,1,.3,1);cursor:pointer;
  display:flex;flex-direction:row;align-items:stretch;
}
.ev-card:hover{box-shadow:0 8px 24px rgba(124,58,237,.08);border-color:rgba(168,85,247,.15)}
.ev-img{position:relative;width:110px;min-height:100%;overflow:hidden;flex-shrink:0}
.ev-img img{width:100%;height:100%;object-fit:cover}
.ev-img::after{content:none}
.ev-cat{position:absolute;top:.5rem;left:.5rem;z-index:2;font-family:'DM Sans',sans-serif;font-size:.5rem;font-weight:600;padding:.2rem .45rem;border-radius:99px;background:rgba(0,0,0,.5);color:#fff;backdrop-filter:blur(6px)}
.ev-date-float{position:absolute;bottom:.5rem;right:.5rem;z-index:2;background:rgba(255,255,255,.95);border-radius:8px;padding:.25rem .4rem;text-align:center;min-width:36px;box-shadow:0 2px 8px rgba(34,10,51,.1)}
.ev-date-float strong{font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:800;color:#220a33;display:block;line-height:1}
.ev-date-float small{font-family:'DM Sans',sans-serif;font-size:.42rem;font-weight:600;color:#a855f7;text-transform:uppercase;letter-spacing:.04em}
.ev-body{padding:.8rem .9rem;display:flex;flex-direction:column;justify-content:center;flex:1;min-width:0}
.ev-title{font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:700;color:#220a33;letter-spacing:-.02em;line-height:1.25;margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ev-meta{display:flex;align-items:center;gap:.3rem;font-family:'DM Sans',sans-serif;font-size:.6rem;color:rgba(34,10,51,.4);margin-bottom:.4rem}
.ev-meta svg{width:10px;height:10px;opacity:.5;flex-shrink:0}
.ev-footer{display:flex;align-items:center;justify-content:space-between}
.ev-price{font-family:'Outfit',sans-serif;font-size:.92rem;font-weight:800;color:#7c3aed}
.ev-price small{font-weight:400;font-size:.55rem;color:rgba(34,10,51,.3)}
.ev-hype{display:flex;align-items:center;gap:.3rem}
.ev-hype-bar{width:40px;height:4px;border-radius:99px;background:rgba(168,85,247,.08);overflow:hidden}
.ev-hype-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,#7c3aed,#a855f7,#c084fc)}
.ev-hype small{font-family:'DM Sans',sans-serif;font-size:.5rem;font-weight:600;color:rgba(34,10,51,.3)}
.ev-card .ev-badge{display:none}

/* Category filters */
.events-cats{
  display:flex;gap:.5rem;margin:1.5rem 0 0;padding:0 1rem;
  overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.events-cats::-webkit-scrollbar{display:none}
.ev-cat-btn{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:600;
  padding:.5rem 1.1rem;border-radius:99px;
  border:1px solid rgba(168,85,247,.12);background:#fff;color:#220a33;
  cursor:pointer;text-decoration:none;transition:all .4s cubic-bezier(.16,1,.3,1);
  white-space:nowrap;flex-shrink:0;
}
.ev-cat-btn:hover{border-color:rgba(168,85,247,.3);background:rgba(168,85,247,.06);transform:translateY(-2px);box-shadow:0 8px 24px rgba(124,58,237,.08)}
.ev-cat-btn.active{background:linear-gradient(135deg,#7c3aed 0%,#a855f7 50%,#c084fc 100%);color:#fff;border-color:transparent;box-shadow:0 6px 20px rgba(124,58,237,.25)}

/* Events CTA */
.events-cta{text-align:center;margin-top:2.5rem;padding:0 2rem}
.events-cta a{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:'DM Sans',sans-serif;font-size:1.05rem;font-weight:700;
  color:#fff;text-decoration:none;padding:1.1rem 2.8rem;border-radius:18px;
  background:linear-gradient(135deg,#7c3aed 0%,#a855f7 50%,#c084fc 100%);
  box-shadow:0 6px 28px rgba(124,58,237,.3);transition:all .35s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;
}
.events-cta a::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 50%);opacity:0;transition:opacity .3s}
.events-cta a:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(124,58,237,.4)}
.events-cta a:hover::before{opacity:1}
.events-cta a svg{transition:transform .3s cubic-bezier(.16,1,.3,1)}
.events-cta a:hover svg{transform:translateX(4px)}

/* ===== STEPS SECTION — Glass morphism cards ===== */
.steps-section{padding:4rem 1rem 3rem;max-width:1100px;margin:0 auto}
.steps-header{text-align:center;margin-bottom:4.5rem}
.steps-header .phrase-label{margin-bottom:1.2rem}
.steps-header h2{font-family:'Outfit',sans-serif;font-size:clamp(2.4rem,5.5vw,3.8rem);font-weight:800;line-height:1.05;letter-spacing:-.045em;color:#220a33}
.steps-header h2 em{font-style:normal;background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.steps-row{display:flex;flex-direction:column;gap:1rem}
.step-tl{
  flex:1;position:relative;padding:2rem 1.4rem 1.6rem;border-radius:24px;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(168,85,247,.08);
  transition:all .5s cubic-bezier(.16,1,.3,1);overflow:hidden;
  box-shadow:0 4px 20px rgba(34,10,51,.04);
}
.step-tl::before{
  content:'';position:absolute;inset:0;border-radius:24px;opacity:0;
  background:linear-gradient(145deg,rgba(124,58,237,.06),rgba(192,132,252,.03),transparent);
  transition:opacity .4s;
}
.step-tl::after{
  content:'';position:absolute;top:-50%;right:-30%;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(168,85,247,.06) 0%,transparent 70%);
  pointer-events:none;transition:all .5s;
}
.step-tl:hover::before{opacity:1}
.step-tl:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(124,58,237,.1);border-color:rgba(168,85,247,.18)}
.step-tl:hover::after{transform:scale(1.5);opacity:.8}
.step-tl-num{
  font-family:'Outfit',sans-serif;font-size:3rem;font-weight:800;line-height:1;
  background:linear-gradient(135deg,#7c3aed,#a855f7,#c084fc);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:.6rem;position:relative;z-index:1;
}
.step-tl h3{font-family:'Outfit',sans-serif;font-size:1.25rem;font-weight:700;color:#220a33;letter-spacing:-.02em;margin-bottom:.5rem;position:relative;z-index:1}
.step-tl>p{font-family:'DM Sans',sans-serif;font-size:.88rem;line-height:1.7;color:rgba(34,10,51,.4);position:relative;z-index:1;margin-bottom:1.2rem}
.step-mock{border-radius:14px;overflow:hidden;background:#f8f6fc;border:1px solid rgba(168,85,247,.06);position:relative;z-index:1}
.step-mock-row{display:flex;align-items:center;gap:.5rem;padding:.6rem .8rem;border-bottom:1px solid rgba(168,85,247,.04)}
.step-mock-row:last-child{border-bottom:none}
.step-mock-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.step-mock-dot.green{background:#10b981}
.step-mock-dot.violet{background:#a855f7;animation:mockPulse 2s ease-in-out infinite}
.step-mock-dot.amber{background:#f59e0b}
.step-mock-text{font-family:'DM Sans',sans-serif;font-size:.68rem;color:rgba(34,10,51,.45);flex:1}
.step-mock-tag{font-family:'DM Sans',sans-serif;font-size:.58rem;font-weight:700;padding:.15rem .5rem;border-radius:100px}
.step-mock-tag.live{background:rgba(16,185,129,.1);color:#059669}
.step-mock-tag.scan{background:rgba(168,85,247,.08);color:#7c3aed}
.step-mock-tag.alert{background:rgba(245,158,11,.1);color:#d97706}
.step-mock-scan-bar{height:2px;background:rgba(168,85,247,.08);position:relative;overflow:hidden;margin:0 .8rem}
.step-mock-scan-bar::after{content:'';position:absolute;top:0;left:0;width:40%;height:100%;background:linear-gradient(90deg,transparent,#a855f7,transparent);animation:scanLine 1.5s ease-in-out infinite}
.step-mock-toast{display:flex;align-items:center;gap:.4rem;padding:.5rem .8rem;background:linear-gradient(135deg,rgba(124,58,237,.06),rgba(192,132,252,.03));animation:toastPulse 3s ease-in-out infinite}
.step-mock-toast span{font-family:'DM Sans',sans-serif;font-size:.62rem;font-weight:600;color:#7c3aed}
@keyframes mockPulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
@keyframes scanLine{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}
.step-arrow{display:none}

/* ===== BRANDS SECTION ===== */
.brands-section{padding:3rem 1rem;text-align:center;max-width:1100px;margin:0 auto}
.brands-section .phrase-label{margin-bottom:1.2rem}
.brands-section h2{font-family:'Outfit',sans-serif;font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;line-height:1.05;letter-spacing:-.045em;color:#220a33;margin-bottom:.8rem}
.brands-section h2 em{font-style:normal;background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.brands-section>p{font-family:'DM Sans',sans-serif;font-size:1rem;color:rgba(34,10,51,.4);max-width:440px;margin:0 auto 3rem}
.brands-row{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}
.brands-row img{height:28px;object-fit:contain;opacity:.3;filter:grayscale(1);transition:all .4s cubic-bezier(.16,1,.3,1)}
.brands-row img:hover{opacity:1;filter:grayscale(0);transform:scale(1.1)}

/* ===== PROOF / AVIS SCROLLING ===== */
.proof-section{padding:3rem 0;overflow:hidden;max-width:100%}
.proof-header{text-align:center;margin-bottom:3rem;padding:0 2rem}
.proof-header .phrase-label{margin-bottom:1.2rem}
.proof-header h2{font-family:'Outfit',sans-serif;font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;line-height:1.05;letter-spacing:-.045em;color:#220a33}
.proof-header h2 em{font-style:normal;background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.proof-scroll{position:relative}
.proof-scroll::before,.proof-scroll::after{content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none}
.proof-scroll::before{left:0;background:linear-gradient(90deg,#fff,transparent)}
.proof-scroll::after{right:0;background:linear-gradient(-90deg,#fff,transparent)}
.proof-track{display:flex;gap:1.2rem;width:max-content;animation:proofScroll 45s linear infinite}
.proof-track:hover{animation-play-state:paused}
@keyframes proofScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.proof-card{width:300px;flex-shrink:0;background:#fff;border:1px solid rgba(168,85,247,.06);border-radius:18px;padding:1.8rem 1.6rem;transition:all .4s cubic-bezier(.16,1,.3,1)}
.proof-card:hover{border-color:rgba(168,85,247,.18);box-shadow:0 12px 40px rgba(124,58,237,.08)}
.proof-stars{display:flex;gap:2px;margin-bottom:.7rem;color:#f59e0b;font-size:.75rem}
.proof-quote{font-family:'DM Sans',sans-serif;font-size:.88rem;line-height:1.7;color:rgba(34,10,51,.5);margin-bottom:1.2rem}
.proof-author{display:flex;align-items:center;gap:.6rem}
.proof-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-size:.7rem;font-weight:800;color:#fff}
.pa-1{background:linear-gradient(135deg,#7c3aed,#a855f7)}
.pa-2{background:linear-gradient(135deg,#a855f7,#c084fc)}
.pa-3{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}
.pa-4{background:linear-gradient(135deg,#6d28d9,#7c3aed)}
.pa-5{background:linear-gradient(135deg,#c084fc,#a855f7)}
.proof-author-info strong{font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:700;color:#220a33;display:block}
.proof-author-info small{font-family:'DM Sans',sans-serif;font-size:.62rem;color:rgba(34,10,51,.35)}

/* ===== PARTNERS — Glass cards with animated gradient border ===== */
.partners-section{padding:3rem 1rem;max-width:1100px;margin:0 auto}
.partners-header{text-align:center;margin-bottom:3.5rem}
.partners-header .phrase-label{margin-bottom:1.2rem}
.partners-header h2{font-family:'Outfit',sans-serif;font-size:clamp(2.4rem,5vw,3.6rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;color:#220a33;margin-bottom:.8rem}
.partners-header h2 em{font-style:normal;background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.partners-header p{font-family:'DM Sans',sans-serif;font-size:1.05rem;line-height:1.7;color:rgba(34,10,51,.4);max-width:520px;margin:0 auto}
/* Partner Centered Card */
.partner-centered{max-width:600px;margin:0 auto}
.partner-card-centered{
  position:relative;display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:2.5rem 2rem;border-radius:28px;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1.5px solid rgba(168,85,247,.1);text-decoration:none;color:inherit;
  transition:all .5s cubic-bezier(.16,1,.3,1);overflow:hidden;
  box-shadow:0 4px 24px rgba(34,10,51,.04);
}
.partner-card-centered::before{
  content:'';position:absolute;inset:-2px;border-radius:inherit;
  background:conic-gradient(from 0deg,#7c3aed,#a855f7,#c084fc,#e9d5ff,#c084fc,#a855f7,#7c3aed);
  z-index:-1;opacity:0;transition:opacity .5s;animation:borderSpin 4s linear infinite;
}
@keyframes borderSpin{0%{filter:hue-rotate(0deg)}100%{filter:hue-rotate(360deg)}}
.partner-card-centered::after{content:'';position:absolute;inset:1px;border-radius:inherit;background:rgba(255,255,255,.96);z-index:-1}
.partner-card-centered:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(124,58,237,.12)}
.partner-card-centered:hover::before{opacity:1}
.partner-card-logo{
  width:120px;height:120px;border-radius:24px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#f8f5ff,#f3eef8);
  border:1px solid rgba(168,85,247,.08);box-shadow:0 4px 16px rgba(34,10,51,.04);
  margin-bottom:1rem;
}
.partner-card-logo img{height:80px;width:80px;object-fit:contain}
.partner-card-badge{
  display:inline-flex;align-items:center;gap:.35rem;padding:.45rem 1rem;
  border-radius:99px;
  background:linear-gradient(135deg,rgba(124,58,237,.06),rgba(192,132,252,.04));
  border:1px solid rgba(168,85,247,.1);
  font-family:'DM Sans',sans-serif;font-size:.72rem;font-weight:600;color:#7c3aed;
  letter-spacing:.02em;text-transform:uppercase;margin-bottom:1.2rem;
}
.partner-card-badge svg{width:12px;height:12px}
.partner-card-centered h3{
  font-family:'Outfit',sans-serif;font-size:1.6rem;font-weight:800;color:#220a33;margin-bottom:.6rem;
}
.partner-card-desc{
  font-family:'DM Sans',sans-serif;font-size:.95rem;line-height:1.7;color:rgba(34,10,51,.5);margin-bottom:1.8rem;
  max-width:480px;
}
.partner-card-features{display:flex;flex-direction:column;gap:1.2rem;text-align:left;width:100%}
.partner-feature{display:flex;align-items:flex-start;gap:.9rem}
.partner-feature svg{width:22px;height:22px;flex-shrink:0;color:#7c3aed;margin-top:.1rem}
.partner-feature strong{display:block;font-family:'Outfit',sans-serif;font-size:.92rem;font-weight:700;color:#220a33;margin-bottom:.15rem}
.partner-feature span{font-family:'DM Sans',sans-serif;font-size:.82rem;line-height:1.5;color:rgba(34,10,51,.4)}

/* ===== FAQ ===== */
.faq-section{padding:3rem 1rem;max-width:720px;margin:0 auto}
.faq-header{text-align:center;margin-bottom:3rem}
.faq-header .phrase-label{margin-bottom:1.2rem}
.faq-header h2{font-family:'Outfit',sans-serif;font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;line-height:1.05;letter-spacing:-.045em;color:#220a33}
.faq-header h2 em{font-style:normal;background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.faq-list{display:flex;flex-direction:column;gap:.6rem}
.faq-item{border:1px solid rgba(168,85,247,.08);border-radius:16px;overflow:hidden;transition:all .3s}
.faq-item:hover{border-color:rgba(168,85,247,.18)}
.faq-item.active{border-color:rgba(168,85,247,.15);background:#f8f5fc;box-shadow:0 4px 20px rgba(124,58,237,.04)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.4rem;cursor:pointer;gap:1rem}
.faq-q span{font-family:'DM Sans',sans-serif;font-size:.92rem;font-weight:600;color:#220a33}
.faq-q svg{width:18px;height:18px;color:#a855f7;flex-shrink:0;transition:transform .3s cubic-bezier(.16,1,.3,1)}
.faq-item.active .faq-q svg{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.16,1,.3,1),padding .3s}
.faq-item.active .faq-a{max-height:200px;padding:0 1.4rem 1.2rem}
.faq-a p{font-family:'DM Sans',sans-serif;font-size:.85rem;line-height:1.75;color:rgba(34,10,51,.45)}

/* ===== FINAL CTA — Same gradient as hero, curves pass over ===== */
.final-cta{
  position:relative;margin:0;padding:4rem 1.5rem 3.5rem;text-align:center;
  border-radius:18px;overflow:hidden;
  background:
    radial-gradient(ellipse 90% 70% at 50% 110%, rgba(124,58,237,.07) 0%, transparent 50%),
    radial-gradient(ellipse 50% 40% at 15% 20%, rgba(168,85,247,.05) 0%, transparent 50%),
    linear-gradient(170deg, #fefcff 0%, #f8f4fc 35%, #f3eef8 65%, #ede5f5 100%);
  box-shadow:0 20px 60px rgba(34,10,51,.06);
}
.bg-mesh-cta{display:none}
.grain-cta{display:none}
.orb-cta{display:none}
.orb-cta-1,.orb-cta-2{display:none}
/* No extra laces — bg-canvas curves pass over */
.final-cta::before{display:none}
.final-cta-inner{position:relative;z-index:3;max-width:680px;margin:0 auto}
.final-cta h2{font-family:'Outfit',sans-serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;line-height:1;letter-spacing:-.04em;color:#1a0e2e;margin-bottom:1.2rem}
.final-cta h2 em{font-style:normal;background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.final-cta-inner>p{font-family:'DM Sans',sans-serif;font-size:1rem;line-height:1.8;color:#6b5a7d;max-width:500px;margin:0 auto 2rem}
.final-cta-form{
  display:inline-flex;align-items:stretch;flex-direction:column;
  background:#fff;border:2px solid rgba(124,58,237,.08);
  border-radius:18px;padding:5px;max-width:580px;width:100%;
  box-shadow:0 4px 20px rgba(0,0,0,.04);transition:border-color .3s,box-shadow .3s;
}
.final-cta-form:focus-within{border-color:rgba(124,58,237,.2);box-shadow:0 4px 20px rgba(124,58,237,.08)}
.final-cta-form input{flex:1;min-width:0;font-family:'DM Sans',sans-serif;font-size:1rem;padding:1rem 1.2rem;background:transparent;border:none;outline:none;color:#1a0e2e}
.final-cta-form input::placeholder{color:rgba(26,14,46,.3)}
.final-cta-form button{font-family:'DM Sans',sans-serif;font-size:.92rem;font-weight:700;padding:1rem 2rem;white-space:nowrap;background:linear-gradient(135deg,#7c3aed,#9333ea);color:#fff;border:none;border-radius:14px;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 3px 16px rgba(124,58,237,.2)}
.final-cta-form button:hover{transform:translateY(-1px);box-shadow:0 6px 28px rgba(124,58,237,.35)}
.final-cta-proof{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;margin-top:2rem}
.final-cta-proof .avatars span{width:34px;height:34px;font-size:.6rem;border-color:rgba(124,58,237,.1)}
.final-cta-proof p{font-size:.92rem;color:#6b5a7d}
.final-cta-proof p strong{color:#1a0e2e;font-weight:700}

/* ===== FOOTER ===== */
.site-footer{padding:4rem 2rem 2.5rem;border-top:1px solid rgba(168,85,247,.06);max-width:1100px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:3rem}
.footer-brand{font-family:'Outfit',sans-serif;font-weight:800;font-size:1.2rem;color:#220a33;display:inline-flex;align-items:center;gap:.4rem;margin-bottom:.8rem}
.footer-brand .brand-dot{width:7px;height:7px}
.footer-brand span{background:linear-gradient(135deg,#7c3aed,#a855f7,#c084fc);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.footer-desc{font-family:'DM Sans',sans-serif;font-size:.82rem;line-height:1.7;color:rgba(34,10,51,.35);max-width:280px}
.footer-col h4{font-family:'DM Sans',sans-serif;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(34,10,51,.25);margin-bottom:1rem}
.footer-col a{display:block;font-family:'DM Sans',sans-serif;font-size:.84rem;color:rgba(34,10,51,.45);text-decoration:none;padding:.3rem 0;transition:color .3s}
.footer-col a:hover{color:#7c3aed}
.footer-bottom{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding-top:1.5rem;border-top:1px solid rgba(168,85,247,.05);text-align:center}
.footer-copy{font-family:'DM Sans',sans-serif;font-size:.72rem;color:rgba(34,10,51,.2)}
.footer-bottom-links{display:flex;gap:1.2rem}
.footer-bottom-links a{font-family:'DM Sans',sans-serif;font-size:.72rem;color:rgba(34,10,51,.25);text-decoration:none;transition:color .3s}
.footer-bottom-links a:hover{color:#7c3aed}

/* ===== MOBILE OVERRIDES ===== */
@media(max-width:600px){
  .shell{padding:0 0 20px;max-width:100vw}

  .brand{font-size:.9rem;gap:.3rem}
  .brand-dot{width:6px;height:6px}

  /* Mobile nav — force GPU layer to prevent scroll jitter */
  .nav{
    position:sticky;top:0;z-index:100;
    -webkit-transform:translateZ(0);transform:translateZ(0);
    -webkit-backface-visibility:hidden;backface-visibility:hidden;
    will-change:transform;
  }

  /* Mobile block reorder: hero → events → features → rest */
  .shell{display:flex;flex-direction:column}
  .hero{order:1}
  .phrase-section{order:3}
  .feat-grid{order:4}
  .events-section{order:2}
  .steps-section{order:5}
  .brands-section{order:6}
  .proof-section{order:7}
  .partners-section{order:8}
  .faq-section{order:9}
  .final-cta{order:10}
  footer{order:11}

  /* Hero mobile — gradient reversed: violet top → white bottom */
  .hero{
    background:linear-gradient(180deg, #ede5f5 0%, #f3eef8 30%, #f8f4fc 60%, #fff 100%);
    padding:2.8rem 1.2rem 2.5rem;
    border-radius:0;
    box-shadow:none;
    overflow:hidden;
    min-height:auto;
    display:flex;flex-direction:column;
    align-items:center;justify-content:center;
  }
  .hero-content{padding:0 .3rem}
  .hero-badge{font-size:.68rem;padding:5px 12px;margin-bottom:1.4rem}

  /* Catchline — large, 2 lines: "Ne ratez plus" / "jamais [ticket]" */
  .headline{
    font-size:clamp(2.4rem,9.5vw,3.2rem);
    margin-bottom:8px;
    line-height:1.08;
  }

  /* Ticket — proportional */
  .ticket{
    font-size:clamp(2rem,8.5vw,2.8rem);
    padding:8px 36px 8px 30px;
    border-radius:12px;
  }
  .ticket::after{width:16px;height:16px;right:-8px}
  .tk-notch{width:16px;height:16px;left:-8px}
  .tk-perf{left:20px}
  .tk-wrap{margin-top:4px}

  /* Subtitle */
  .subtitle{font-size:.82rem;margin:18px auto 0;max-width:100%;line-height:1.65}

  /* CTA zone */
  .cta-zone{margin-top:22px;gap:8px}
  .search-bar{padding:3px 3px 3px 14px;border-radius:50px}
  .search-bar input{font-size:.75rem;padding:10px 0}
  .search-bar input::placeholder{font-size:.72rem}
  .search-bar button{padding:9px 16px;font-size:.78rem;border-radius:48px}
  .s-ico{width:15px;height:15px;margin-right:6px}

  /* Only 3 tendances on mobile — hide 4th */
  .popular{gap:5px;margin-top:2px}
  .pop-lbl{font-size:.62rem}
  .pop-t{font-size:.6rem;padding:3px 9px}
  .pop-t:nth-child(5){display:none}

  /* Only 3 trust items on mobile — hide 4th */
  .trust{margin-top:1.4rem;gap:12px}
  .tr{font-size:.66rem;gap:4px}
  .tr svg{width:11px;height:11px}
  .tr:nth-child(4){display:none}

  /* Hide floating cards on mobile */
  .fl{display:none!important}

  /* Final CTA mobile — pure white */
  .final-cta{
    background:#fff;
    padding:3rem 1.2rem 2.5rem;
    border-radius:0;
    box-shadow:none;
    margin:0;
  }
  .final-cta::before,
  .final-cta .bg-mesh-cta,
  .final-cta .grain-cta,
  .final-cta .orb-cta,
  .final-cta .orb-cta-1,
  .final-cta .orb-cta-2{display:none !important}
  .final-cta h2{color:#220a33}
  .final-cta h2 em{background:linear-gradient(135deg,#7c3aed 0%,#a855f7 40%,#c084fc 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .final-cta-inner>p{color:rgba(34,10,51,.5)}
  .final-cta-form{background:rgba(243,238,248,.5);border-color:rgba(168,85,247,.1);box-shadow:0 4px 24px rgba(34,10,51,.06)}
  .final-cta-form input{color:#220a33}
  .final-cta-form input::placeholder{color:rgba(34,10,51,.35)}
  .final-cta-proof p{color:rgba(34,10,51,.45)}
  .final-cta-proof p strong{color:#220a33}
  .final-cta-proof .avatars span{border-color:#fff}

  /* Events mobile — full width */
  .events-section{padding:2.5rem 0 3rem;overflow:hidden;max-width:100vw}
  .events-header{padding:0 1rem}
  .events-header h2{font-size:clamp(2rem,7vw,2.8rem)}
  .ev-featured{margin:0 1rem .8rem}
  .ev-card-big{height:180px;border-radius:16px}
  .ev-card-big .ev-big-content{padding:1rem}
  .ev-big-title{font-size:1rem}
  .ev-big-right{display:none}
  .ev-big-info{font-size:.7rem;gap:.5rem}
  .events-grid{
    display:flex;flex-direction:column;gap:.6rem;
    padding:0 1rem;margin:0;
    width:100%;max-width:100%;
    overflow:hidden;
  }
  .ev-card{
    flex-direction:row;width:100%;max-width:100%;
    border-radius:14px;
  }
  .ev-img{width:100px;min-width:100px;max-width:100px;min-height:auto;flex-shrink:0}
  .ev-body{padding:.7rem .8rem;flex:1;min-width:0}
  .ev-title{font-size:.78rem}
  .ev-meta{font-size:.58rem}
  .ev-price{font-size:.85rem}
  .ev-hype-bar{width:35px}
  .ev-hype small{font-size:.48rem}
  .events-cats{padding:0 1rem;margin-top:1.2rem}
  .events-cta{margin-top:2rem;padding:0 1rem}
  .events-cta a{font-size:.88rem;padding:.85rem 1.8rem;border-radius:14px;width:100%;justify-content:center}

  /* All sections — prevent overflow */
  .phrase-section,.feat-grid,.steps-section,.brands-section,
  .proof-section,.partners-section,.faq-section{
    max-width:100vw;overflow:hidden;
  }
  .feat-grid{padding:1.5rem 1rem 2.5rem}
  .proof-scroll::before,.proof-scroll::after{width:40px}
  .partners-section{padding:2.5rem 1rem}
  .faq-section{padding:2.5rem 1rem}
  .steps-section{padding:3rem 1rem 2rem}
}

/* ===== DESKTOP BREAKPOINTS ===== */
@media(min-width:601px){
  .shell{padding:0 64px 64px}
  /* Nav desktop — logo on LEFT */
  .burger{display:none}
  .mobile-menu{display:none!important}
  .nav{padding:.8rem 2rem;flex-wrap:nowrap;gap:0}
  .brand{order:0;font-size:1.3rem;flex-shrink:0}
  .brand-dot{width:8px;height:8px}
  .nav-links{display:flex;order:1;margin-left:1.5rem;flex-shrink:0}
  .nav-links a{font-size:.8rem;padding:.45rem 1.1rem;border-radius:9px}
  .nav-search{
    position:relative;left:auto;top:auto;transform:none;
    flex:1;min-width:0;max-width:400px;order:2;margin:0 auto;
  }
  .nav-right{display:flex;order:3;flex-shrink:0}
  /* Hero desktop */
  .hero{padding:5rem 2.5rem 4rem;border-radius:24px;flex:1;min-height:85vh;overflow:visible}
  .hero-content{padding:0 2rem;max-width:920px}
  .hero-badge{font-size:.75rem;padding:6px 16px;margin-bottom:2rem}
  .headline{font-size:clamp(3.2rem,7vw,6rem);margin-bottom:12px}
  .tk-lbl{display:block}
  .tk-meta{display:flex}
  .subtitle{max-width:780px;margin:32px auto 0;font-size:1.05rem}
  .cta-zone{margin-top:36px}
  .search-bar{padding:6px 6px 6px 24px;max-width:560px}
  .search-bar input{font-size:.88rem;padding:14px 0}
  .search-bar button{padding:14px 30px;font-size:.95rem}
  .trust{margin-top:44px;gap:22px}
  .tr{font-size:.76rem}
  /* Show floating cards on desktop */
  .fl{display:block}
  /* Sections */
  .phrase-section{padding:7rem 2rem 1rem}
  .feat-grid{grid-template-columns:1fr 1fr;padding:3rem 2rem 5rem}
  .feat-visual{aspect-ratio:4/3}
  .events-section{padding:5rem 0 6rem}
  .events-header{margin-bottom:4rem}
  .ev-featured{margin:0 2rem 1.5rem}
  .ev-card-big{height:420px}
  .ev-card-big .ev-big-content{padding:2.2rem 2.5rem;flex-direction:row;align-items:flex-end;justify-content:space-between}
  .ev-big-right{flex-direction:column;align-items:flex-end}
  .ev-big-title{font-size:clamp(1.6rem,3vw,2.4rem)}
  /* Events: restore grid */
  .events-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;
    margin:0 2rem;padding:0;flex-direction:initial;
  }
  .ev-card{flex-direction:column;align-items:stretch;border-radius:20px}
  .ev-card .ev-badge{display:block}
  .ev-img{width:100%;height:200px;min-height:200px}
  .ev-img::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(34,10,51,.55) 0%,rgba(34,10,51,.05) 50%,transparent 100%)}
  .ev-cat{top:.75rem;right:.75rem;left:auto;font-size:.55rem}
  .ev-date-float{bottom:.75rem;left:.75rem;right:auto;border-radius:12px;padding:.4rem .6rem;min-width:48px}
  .ev-date-float strong{font-size:1.1rem}
  .ev-date-float small{font-size:.5rem}
  .ev-body{padding:1rem 1rem 1.1rem}
  .ev-title{font-size:.9rem;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:initial}
  .ev-meta{font-size:.65rem;margin-bottom:.65rem}
  .ev-footer{padding-top:.55rem;border-top:1px solid rgba(168,85,247,.06)}
  .ev-price{font-size:1.05rem}
  .ev-hype-bar{width:52px;height:5px}
  .ev-hype small{font-size:.55rem}
  .events-cats{gap:.7rem;margin:2.5rem 2rem 0;justify-content:center;overflow:visible;padding:0}
  .ev-cat-btn{padding:.65rem 1.6rem;font-size:.85rem}
  .events-cta{margin-top:3.5rem}
  .steps-section{padding:6rem 2rem 7rem}
  .steps-row{flex-direction:row;gap:1.2rem}
  .step-arrow{display:flex;align-items:center;justify-content:center;width:40px;flex-shrink:0}
  .step-arrow svg{width:20px;height:20px;color:rgba(168,85,247,.2)}
  .step-tl{padding:2.5rem 2rem 2rem}
  .step-tl-num{font-size:4.5rem}
  .brands-section{padding:5rem 2rem}
  .brands-row{gap:3.5rem}
  .brands-row img{height:36px}
  .proof-section{padding:5rem 0}
  .proof-card{width:360px}
  .partners-section{padding:6rem 2rem}
  .partner-card-centered{padding:3rem}
  .partner-card-logo{width:140px;height:140px;border-radius:28px}
  .partner-card-logo img{height:100px;width:100px}
  .partner-card-features{flex-direction:row;gap:1.5rem}
  .partner-feature{flex:1}
  .faq-section{padding:5rem 2rem}
  .final-cta{padding:7rem 2.5rem 6rem;border-radius:24px}
  .final-cta-form{flex-direction:row}
  .final-cta-proof{flex-direction:row;gap:.8rem}
  .footer-top{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem}
  .footer-bottom{flex-direction:row;justify-content:space-between;text-align:left}
}

@media(min-width:901px){
  .events-grid{grid-template-columns:repeat(3,1fr)}
}

@media(min-width:1101px){
  .events-grid{grid-template-columns:repeat(5,1fr);gap:1.2rem;margin:0 2rem}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}

/* ===== ALERT MODAL ===== */
.tx-alert-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem}
.tx-alert-overlay{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.tx-alert-box{position:relative;background:#fff;border-radius:24px;padding:2.5rem;max-width:440px;width:100%;box-shadow:0 24px 64px rgba(0,0,0,.2);animation:txAlertIn .3s ease-out}
@keyframes txAlertIn{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.tx-alert-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}
.tx-alert-close:hover{background:rgba(0,0,0,.05);color:#333}
.tx-alert-icon{font-size:2.5rem;text-align:center;margin-bottom:.5rem}
.tx-alert-box h3{font-family:'Outfit',sans-serif;font-size:1.5rem;font-weight:800;color:#220a33;text-align:center;margin-bottom:.3rem}
.tx-alert-event-name{text-align:center;font-family:'DM Sans',sans-serif;font-size:.95rem;color:#7c3aed;font-weight:600;margin-bottom:1.5rem}
.tx-alert-field{margin-bottom:1rem}
.tx-alert-field label{display:block;font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:600;color:#220a33;margin-bottom:.4rem}
.tx-alert-field input{width:100%;padding:.75rem 1rem;border:1.5px solid rgba(168,85,247,.15);border-radius:12px;font-family:'DM Sans',sans-serif;font-size:.95rem;transition:border-color .2s;outline:none}
.tx-alert-field input:focus{border-color:#7c3aed;box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.tx-alert-submit{width:100%;padding:.85rem;border:none;border-radius:14px;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s;margin-top:.5rem}
.tx-alert-submit:hover{background:linear-gradient(135deg,#6d28d9,#9333ea);box-shadow:0 8px 24px rgba(124,58,237,.25)}
.tx-alert-submit:disabled{opacity:.6;cursor:not-allowed}
.tx-alert-message{margin-top:1rem;padding:.8rem 1rem;border-radius:12px;font-family:'DM Sans',sans-serif;font-size:.88rem;text-align:center;font-weight:700}
.tx-alert-success{background:#22c55e;color:#fff;border:none}
.tx-alert-error{background:#dc2626;color:#fff;border:none}
.tx-alert-privacy{text-align:center;font-size:.75rem;color:rgba(34,10,51,.35);margin-top:1rem;margin-bottom:0}

/* Inline alert messages on event pages */
.tx-inline-msg{margin-top:.8rem;padding:.6rem 1rem;border-radius:10px;font-family:'DM Sans',sans-serif;font-size:.85rem;text-align:center;font-weight:700}
.tx-inline-success{background:#22c55e;color:#fff;border:none}
.tx-inline-error{background:#dc2626;color:#fff;border:none}

/* Alert button style */
.tx-btn-alert{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.2rem;border-radius:10px;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;border:none;cursor:pointer;transition:all .3s;text-decoration:none;z-index:2;position:relative}
.tx-btn-alert:hover{background:linear-gradient(135deg,#6d28d9,#9333ea);box-shadow:0 4px 16px rgba(124,58,237,.2);transform:translateY(-2px)}
.tx-btn-alert svg{width:14px;height:14px}

/* Mon Compte: alerts from DB */
.tx-my-alerts-list{display:flex;flex-direction:column;gap:10px}
.tx-my-alert{display:flex;align-items:center;gap:14px;padding:14px;border-radius:12px;border:1px solid rgba(124,58,237,.08);background:#faf8ff;transition:box-shadow .2s}
.tx-my-alert:hover{box-shadow:0 2px 12px rgba(124,58,237,.08)}
.tx-my-alert-info{flex:1;min-width:0}
.tx-my-alert-title{font-family:'DM Sans',sans-serif;font-weight:700;font-size:.92rem;color:#1a0e2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-my-alert-date{font-family:'DM Sans',sans-serif;font-size:.8rem;color:#6b7280;margin-top:3px}
.tx-cancel-alert{flex-shrink:0;width:34px;height:34px;border-radius:8px;border:none;cursor:pointer;background:rgba(220,38,38,.06);color:#dc2626;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;transition:background .2s}
.tx-cancel-alert:hover{background:rgba(220,38,38,.12)}
.tx-no-alerts{font-family:'DM Sans',sans-serif;font-size:.9rem;color:#6b7280;text-align:center;padding:20px 0}
