/* ====== RESET ====== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Quicksand',system-ui,sans-serif;
  font-weight:500;
  color:#3d1640;
  background:#ffeaf6;
  overflow-x:hidden;
  cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'><text x='0' y='22' font-size='22'>💖</text></svg>") 4 4, auto;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'><text x='0' y='22' font-size='22'>✨</text></svg>") 4 4, pointer}

/* ====== VARS ====== */
:root{
  --pink-50:#fff4fa;
  --pink-100:#ffe4f3;
  --pink-200:#ffc4dd;
  --pink-300:#ff9ec8;
  --pink-400:#ff6fb5;
  --pink-500:#ff3ea0;
  --pink-600:#e41f87;
  --violet:#a855f7;
  --gold:#ffd86b;
  --ink:#3d1640;
  --glass:rgba(255,255,255,.55);
  --shadow:0 20px 40px -12px rgba(228,31,135,.35);
}

/* ====== BACKGROUND ====== */
.party-bg{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1000px 800px at 10% 0%, #ffd6e8 0%, transparent 60%),
    radial-gradient(900px 700px at 90% 20%, #ffe7b3 0%, transparent 55%),
    radial-gradient(1200px 900px at 50% 100%, #e0c8ff 0%, transparent 60%),
    linear-gradient(180deg,#ffeaf6 0%, #ffd6e8 40%, #ffe0f0 100%);
  animation:bgShift 14s ease-in-out infinite alternate;
}
@keyframes bgShift{
  0%{filter:hue-rotate(0deg) saturate(1)}
  100%{filter:hue-rotate(20deg) saturate(1.15)}
}
.floaters{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.floaters span{
  position:absolute;font-size:28px;opacity:.7;
  animation:floatUp linear infinite;
  filter:drop-shadow(0 2px 8px rgba(255,62,160,.4));
}
@keyframes floatUp{
  0%{transform:translateY(110vh) rotate(0) scale(.9);opacity:0}
  10%{opacity:.9}
  100%{transform:translateY(-20vh) rotate(360deg) scale(1.1);opacity:0}
}
#sparkles{position:fixed;inset:0;z-index:9999;pointer-events:none}

/* ====== DISCO MODE ====== */
body.disco .party-bg{animation:disco 2s linear infinite}
@keyframes disco{
  0%{filter:hue-rotate(0)}
  100%{filter:hue-rotate(360deg)}
}
body.disco .hero__title,body.disco .section__title{animation:rainbow 2s linear infinite}
@keyframes rainbow{
  0%{filter:hue-rotate(0)}
  100%{filter:hue-rotate(360deg)}
}

/* ====== STAY BAR ====== */
.stay-bar{
  position:fixed;left:50%;bottom:16px;transform:translateX(-50%);
  background:linear-gradient(135deg,#fff 0%, #ffe4f3 100%);
  border:2px solid var(--pink-300);
  box-shadow:var(--shadow);
  border-radius:999px;
  padding:10px 16px 10px 14px;
  display:flex;align-items:center;gap:10px;
  z-index:90;
  font-size:14px;
  animation:bob 3s ease-in-out infinite;
  max-width:92vw;
}
.stay-bar.hidden{display:none}
@keyframes bob{50%{transform:translate(-50%,-6px)}}
.stay-bar__icon{font-size:20px;animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{50%{transform:scale(1.25)}}
.stay-bar__text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}
.stay-bar__close{
  background:var(--pink-500);color:#fff;border:none;width:22px;height:22px;border-radius:50%;
  font-weight:bold;font-size:14px;line-height:1;
}

/* ====== NAV ====== */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:all .3s}
.nav__inner{
  max-width:1280px;margin:0 auto;padding:18px 24px;
  display:flex;align-items:center;gap:18px;
}
.nav.scrolled{backdrop-filter:blur(14px);background:rgba(255,228,243,.75);box-shadow:0 4px 20px rgba(228,31,135,.18)}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:'Pacifico',cursive;font-size:22px;color:var(--pink-600);
}
.brand small{display:block;font-family:'Quicksand';font-size:11px;color:var(--pink-400);font-weight:500;letter-spacing:1px}
.brand__emoji{font-size:24px;animation:spin 4s linear infinite}
@keyframes spin{100%{transform:rotate(360deg)}}
.nav__links{margin-left:auto;display:flex;gap:22px;align-items:center}
.nav__links a{font-size:14px;font-weight:600;color:var(--ink);transition:color .2s;position:relative}
.nav__links a:hover{color:var(--pink-500)}
.nav__links a:hover::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,var(--pink-400),var(--violet));border-radius:3px}

.music-btn{
  display:flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,#fff,#ffe4f3);
  border:2px solid var(--pink-300);
  padding:8px 14px;border-radius:999px;font-weight:700;color:var(--pink-600);
  transition:transform .2s;
}
.music-btn:hover{transform:scale(1.06)}
.music-btn.playing{animation:pulse 1s ease-in-out infinite;background:linear-gradient(135deg,var(--pink-400),var(--violet));color:#fff;border-color:var(--pink-500)}
.music-btn__label{font-size:12px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:999px;
  font-weight:700;font-size:15px;
  border:none;cursor:pointer;
  transition:transform .2s, box-shadow .2s;
  text-align:center;
}
.btn--primary{
  color:#fff;
  background:linear-gradient(135deg,var(--pink-500),var(--violet));
  box-shadow:0 10px 24px -6px rgba(228,31,135,.6), inset 0 1px 0 rgba(255,255,255,.4);
  position:relative;overflow:hidden;
}
.btn--primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%, rgba(255,255,255,.55) 50%, transparent 70%);
  transform:translateX(-100%);
  animation:shine 3s ease-in-out infinite;
}
@keyframes shine{50%{transform:translateX(100%)}100%{transform:translateX(100%)}}
.btn--primary:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 14px 30px -6px rgba(228,31,135,.7)}
.btn--ghost{
  background:rgba(255,255,255,.6);color:var(--pink-600);
  border:2px solid var(--pink-300);
  backdrop-filter:blur(10px);
}
.btn--ghost:hover{background:#fff;border-color:var(--pink-500)}
.btn--block{width:100%}
.nav__cta{padding:10px 18px;font-size:13px}

.burger{display:none;background:none;border:none;flex-direction:column;gap:5px;padding:8px}
.burger span{display:block;width:24px;height:2px;background:var(--pink-600);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ====== HERO ====== */
.hero{position:relative;padding:140px 24px 100px;text-align:center}
.hero__glow{
  position:absolute;left:50%;top:20%;transform:translateX(-50%);
  width:900px;height:900px;max-width:90vw;max-height:90vw;
  background:radial-gradient(circle, rgba(255,110,181,.4) 0%, transparent 60%);
  filter:blur(40px);z-index:-1;
  animation:glow 6s ease-in-out infinite alternate;
}
@keyframes glow{
  0%{transform:translate(-50%,0) scale(1)}
  100%{transform:translate(-50%,-20px) scale(1.1)}
}
.hero__inner{max-width:900px;margin:0 auto}
.hero__tag{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.7);backdrop-filter:blur(10px);
  border:2px solid var(--pink-200);
  padding:8px 18px;border-radius:999px;
  font-size:13px;font-weight:700;color:var(--pink-600);
  margin-bottom:28px;
}
.dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}
.hero__title{
  font-family:'Pacifico',cursive;
  font-size:clamp(48px,9vw,120px);
  font-weight:400;
  line-height:1.05;
  color:var(--pink-600);
  letter-spacing:-.02em;
  margin-bottom:26px;
  text-shadow:3px 3px 0 rgba(255,255,255,.6), 6px 6px 20px rgba(228,31,135,.2);
}
.hero__title-accent{
  background:linear-gradient(135deg,var(--pink-500) 0%, var(--violet) 50%, var(--pink-500) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 200%;
  animation:gradient 4s ease-in-out infinite;
  display:inline-block;
}
@keyframes gradient{50%{background-position:100% 100%}}
.shine{
  background:linear-gradient(120deg,var(--pink-600) 0%, var(--pink-400) 50%, var(--pink-600) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 100%;
  animation:shineText 3s linear infinite;
}
@keyframes shineText{100%{background-position:-200% 0}}
.heart{display:inline-block;animation:beat 1s ease-in-out infinite}
@keyframes beat{0%,100%{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(.95)}75%{transform:scale(1.15)}}

.hero__sub{
  font-size:18px;line-height:1.6;color:var(--ink);
  max-width:640px;margin:0 auto 36px;
}
.hero__sub strong{color:var(--pink-600)}
.hero__sub em{font-style:italic;color:var(--violet)}

.hero__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:60px}

.hero__strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  max-width:760px;margin:0 auto;
  background:rgba(255,255,255,.65);backdrop-filter:blur(14px);
  border:2px solid var(--pink-200);
  border-radius:28px;padding:22px;
  box-shadow:var(--shadow);
}
.hero__strip div{text-align:center}
.hero__strip strong{display:block;font-family:'Lobster',cursive;font-size:28px;color:var(--pink-600)}
.hero__strip span{display:block;font-size:12px;color:var(--ink);opacity:.75;margin-top:4px}

/* ====== MARQUEE ====== */
.marquee{
  margin-top:70px;overflow:hidden;
  background:linear-gradient(90deg,var(--pink-500),var(--violet),var(--pink-500));
  padding:16px 0;transform:rotate(-2deg);
  box-shadow:0 10px 30px -10px rgba(168,85,247,.5);
}
.marquee__track{
  display:flex;gap:24px;white-space:nowrap;
  animation:marquee 40s linear infinite;
}
.marquee__track span{
  font-family:'Lobster',cursive;font-size:26px;color:#fff;
  text-shadow:2px 2px 0 rgba(0,0,0,.1);
}
@keyframes marquee{100%{transform:translateX(-50%)}}

/* ====== SECTION ====== */
.section{padding:100px 24px;position:relative}
.container{max-width:1280px;margin:0 auto}
.container--narrow{max-width:780px}

.section__head{text-align:center;margin-bottom:60px}
.eyebrow{
  display:inline-block;
  font-family:'Pacifico',cursive;font-size:18px;color:var(--pink-500);
  margin-bottom:12px;
}
.eyebrow--light{color:var(--pink-200)}
.section__title{
  font-family:'Pacifico',cursive;font-weight:400;
  font-size:clamp(32px,5.5vw,56px);line-height:1.1;color:var(--ink);
}
.underline-wavy{
  text-decoration:underline wavy var(--pink-400);
  text-underline-offset:8px;
  text-decoration-thickness:3px;
}

/* ====== SERVICES ====== */
.services{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;
}
.service{
  background:linear-gradient(180deg,#fff 0%, #fff4fa 100%);
  border-radius:28px;padding:32px;
  border:2px solid var(--pink-100);
  position:relative;overflow:hidden;
  transition:transform .3s, box-shadow .3s, border-color .3s;
  box-shadow:0 10px 30px -15px rgba(228,31,135,.3);
}
.service::before{
  content:'';position:absolute;top:0;right:0;width:120px;height:120px;
  background:radial-gradient(circle, var(--pink-200), transparent 70%);
  border-radius:50%;transform:translate(40%,-40%);
  transition:transform .5s;
}
.service:hover{
  transform:translateY(-6px) rotate(-.5deg);
  border-color:var(--pink-400);
  box-shadow:0 20px 50px -15px rgba(228,31,135,.4);
}
.service:hover::before{transform:translate(20%,-20%) scale(1.3)}
.service__num{
  font-family:'Lobster',cursive;font-size:14px;color:var(--pink-400);
  letter-spacing:2px;margin-bottom:18px;
}
.service__emoji{font-size:44px;margin-bottom:18px;animation:wobble 3s ease-in-out infinite}
@keyframes wobble{
  0%,100%{transform:rotate(-4deg)}
  50%{transform:rotate(4deg)}
}
.service h3{font-family:'Pacifico',cursive;font-weight:400;font-size:26px;color:var(--pink-600);margin-bottom:12px}
.service p{font-size:15px;line-height:1.6;color:var(--ink);opacity:.85;margin-bottom:18px}
.service ul{list-style:none}
.service li{
  font-size:14px;color:var(--ink);padding:6px 0 6px 26px;position:relative;
}
.service li::before{content:'💖';position:absolute;left:0;font-size:14px}

/* ====== SECTION DARK ====== */
.section--dark{
  background:linear-gradient(135deg,#3d1640 0%, #6a1b9a 40%, #ff3ea0 100%);
  color:#fff;border-radius:48px;margin:0 24px;position:relative;overflow:hidden;
}
.section--dark::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(400px 400px at 20% 20%, rgba(255,217,107,.15), transparent),
    radial-gradient(400px 400px at 80% 80%, rgba(255,255,255,.1), transparent);
  pointer-events:none;
}
.section--dark .section__title{color:#fff}
.section--dark .lead{color:rgba(255,255,255,.85);font-size:18px;line-height:1.6;margin-bottom:36px;max-width:440px}

/* ====== SHOWCASE ====== */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.steps{display:flex;flex-direction:column;gap:22px}
.step{display:flex;gap:20px;align-items:flex-start}
.step__num{
  font-family:'Lobster',cursive;font-size:28px;
  background:linear-gradient(135deg,var(--pink-400),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  flex-shrink:0;min-width:50px;
}
.step h4{font-family:'Pacifico',cursive;font-weight:400;font-size:22px;margin-bottom:6px;color:#fff}
.step p{color:rgba(255,255,255,.8);font-size:15px;line-height:1.5}

.showcase__visual{position:relative;height:480px}
.card-img{
  position:absolute;border-radius:24px;
  display:flex;align-items:center;justify-content:center;font-size:90px;
  box-shadow:0 20px 50px rgba(0,0,0,.4);
  border:4px solid #fff;
}
.card-img--1{
  top:0;left:0;width:65%;height:65%;
  background:linear-gradient(135deg,var(--pink-300),var(--pink-500));
  animation:float1 6s ease-in-out infinite;
  transform:rotate(-4deg);
}
.card-img--2{
  bottom:0;right:0;width:55%;height:55%;
  background:linear-gradient(135deg,var(--gold),var(--pink-300));
  animation:float1 6s ease-in-out infinite reverse;
  transform:rotate(4deg);
}
@keyframes float1{50%{transform:translateY(-16px) rotate(-2deg)}}
.badge-floating{
  position:absolute;top:40%;left:40%;
  background:#fff;padding:14px 20px;border-radius:16px;color:var(--ink);
  box-shadow:0 10px 30px rgba(0,0,0,.3);
  text-align:center;z-index:3;
  animation:bob 3s ease-in-out infinite;
}
.badge-floating strong{display:block;font-family:'Lobster',cursive;font-size:20px;color:var(--pink-600)}
.badge-floating span{font-size:11px;color:var(--ink);opacity:.7}

.sticker{
  position:absolute;background:var(--gold);padding:8px 16px;border-radius:999px;
  font-weight:800;color:var(--ink);font-size:14px;
  box-shadow:0 6px 16px rgba(0,0,0,.25);z-index:4;
  transform:rotate(-8deg);
  border:2px dashed #fff;
}
.sticker--1{top:-10px;right:10%;animation:wobble 2s ease-in-out infinite}
.sticker--2{bottom:-10px;left:10%;background:#fff;color:var(--pink-500);transform:rotate(8deg);animation:wobble 2.5s ease-in-out infinite reverse}

/* ====== STATS ====== */
.stats-section{padding:80px 24px}
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
}
.stat{
  text-align:center;padding:36px 24px;
  background:linear-gradient(180deg,#fff,#fff4fa);
  border:2px solid var(--pink-100);border-radius:24px;
  transition:transform .3s;
  box-shadow:0 10px 30px -15px rgba(228,31,135,.3);
}
.stat:hover{transform:translateY(-4px) rotate(.5deg)}
.stat__num{
  font-family:'Lobster',cursive;font-size:52px;
  background:linear-gradient(135deg,var(--pink-500),var(--violet));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:6px;
}
.stat__num span{font-size:36px}
.stat__label{font-size:14px;color:var(--ink);font-weight:600}

/* ====== TEAM ====== */
.team{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:22px}
.member{text-align:center}
.member__photo{
  width:180px;height:180px;margin:0 auto 16px;
  border-radius:50%;
  border:5px solid #fff;
  box-shadow:0 15px 35px -10px rgba(228,31,135,.5);
  display:flex;align-items:center;justify-content:center;font-size:70px;
  transition:transform .3s;
  position:relative;
}
.member__photo::after{
  content:'';position:absolute;inset:-5px;border-radius:50%;
  background:conic-gradient(from 0deg, var(--pink-400), var(--violet), var(--gold), var(--pink-400));
  z-index:-1;animation:spin 4s linear infinite;
  filter:blur(6px);opacity:.7;
}
.member:hover .member__photo{transform:scale(1.06) rotate(-4deg)}
.member h4{font-family:'Pacifico',cursive;font-weight:400;font-size:22px;color:var(--pink-600);margin-bottom:4px}
.member span{font-size:13px;color:var(--ink);opacity:.7}

/* ====== TESTIMONIALS ====== */
.section--soft{background:linear-gradient(180deg,transparent,rgba(255,214,232,.4),transparent)}
.testis{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.testi{
  background:#fff;padding:30px;border-radius:24px;
  border:2px solid var(--pink-100);
  box-shadow:0 10px 30px -15px rgba(228,31,135,.3);
  position:relative;
}
.testi::before{
  content:'💕';position:absolute;top:-14px;right:20px;
  background:var(--gold);width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:18px;
  box-shadow:0 4px 10px rgba(0,0,0,.15);
}
.stars{font-size:18px;margin-bottom:14px;letter-spacing:2px}
.testi p{font-size:16px;line-height:1.6;margin-bottom:16px;font-style:italic;color:var(--ink)}
.testi footer{font-size:13px;color:var(--ink);opacity:.7}
.testi strong{color:var(--pink-600)}

/* ====== FAQ ====== */
.faq{display:flex;flex-direction:column;gap:14px}
.faq__item{
  background:#fff;border:2px solid var(--pink-100);
  border-radius:20px;padding:20px 24px;
  transition:all .3s;
  box-shadow:0 6px 18px -10px rgba(228,31,135,.25);
}
.faq__item[open]{border-color:var(--pink-400);background:linear-gradient(180deg,#fff,#fff4fa)}
.faq__item summary{
  font-weight:700;cursor:pointer;font-size:16px;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;
  list-style:none;
}
.faq__item summary::after{content:'💖';font-size:14px;transition:transform .3s}
.faq__item[open] summary::after{transform:rotate(360deg) scale(1.3)}
.faq__item p{margin-top:14px;font-size:15px;line-height:1.6;color:var(--ink);opacity:.85}

/* ====== CONTACT ====== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-list{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:14px}
.contact-list li{display:flex;align-items:center;gap:14px;font-size:16px;color:rgba(255,255,255,.9)}
.contact-list span{font-size:22px}

.form{
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(14px);
  border-radius:28px;padding:34px;
  border:3px solid #fff;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.4);
  display:flex;flex-direction:column;gap:16px;
}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:700;color:var(--pink-600)}
.form input,.form select,.form textarea{
  padding:12px 14px;border:2px solid var(--pink-100);border-radius:14px;
  font-family:inherit;font-size:15px;font-weight:500;color:var(--ink);
  background:var(--pink-50);transition:all .2s;
  outline:none;
}
.form input:focus,.form select:focus,.form textarea:focus{
  border-color:var(--pink-400);background:#fff;
  box-shadow:0 0 0 4px rgba(255,110,181,.2);
}
.form textarea{resize:vertical;min-height:90px}
.form__note{text-align:center;font-size:12px;color:var(--ink);opacity:.6}

/* ====== FOOTER ====== */
.footer{
  background:linear-gradient(135deg,#3d1640,#6a1b9a);
  color:#fff;padding:60px 24px 30px;
  position:relative;overflow:hidden;
}
.footer::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(800px 400px at 50% -50%, rgba(255,110,181,.3), transparent);
  pointer-events:none;
}
.footer__inner{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;
  position:relative;
}
.footer__brand p{font-size:14px;opacity:.7;margin-top:12px;max-width:280px}
.footer h5{font-family:'Pacifico',cursive;font-size:18px;color:var(--pink-300);margin-bottom:16px;font-weight:400}
.footer a{display:block;padding:4px 0;font-size:14px;opacity:.75;transition:opacity .2s}
.footer a:hover{opacity:1;color:var(--pink-200)}
.footer__bottom{
  display:flex;justify-content:space-between;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.15);
  font-size:12px;opacity:.6;flex-wrap:wrap;gap:10px;
}

/* ====== TO TOP ====== */
.to-top{
  position:fixed;bottom:20px;right:20px;z-index:60;
  width:48px;height:48px;border-radius:50%;border:none;
  background:linear-gradient(135deg,var(--pink-500),var(--violet));
  color:#fff;font-size:22px;font-weight:bold;
  box-shadow:0 10px 24px -6px rgba(228,31,135,.6);
  opacity:0;pointer-events:none;transition:all .3s;
  transform:translateY(20px);
}
.to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0);animation:bob 2s ease-in-out infinite}

/* ====== DISCO BTN ====== */
.disco-btn{
  position:fixed;bottom:20px;left:20px;z-index:60;
  width:52px;height:52px;border-radius:50%;border:none;
  background:linear-gradient(135deg,#fff,#ffe4f3);
  box-shadow:var(--shadow);
  font-size:28px;
  animation:spin 5s linear infinite;
  transition:transform .3s;
}
.disco-btn:hover{transform:scale(1.15)}

/* ====== EXIT POPUP ====== */
.exit-overlay{
  position:fixed;inset:0;z-index:100;
  background:rgba(61,22,64,.7);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.exit-overlay.show{display:flex;animation:fadeIn .3s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.exit-modal{
  background:linear-gradient(180deg,#fff,#ffe4f3);
  border:4px solid var(--pink-400);
  border-radius:32px;padding:40px 32px;max-width:440px;text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.5), 0 0 0 8px rgba(255,255,255,.3);
  animation:pop .5s cubic-bezier(.34,1.56,.64,1);
  position:relative;
}
@keyframes pop{from{transform:scale(.5) rotate(-10deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.exit-modal__emoji{font-size:60px;margin-bottom:14px;animation:shake .5s ease-in-out infinite}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px) rotate(-3deg)}75%{transform:translateX(4px) rotate(3deg)}}
.exit-modal h2{
  font-family:'Pacifico',cursive;font-weight:400;
  font-size:40px;color:var(--pink-600);margin-bottom:14px;line-height:1;
}
.exit-modal p{font-size:16px;line-height:1.5;color:var(--ink);margin-bottom:24px}
.exit-modal__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.exit-modal__fine{margin-top:14px;font-size:11px;opacity:.5}

/* ====== TOAST ====== */
.toast{
  position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-80px);
  background:linear-gradient(135deg,var(--pink-500),var(--violet));
  color:#fff;padding:14px 22px;border-radius:999px;
  font-weight:700;font-size:14px;
  box-shadow:0 15px 40px -10px rgba(228,31,135,.6);
  z-index:200;opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);
  pointer-events:none;max-width:90vw;text-align:center;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ====== REVEAL ====== */
.reveal{opacity:0;transform:translateY(24px);transition:all .7s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================
   💅 PARTIE 2 — LE GRAND N'IMPORTE QUOI
   ============================================ */

/* ===== LOADING SCREEN ===== */
.loader{
  position:fixed;inset:0;z-index:1000;
  background:linear-gradient(135deg,#ffeaf6 0%, #ff9ec8 60%, #a855f7 100%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .7s, transform .7s;
}
.loader.gone{opacity:0;pointer-events:none;transform:scale(1.1)}
.loader__inner{text-align:center;max-width:90vw}
.loader__heart{font-size:90px;animation:beat 1s ease-in-out infinite;filter:drop-shadow(0 10px 30px rgba(228,31,135,.6))}
.loader__title{
  font-family:'Pacifico',cursive;font-size:42px;color:#fff;
  text-shadow:2px 4px 0 rgba(228,31,135,.3);
  margin:20px 0 30px;
}
.loader__bar{
  width:320px;max-width:70vw;height:16px;margin:0 auto;
  background:rgba(255,255,255,.35);border-radius:999px;overflow:hidden;
  border:2px solid #fff;
}
.loader__fill{
  height:100%;width:0%;
  background:linear-gradient(90deg,#fff,#ffd86b,#fff);
  background-size:200% 100%;
  animation:shineText 1s linear infinite;
  transition:width .3s ease-out;border-radius:999px;
}
.loader__msg{
  margin-top:20px;font-family:'Quicksand',sans-serif;color:#fff;font-weight:700;
  font-size:14px;letter-spacing:.5px;min-height:20px;
}

/* ===== SCROLL PROGRESS ===== */
.scroll-progress{
  position:fixed;top:0;left:0;height:4px;z-index:100;
  background:linear-gradient(90deg,var(--pink-500),var(--gold),var(--violet),var(--pink-500));
  background-size:200% 100%;
  animation:shineText 3s linear infinite;
  width:0%;transition:width .1s;
  box-shadow:0 0 12px rgba(255,62,160,.6);
}

/* ===== LIVE COUNT ===== */
.live-count{
  position:fixed;top:80px;right:20px;z-index:40;
  background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  border:2px solid var(--pink-300);border-radius:999px;
  padding:8px 14px;font-size:12px;font-weight:700;color:var(--pink-600);
  display:flex;align-items:center;gap:8px;
  box-shadow:0 6px 18px -6px rgba(228,31,135,.4);
  animation:bob 3s ease-in-out infinite;
}
.live-count__dot{
  width:8px;height:8px;background:#22c55e;border-radius:50%;
  box-shadow:0 0 8px #22c55e;animation:pulse 1.5s infinite;
}

/* ===== TICKER ===== */
.ticker{
  position:fixed;top:130px;right:20px;z-index:40;
  background:linear-gradient(135deg,#fff,#ffe4f3);
  border:2px solid var(--pink-200);border-radius:20px;
  padding:10px 14px;max-width:280px;font-size:13px;
  box-shadow:0 6px 18px -6px rgba(228,31,135,.35);
  display:flex;align-items:center;gap:8px;
  transform:translateX(120%);transition:transform .5s cubic-bezier(.34,1.56,.64,1);
}
.ticker.show{transform:translateX(0)}
.ticker__icon{font-size:18px;animation:pulse 1.2s infinite}
.ticker__text{color:var(--ink);font-weight:600;line-height:1.3}

/* ===== MASCOT ===== */
.mascot{
  position:fixed;bottom:20px;right:80px;z-index:55;
  width:110px;height:140px;
  animation:mascotBob 2s ease-in-out infinite;
  cursor:pointer;user-select:none;
}
@keyframes mascotBob{50%{transform:translateY(-6px)}}
.mascot__bubble{
  position:absolute;bottom:110%;right:0;
  background:#fff;border:2px solid var(--pink-400);
  padding:8px 14px;border-radius:18px 18px 18px 4px;
  font-size:13px;font-weight:700;color:var(--pink-600);white-space:nowrap;
  box-shadow:var(--shadow);
  min-width:90px;max-width:220px;white-space:normal;text-align:center;
  opacity:0;transform:translateY(10px);transition:all .3s;
  pointer-events:none;
}
.mascot__bubble.show{opacity:1;transform:translateY(0)}
.mascot__body{
  position:absolute;bottom:0;left:0;right:0;height:100%;
  background:linear-gradient(180deg,#ffd6e8 0%, var(--pink-400) 100%);
  border-radius:50% 50% 40% 40%;
  border:3px solid #fff;
  box-shadow:0 10px 24px -6px rgba(228,31,135,.5);
  overflow:hidden;
}
.mascot__hair{
  position:absolute;top:-8px;left:-6px;right:-6px;height:48px;
  background:linear-gradient(180deg,#ffd86b 0%, #ffc63e 100%);
  border-radius:50% 50% 30% 30%;
  border:2px solid #fff;
}
.mascot__face{
  position:absolute;top:38px;left:20px;right:20px;height:40px;
  display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;
}
.mascot__eye{
  width:10px;height:14px;background:#3d1640;border-radius:50%;
  animation:blink 4s infinite;
}
@keyframes blink{
  0%,96%,100%{transform:scaleY(1)}
  98%{transform:scaleY(.1)}
}
.mascot__mouth{
  width:16px;height:8px;border:2px solid #c41d7f;border-top:none;border-radius:0 0 20px 20px;
  margin-top:6px;background:#ff3ea0;width:100%;height:6px;max-width:24px;margin:6px auto 0;
}
.mascot__wrench{
  position:absolute;bottom:10px;right:-6px;font-size:26px;
  animation:wobble 2s ease-in-out infinite;
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.2));
}

/* ===== THEME PICKER ===== */
.theme-picker{position:fixed;bottom:20px;left:80px;z-index:60}
.theme-picker__toggle{
  width:52px;height:52px;border-radius:50%;border:none;
  background:linear-gradient(135deg,var(--pink-500),var(--violet));
  color:#fff;font-size:26px;
  box-shadow:var(--shadow);
  transition:transform .3s;
}
.theme-picker__toggle:hover{transform:scale(1.1) rotate(-10deg)}
.theme-picker__panel{
  position:absolute;bottom:60px;left:0;
  background:rgba(255,255,255,.95);backdrop-filter:blur(14px);
  border-radius:20px;padding:14px;min-width:180px;
  box-shadow:0 20px 40px -10px rgba(0,0,0,.3);
  border:2px solid var(--pink-200);
  opacity:0;pointer-events:none;transform:translateY(10px) scale(.9);
  transform-origin:bottom left;transition:all .3s cubic-bezier(.34,1.56,.64,1);
}
.theme-picker.open .theme-picker__panel{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
.theme-picker__title{
  font-family:'Pacifico',cursive;color:var(--pink-600);font-size:14px;margin-bottom:10px;text-align:center;
}
.theme-picker__swatch{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:8px 12px;border-radius:12px;border:2px solid transparent;
  background:var(--pink-50);color:var(--ink);font-weight:700;font-size:13px;
  margin-bottom:6px;transition:all .2s;
  text-align:left;
}
.theme-picker__swatch::before{
  content:'';width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--s1),var(--s2));
  border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.2);
}
.theme-picker__swatch:hover{border-color:var(--pink-300);background:#fff}
.theme-picker__swatch.active{border-color:var(--pink-500);background:#fff}

/* ===== PLAYLIST ===== */
.playlist{
  position:fixed;top:80px;left:20px;z-index:40;
  display:flex;flex-direction:column;gap:6px;
  background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  padding:8px;border-radius:16px;
  border:2px solid var(--pink-200);
  box-shadow:0 6px 18px -6px rgba(228,31,135,.35);
  opacity:0;pointer-events:none;transform:translateX(-20px);transition:all .3s;
}
.playlist.show{opacity:1;pointer-events:auto;transform:translateX(0)}
.playlist__opt{
  background:transparent;border:none;padding:6px 12px;border-radius:10px;
  font-size:12px;font-weight:700;color:var(--ink);text-align:left;
  transition:all .2s;
}
.playlist__opt:hover{background:var(--pink-100)}
.playlist__opt.active{background:linear-gradient(135deg,var(--pink-400),var(--violet));color:#fff}

/* ===== DANCE BUTTON ===== */
.dance-btn{
  position:fixed;bottom:80px;left:20px;z-index:60;
  width:48px;height:48px;border-radius:50%;border:none;
  background:linear-gradient(135deg,#fff,var(--pink-200));
  font-size:24px;box-shadow:var(--shadow);
  transition:transform .3s;
}
.dance-btn:hover{transform:scale(1.15) rotate(20deg)}
body.dancing{animation:pageDance .8s cubic-bezier(.36,.07,.19,.97) 3}
@keyframes pageDance{
  0%,100%{transform:translate(0)}
  10%{transform:translate(-6px,-2px) rotate(-1deg)}
  30%{transform:translate(6px,2px) rotate(1deg)}
  50%{transform:translate(-4px,-4px) rotate(-.5deg)}
  70%{transform:translate(4px,4px) rotate(.5deg)}
  90%{transform:translate(-2px,0)}
}

/* ===== SCREEN SHAKE ===== */
body.shake{animation:shakeIt .5s}
@keyframes shakeIt{
  0%,100%{transform:translate(0)}
  20%{transform:translate(-10px,4px) rotate(-1deg)}
  40%{transform:translate(10px,-4px) rotate(1deg)}
  60%{transform:translate(-8px,4px) rotate(-.5deg)}
  80%{transform:translate(8px,-2px)}
}

/* ===== ACHIEVEMENT ===== */
.achievement{
  position:fixed;top:20px;left:50%;transform:translate(-50%,-120%);
  background:linear-gradient(135deg,#fff,#fff4fa);
  border:3px solid var(--gold);border-radius:22px;padding:14px 20px;
  display:flex;align-items:center;gap:14px;
  box-shadow:0 20px 50px -10px rgba(0,0,0,.3), 0 0 0 6px rgba(255,216,107,.3);
  z-index:200;transition:transform .6s cubic-bezier(.34,1.56,.64,1);
  max-width:90vw;
}
.achievement.show{transform:translate(-50%,0)}
.achievement__icon{
  font-size:38px;animation:wobble 1s ease-in-out infinite;
  filter:drop-shadow(0 4px 8px rgba(255,216,107,.6));
}
.achievement__kicker{font-size:11px;font-weight:700;color:var(--pink-500);letter-spacing:1px;text-transform:uppercase}
.achievement__title{font-family:'Pacifico',cursive;font-size:22px;color:var(--pink-600);line-height:1}

/* ===== KARAOKE ===== */
.karaoke{
  position:fixed;left:20px;bottom:90px;transform:translateX(-10px) scale(.95);
  display:flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,rgba(61,22,64,.95),rgba(168,85,247,.95));
  backdrop-filter:blur(12px);
  color:#fff;padding:10px 16px;border-radius:18px;
  border:2px solid var(--gold);
  box-shadow:0 12px 30px rgba(0,0,0,.3);
  text-align:left;z-index:150;
  opacity:0;pointer-events:none;transition:all .4s cubic-bezier(.34,1.56,.64,1);
  max-width:min(70vw,380px);
}
.karaoke.show{opacity:1;transform:translateX(0) scale(1)}
.karaoke__icon{font-size:20px;margin-bottom:0;animation:wobble 1s infinite;flex-shrink:0}
.karaoke__line{
  font-family:'Pacifico',cursive;font-size:clamp(13px,1.6vw,16px);
  background:linear-gradient(90deg,var(--gold),#fff,var(--gold));
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shineText 2s linear infinite;
  text-shadow:none;min-height:0;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ===== QUIZ ===== */
.quiz{
  background:linear-gradient(180deg,#fff,#fff4fa);
  border:3px solid var(--pink-200);border-radius:28px;padding:34px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
  min-height:340px;
}
.quiz::before{
  content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;
  background:radial-gradient(circle,var(--pink-200),transparent 70%);
  border-radius:50%;
}
.quiz__step{display:none;position:relative;z-index:1}
.quiz__step.active{display:block;animation:fadeIn .4s}
.quiz__step h3{
  font-family:'Pacifico',cursive;font-weight:400;font-size:26px;color:var(--pink-600);
  margin-bottom:22px;text-align:center;
}
.quiz__opts{display:flex;flex-direction:column;gap:10px}
.quiz__opt{
  padding:14px 18px;border-radius:14px;
  border:2px solid var(--pink-200);background:#fff;
  font-weight:700;font-size:15px;color:var(--ink);text-align:left;
  transition:all .2s;
}
.quiz__opt:hover{border-color:var(--pink-500);background:var(--pink-50);transform:translateX(6px)}

.quiz__result{display:none;text-align:center}
.quiz__result.show{display:block;animation:pop .5s cubic-bezier(.34,1.56,.64,1)}
.quiz__result-emoji{font-size:80px;margin-bottom:10px;animation:beat 1s infinite}
.quiz__result h3{font-family:'Pacifico',cursive;font-weight:400;font-size:30px;color:var(--pink-600);margin-bottom:12px}
.quiz__result p{font-size:16px;line-height:1.5;color:var(--ink);margin-bottom:20px}
.quiz__result .btn{margin:4px}

/* ===== WHEEL ===== */
.section--wheel{background:linear-gradient(180deg,transparent,rgba(255,230,245,.6),transparent)}
.section__sub{text-align:center;color:var(--ink);opacity:.7;margin-top:8px;font-weight:600}
.wheel-wrap{
  max-width:500px;margin:0 auto;text-align:center;position:relative;
  padding-top:20px;
}
.wheel-pointer{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  font-size:36px;color:var(--pink-600);z-index:3;
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.3));
  animation:pointerBob 1.5s ease-in-out infinite;
}
@keyframes pointerBob{50%{transform:translateX(-50%) translateY(4px)}}
.wheel{
  position:relative;width:360px;height:360px;max-width:80vw;max-height:80vw;
  margin:0 auto 26px;border-radius:50%;
  border:8px solid #fff;
  box-shadow:0 25px 60px -10px rgba(228,31,135,.5), inset 0 0 0 4px var(--pink-400);
  overflow:hidden;
  transition:transform 5s cubic-bezier(.17,.67,.29,1);
}
.wheel__slice{
  position:absolute;top:0;left:50%;width:50%;height:50%;
  transform-origin:0% 100%;
  transform:rotate(calc(var(--i) * 45deg)) skewY(-45deg);
  background:var(--c);
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:14px;
  color:#fff;font-family:'Lobster',cursive;font-size:18px;
  text-shadow:1px 1px 0 rgba(0,0,0,.2);
}
.wheel__slice span{transform:skewY(45deg) rotate(22.5deg);display:block}
.wheel__center{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:80px;height:80px;border-radius:50%;
  background:linear-gradient(135deg,#fff,var(--pink-200));
  display:flex;align-items:center;justify-content:center;
  font-family:'Pacifico',cursive;color:var(--pink-600);font-size:18px;
  box-shadow:0 6px 14px rgba(0,0,0,.25);z-index:2;
}
.wheel__btn{margin:10px}
.wheel__result{
  min-height:30px;margin-top:12px;
  font-family:'Pacifico',cursive;font-size:26px;color:var(--pink-600);
  opacity:0;transition:opacity .5s;
}
.wheel__result.show{opacity:1;animation:pop .4s cubic-bezier(.34,1.56,.64,1)}

/* ===== CERTIFICAT BFF ===== */
.cert-gen{
  display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:26px;
}
.cert-gen input{
  padding:12px 18px;border-radius:999px;border:2px solid var(--pink-300);
  font-family:'Quicksand',sans-serif;font-size:15px;font-weight:600;color:var(--ink);
  background:#fff;min-width:220px;outline:none;
}
.cert-gen input:focus{border-color:var(--pink-500);box-shadow:0 0 0 4px rgba(255,110,181,.2)}

.cert{
  opacity:0;pointer-events:none;transform:translateY(40px) scale(.9);
  transition:all .6s cubic-bezier(.34,1.56,.64,1);
}
.cert.show{opacity:1;pointer-events:auto;transform:none}
.cert__border{
  max-width:560px;margin:0 auto;padding:40px 30px;
  background:linear-gradient(135deg,#fff 0%, #fff9fc 100%);
  border:6px double var(--pink-500);
  border-radius:8px;text-align:center;position:relative;
  box-shadow:0 30px 60px -15px rgba(228,31,135,.4);
}
.cert__border::before,.cert__border::after{
  content:'✨';position:absolute;font-size:30px;
}
.cert__border::before{top:10px;left:16px}
.cert__border::after{bottom:10px;right:16px}
.cert__seal{
  position:absolute;top:-24px;right:-24px;
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#ffb01d);
  display:flex;align-items:center;justify-content:center;font-size:28px;
  box-shadow:0 6px 14px rgba(0,0,0,.25);
  border:3px solid #fff;
  animation:spin 8s linear infinite;
}
.cert__title{
  font-family:'Lobster',cursive;font-size:14px;letter-spacing:3px;color:var(--pink-500);
}
.cert__sub{
  font-family:'Pacifico',cursive;font-size:42px;color:var(--pink-600);
  margin:10px 0 24px;line-height:1;
}
.cert__body{font-size:18px;line-height:1.7;color:var(--ink);margin-bottom:20px}
.cert__body strong{font-family:'Pacifico',cursive;font-weight:400;font-size:22px;color:var(--pink-600)}
.cert__stars{font-size:22px;margin-bottom:24px;letter-spacing:8px}
.cert__signatures{
  display:flex;justify-content:space-around;gap:20px;flex-wrap:wrap;
  padding-top:20px;border-top:1px dashed var(--pink-300);
}
.cert__signatures>div{display:flex;flex-direction:column}
.cert__signatures span{font-family:'Pacifico',cursive;font-size:18px;color:var(--pink-600)}
.cert__signatures small{font-size:11px;opacity:.6;color:var(--ink)}

/* ===== YT PLAYER HIDDEN ===== */
#ytHolder{position:fixed;bottom:-300px;left:-300px;width:2px;height:2px;opacity:0;pointer-events:none}

/* ===== UNMUTE NAG ===== */
.unmute-nag{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:linear-gradient(135deg,var(--pink-500),var(--violet));
  color:#fff;padding:20px 32px;border-radius:999px;
  font-weight:800;font-size:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.5), 0 0 0 6px rgba(255,255,255,.3);
  z-index:250;pointer-events:none;
  animation:nagPulse 1.5s ease-in-out infinite;
  border:3px solid #fff;
}
.unmute-nag.gone{opacity:0;transform:translate(-50%,-50%) scale(.5);transition:all .5s}
@keyframes nagPulse{50%{transform:translate(-50%,-50%) scale(1.05)}}

/* ===== NOW PLAYING ===== */
.now-playing{
  position:fixed;bottom:20px;right:80px;z-index:40;
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.9);backdrop-filter:blur(12px);
  border:2px solid var(--pink-200);border-radius:999px;
  padding:6px 16px 6px 6px;
  box-shadow:0 10px 24px -6px rgba(228,31,135,.4);
  opacity:0;transform:translateY(40px);transition:all .5s;
  max-width:280px;
}
.now-playing.show{opacity:1;transform:translateY(0)}
.np__disc{
  width:36px;height:36px;flex-shrink:0;border-radius:50%;
  background:
    radial-gradient(circle at center, var(--pink-50) 0 8px, transparent 9px),
    radial-gradient(circle at center, var(--pink-500) 0 100%);
  border:2px solid #fff;
  box-shadow:0 4px 10px rgba(0,0,0,.2);
  animation:spin 3s linear infinite;
}
.np__label{font-size:10px;letter-spacing:1px;color:var(--pink-500);font-weight:700;text-transform:uppercase}
.np__title{font-size:13px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ====== RESPONSIVE ====== */
@media (max-width:880px){
  .nav__links{
    position:fixed;top:70px;left:16px;right:16px;
    background:rgba(255,255,255,.98);backdrop-filter:blur(14px);
    border-radius:24px;padding:16px;
    flex-direction:column;gap:10px;align-items:flex-start;
    display:none;box-shadow:var(--shadow);border:2px solid var(--pink-200);
  }
  .nav__links.mobile{display:flex}
  .nav__cta{display:none}
  .burger{display:flex}
  .music-btn__label{display:none}
  .hero__strip{grid-template-columns:repeat(2,1fr)}
  .showcase,.contact-grid{grid-template-columns:1fr;gap:40px}
  .showcase__visual{height:380px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr 1fr;gap:24px}
  .form__row{grid-template-columns:1fr}
  .section--dark{border-radius:32px;margin:0 12px}
  .stay-bar__text{max-width:52vw}
  .mascot{width:80px;height:100px;right:70px;bottom:15px}
  .mascot__wrench{font-size:20px}
  .theme-picker{left:75px;bottom:15px}
  .dance-btn{bottom:70px;left:15px}
  .live-count{top:70px;right:12px;font-size:11px;padding:6px 10px}
  .ticker{top:115px;right:12px;max-width:230px;font-size:12px;padding:8px 12px}
  .now-playing{right:70px;bottom:15px;display:none}
  .scroll-progress{height:3px}
  .quiz{padding:22px}
  .cert__border{padding:30px 18px}
  .cert__sub{font-size:32px}
  .cert__body{font-size:15px}
}
