/* ═══════════════════════════════════════════════
   REVOLUTION SAMBAFIT® — MAIN STYLESHEET
   ═══════════════════════════════════════════════ */

:root {
  --viola:       #3A006F;
  --lime:        #D2FF00;
  --oro:         #FFC600;
  --lavanda:     #BF70F0;
  --viola-dark:  #12002B;
  --viola-mid:   #220040;
  --viola-card:  rgba(58,0,111,0.35);
  --glass:       rgba(255,255,255,0.055);
  --glass-b:     rgba(255,255,255,0.1);
  --glass-h:     rgba(255,255,255,0.09);
  --text:        #ffffff;
  --text-sec:    rgba(255,255,255,0.68);
  --text-muted:  rgba(255,255,255,0.38);

  --font-h: 'Montserrat', sans-serif;
  --font-b: 'Inter', sans-serif;

  --max-w:    1200px;
  --pad-sec:  clamp(64px, 8vw, 110px) 0;
  --nav-h:    80px;
  --radius:   16px;
  --radius-s: 10px;
  --radius-xl:28px;
  --shadow:   0 24px 80px rgba(0,0,0,0.45);
  --shadow-s: 0 8px 24px rgba(0,0,0,0.25);
  --ease:     all 0.32s cubic-bezier(0.4,0,0.2,1);
}

/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-b);
  background:var(--viola-dark);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit}

/* ─── LAYOUT ─── */
.container{
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 clamp(20px,4vw,48px);
}
.section{padding:var(--pad-sec)}
.section-alt{background:var(--viola-mid)}

/* ─── TYPOGRAPHY HELPERS ─── */
.gradient-text{
  background:linear-gradient(125deg,var(--lime) 0%,var(--oro) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ─── HERO CURTAIN REVEAL ─── */
.hl{
  display:inline-block;
  overflow:hidden;
  vertical-align:bottom;
  padding-bottom:.06em; /* prevents descenders from clipping */
}
.hl-i{
  display:inline-block;
  transform:translateY(110%);
  /* transition set by JS to fire after paint */
}

/* ─── HERO FADE ELEMENTS ─── */
.h-reveal{
  opacity:0;
  transform:translateY(16px);
  /* transition set by JS */
}

/* ─── ANIMATED GRADIENT ON HERO RITMO ─── */
#heroRitmo{
  background:linear-gradient(90deg,
    var(--lime)    0%,
    var(--oro)     30%,
    var(--lavanda) 60%,
    var(--lime)   100%
  );
  background-size:300% auto;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:ritmoGradient 3.5s linear infinite;
}
@keyframes ritmoGradient{
  0%  {background-position:0% center}
  100%{background-position:300% center}
}
.lime{color:var(--lime)}
.oro{color:var(--oro)}

.tag{
  display:inline-block;
  background:rgba(210,255,0,0.1);
  color:var(--lime);
  border:1px solid rgba(210,255,0,0.28);
  padding:5px 16px;
  border-radius:50px;
  font-size:11px;
  font-weight:700;
  letter-spacing:2.5px;
  text-transform:uppercase;
  margin-bottom:18px;
}

.sec-hd{
  text-align:center;
  max-width:660px;
  margin:0 auto 64px;
}
.sec-hd .tag{display:block;margin-bottom:14px}
.sec-title{
  font-family:var(--font-h);
  font-weight:900;
  font-size:clamp(34px,5vw,58px);
  line-height:1.05;
  letter-spacing:-1px;
  margin-bottom:16px;
}
.sec-sub{
  color:var(--text-sec);
  font-size:17px;
  line-height:1.75;
}

/* ─── BUTTONS ─── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 34px;
  border-radius:50px;
  font-family:var(--font-h);font-weight:700;font-size:13.5px;
  letter-spacing:0.6px;text-transform:uppercase;
  transition:var(--ease);cursor:pointer;
  border:2px solid transparent;white-space:nowrap;
}
.btn-primary{background:var(--lime);color:var(--viola-dark);border-color:var(--lime)}
.btn-primary:hover{background:var(--oro);border-color:var(--oro);transform:translateY(-2px);box-shadow:0 12px 40px rgba(210,255,0,.28)}
.btn-outline{background:transparent;color:var(--text);border-color:rgba(255,255,255,.45)}
.btn-outline:hover{border-color:var(--lime);color:var(--lime);transform:translateY(-2px)}
.btn-ghost{background:var(--glass);color:var(--text);border-color:var(--glass-b)}
.btn-ghost:hover{border-color:var(--lime);color:var(--lime)}
.btn-lg{padding:18px 48px;font-size:15px}
.btn-full{width:100%}
.btn-oro{background:var(--oro);color:var(--viola-dark);border-color:var(--oro)}
.btn-oro:hover{filter:brightness(1.1);transform:translateY(-2px)}

/* ─── NAVBAR ─── */
.navbar{
  position:fixed;top:0;left:0;right:0;
  height:var(--nav-h);
  z-index:1000;
  transition:background .4s ease,box-shadow .4s ease;
}
.navbar.scrolled{
  background:rgba(18,0,43,.96);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--glass-b);
  box-shadow:0 4px 40px rgba(0,0,0,.35);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;
}
.nav-logo img{height:68px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links li a{
  padding:8px 14px;border-radius:50px;
  font-weight:600;font-size:13.5px;
  color:rgba(255,255,255,.82);
  transition:var(--ease);
}
.nav-links li a:hover{color:var(--lime)}
.nav-cta{
  background:var(--lime)!important;
  color:var(--viola-dark)!important;
  font-weight:800!important;
  padding:9px 22px!important;
}
.nav-cta:hover{background:var(--oro)!important;color:var(--viola-dark)!important}

/* ─── SELETTORE LINGUA (bandierina) ─── */
.nav-lang{position:relative;display:flex;align-items:center;margin-left:4px}
.lang-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 12px;border-radius:50px;cursor:pointer;
  background:var(--glass);border:1px solid var(--glass-b);
  color:rgba(255,255,255,.9);font-weight:700;font-size:13px;
  transition:var(--ease);line-height:1;
}
.lang-btn:hover{border-color:rgba(210,255,0,.4);color:var(--lime)}
.lang-btn .lang-flag{font-size:16px;line-height:1}
.lang-btn .lang-caret{transition:transform .2s ease;opacity:.7}
.nav-lang.open .lang-btn .lang-caret{transform:rotate(180deg)}
.lang-menu{
  position:absolute;top:calc(100% + 10px);right:0;z-index:200;
  min-width:180px;list-style:none;margin:0;padding:6px;
  background:rgba(18,0,43,.98);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-b);border-radius:var(--radius-s);
  box-shadow:0 12px 40px rgba(0,0,0,.45);
  opacity:0;transform:translateY(-8px);pointer-events:none;
  transition:var(--ease);
}
.nav-lang.open .lang-menu{opacity:1;transform:translateY(0);pointer-events:all}
.lang-option{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:9px 12px;border-radius:8px;cursor:pointer;
  background:none;border:none;color:rgba(255,255,255,.82);
  font-weight:600;font-size:13.5px;text-align:left;transition:var(--ease);
}
.lang-option:hover{background:var(--glass);color:var(--lime)}
.lang-option.active{background:rgba(210,255,0,.12);color:var(--lime)}
.lang-option .lang-flag{font-size:18px;line-height:1}

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

/* ─── HERO ─── */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;overflow:hidden;
  padding-bottom:100px;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center 25%;
  transition:transform 8s ease;transform:scale(1.06);
}
.hero-bg.loaded{transform:scale(1)}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    130deg,
    rgba(18,0,43,.94) 0%,
    rgba(58,0,111,.72) 55%,
    rgba(18,0,43,.88) 100%
  );
}
.hero-content{
  position:relative;z-index:2;
  padding-top:80px;
  max-width:820px;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(210,255,0,.1);
  color:var(--lime);
  border:1px solid rgba(210,255,0,.3);
  padding:8px 20px;border-radius:50px;
  font-size:11.5px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  margin-bottom:20px;
}
.hero-badge::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--lime);animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}

.hero-title{
  font-family:var(--font-h);
  font-weight:900;
  font-size:clamp(50px,8.5vw,104px);
  line-height:.92;
  letter-spacing:-2.5px;
  text-transform:uppercase;
  margin-bottom:20px;
}
.hero-sub{
  font-size:18px;color:var(--text-sec);
  max-width:520px;margin-bottom:44px;line-height:1.75;
}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap}

.hero-scroll{
  position:absolute;bottom:36px;left:50%;
  transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  color:var(--text-muted);font-size:10px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;
}
.scroll-bar{
  width:1px;height:52px;
  background:linear-gradient(to bottom,var(--lime),transparent);
  animation:scrollAnim 2s ease-in-out infinite;
}
@keyframes scrollAnim{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.4;transform:scaleY(.6)}}

/* ─── STATS BAR ─── */
.stats-bar{background:var(--lime);padding:36px 0}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}
.stat-n{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(28px,4vw,42px);
  color:var(--viola-dark);line-height:1;
}
.stat-l{
  font-size:11px;font-weight:600;
  color:rgba(26,0,53,.65);
  text-transform:uppercase;letter-spacing:1.2px;
}

/* ─── METHOD CARDS ─── */
.method-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;margin-bottom:80px;
}
.method-card{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);padding:32px 24px;
  transition:var(--ease);
}
.method-card:hover{
  background:var(--glass-h);
  border-color:rgba(210,255,0,.32);
  transform:translateY(-5px);
  box-shadow:0 20px 60px rgba(0,0,0,.3);
}
.method-icon{
  width:56px;height:56px;border-radius:16px;
  background:rgba(210,255,0,.1);border:1px solid rgba(210,255,0,.14);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:22px;color:var(--lime);flex-shrink:0;
}
.method-icon svg{width:28px;height:28px;stroke-width:1.75}
.method-card h3{
  font-family:var(--font-h);font-weight:700;font-size:17px;
  margin-bottom:10px;
}
.method-card p{color:var(--text-sec);font-size:14px;line-height:1.75}

/* ─── METHOD VISUAL ─── */
.method-visual{
  display:grid;grid-template-columns:1fr 1fr;
  gap:72px;align-items:center;
}
.method-img-wrap{position:relative}
.method-img{
  width:100%;height:520px;object-fit:cover;
  object-position:top;
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
}
.method-badge{
  position:absolute;bottom:24px;right:-24px;
  background:var(--lime);color:var(--viola-dark);
  padding:18px 24px;border-radius:var(--radius);
  box-shadow:var(--shadow-s);
}
.method-badge span{
  display:block;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:1px;margin-bottom:2px;
  opacity:.7;
}
.method-badge strong{font-family:var(--font-h);font-size:15px;font-weight:900}

.method-text h3{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(28px,3.5vw,40px);line-height:1.15;
  margin-bottom:24px;
}
.method-text p{color:var(--text-sec);margin-bottom:16px;line-height:1.8;font-size:16px}
.method-text .btn{margin-top:12px}

/* ─── CTA SECTION ─── */
.cta-sec{position:relative;padding:clamp(80px,10vw,140px) 0;overflow:hidden}
.cta-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:blur(3px) brightness(.35) saturate(1.3);
  transform:scale(1.04);
}
.cta-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(58,0,111,.88),rgba(18,0,43,.82));
}
.cta-inner{
  position:relative;z-index:2;
  text-align:center;max-width:820px;margin:0 auto;
}
.cta-title{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(30px,5vw,54px);line-height:1.1;
  margin-bottom:20px;
}
.cta-inner>p{color:var(--text-sec);font-size:18px;margin-bottom:40px;line-height:1.75}

/* ─── FEATURES LIST (diventa-istruttore) ─── */
.features-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:28px;margin-bottom:0;
}
.feat-card{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);padding:36px 28px;
  transition:var(--ease);
}
.feat-card:hover{
  border-color:rgba(210,255,0,.3);
  background:var(--glass-h);
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(0,0,0,.25);
}
.feat-num{
  font-family:var(--font-h);font-weight:900;
  font-size:52px;line-height:1;
  color:rgba(210,255,0,.18);
  margin-bottom:16px;
}
.feat-card h3{
  font-family:var(--font-h);font-weight:800;
  font-size:19px;margin-bottom:12px;
}
.feat-card p{color:var(--text-sec);font-size:14.5px;line-height:1.75}

/* ─── STEPS (diventa-istruttore) ─── */
.steps-grid{display:flex;flex-direction:column;gap:0}
.step{
  display:grid;grid-template-columns:80px 1fr;
  gap:32px;align-items:start;
  padding:40px 0;
  border-bottom:1px solid var(--glass-b);
}
.step:last-child{border-bottom:none}
.step-num{
  font-family:var(--font-h);font-weight:900;
  font-size:64px;line-height:1;
  color:var(--lime);
  opacity:.9;
}
.step-content h3{
  font-family:var(--font-h);font-weight:800;
  font-size:22px;margin-bottom:10px;margin-top:12px;
}
.step-content p{color:var(--text-sec);font-size:15px;line-height:1.8}

/* ─── WHAT YOU GET (area istruttori preview) ─── */
.gets-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:20px;
}
.get-item{
  display:flex;align-items:flex-start;gap:16px;
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);padding:24px;
  transition:var(--ease);
}
.get-item:hover{border-color:rgba(210,255,0,.3);background:var(--glass-h)}
.get-icon{
  width:48px;height:48px;border-radius:12px;
  background:rgba(210,255,0,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.get-text h4{font-family:var(--font-h);font-weight:700;font-size:15px;margin-bottom:4px}
.get-text p{color:var(--text-sec);font-size:13.5px;line-height:1.6}

/* ─── EDUARDO ─── */
.eduardo-grid{
  display:grid;grid-template-columns:1fr 1.15fr;
  gap:80px;align-items:center;
}
.edu-imgs{position:relative;}
.edu-main{
  display:block;
  width:100%;aspect-ratio:4/5;
  object-fit:cover;object-position:top;
  border-radius:var(--radius-xl);box-shadow:var(--shadow);
}
.edu-bio .sec-title{text-align:left;margin-bottom:8px}
.bio-p{color:var(--text-sec);margin-bottom:16px;line-height:1.85;font-size:15.5px}
.achievements{display:flex;flex-direction:column;gap:14px;margin:28px 0}
.achiev{
  display:flex;align-items:center;gap:16px;
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius-s);padding:16px 20px;
  transition:var(--ease);
}
.achiev:hover{border-color:rgba(191,112,240,.3);background:var(--glass-h)}
.achiev-ico{
  width:52px;height:52px;border-radius:14px;
  background:rgba(210,255,0,.08);border:1px solid rgba(210,255,0,.12);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--lime);
}
.achiev-ico svg{width:24px;height:24px;stroke-width:1.75}
.achiev-txt strong{display:block;font-weight:700;font-size:14.5px;margin-bottom:2px}
.achiev-txt span{color:var(--text-sec);font-size:13px}

/* ─── INSTRUCTORS MARQUEE ─── */
.instrs-marquee{
  overflow:hidden;
  display:flex;flex-direction:column;gap:14px;
  padding:8px 0 24px;
  /* Fade ai bordi sinistro e destro */
  mask-image:linear-gradient(to right,transparent 0%,black 7%,black 93%,transparent 100%);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,black 7%,black 93%,transparent 100%);
}
.instrs-track{
  display:flex;gap:14px;
  width:max-content;
  animation:instrLeft 40s linear infinite;
  will-change:transform;
}
.instrs-track--rev{
  animation:instrRight 36s linear infinite;
}
@keyframes instrLeft{
  from{transform:translateX(0)}
  to  {transform:translateX(-50%)}
}
@keyframes instrRight{
  from{transform:translateX(-50%)}
  to  {transform:translateX(0)}
}
.instrs-marquee .instr-card{
  width:240px;flex-shrink:0;
}
.instr-card{
  position:relative;border-radius:var(--radius);
  overflow:hidden;aspect-ratio:3/4;cursor:pointer;
  /* Consistent brand gradient — all photos blend into this */
  background:linear-gradient(160deg,
    var(--viola-mid)      0%,
    var(--viola)          60%,
    rgba(191,112,240,.4) 100%
  );
  isolation:isolate;
  transition:transform .32s cubic-bezier(.4,0,.2,1),
             box-shadow  .32s cubic-bezier(.4,0,.2,1);
}
.instr-card:hover{
  transform:translateY(-5px);
  box-shadow:0 28px 72px rgba(0,0,0,.55),0 0 0 1px rgba(210,255,0,.28);
}
.instr-card img{
  width:100%;height:100%;object-fit:cover;
  object-position:center top;
  transition:transform .6s ease, opacity .35s ease;
  /* mix-blend-mode: luminosity unifica tutti gli sfondi diversi delle foto */
  mix-blend-mode:luminosity;
  opacity:.88;
  display:block;
}
.instr-card:hover img{transform:scale(1.07);opacity:.72}

/* Barra accent lime che scorre da sinistra al hover */
.instr-card::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:2px;z-index:3;
  background:linear-gradient(90deg,var(--lime),var(--lavanda));
  transform:scaleX(0);transform-origin:left;
  transition:transform .42s cubic-bezier(.4,0,.2,1);
}
.instr-card:hover::after{transform:scaleX(1)}

/* Overlay sempre visibile — nome non si nasconde più */
.instr-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,
    rgba(12,0,30,.95)  0%,
    rgba(18,0,43,.55)  35%,
    transparent        62%
  );
  display:flex;align-items:flex-end;padding:22px 20px;
}
.instr-overlay .instr-info{
  display:flex;flex-direction:column;gap:5px;
}
.instr-overlay h3{
  font-family:var(--font-h);font-weight:800;font-size:16px;
  color:var(--text);margin:0;line-height:1.2;
}
.instr-overlay span{
  font-weight:700;font-size:10px;
  color:var(--lime);text-transform:uppercase;letter-spacing:1.8px;
}

/* ─── SHOP PREVIEW ─── */
.shop-prev-grid{
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:24px;align-items:start;
}
.shop-feat-card{
  border-radius:var(--radius-xl);overflow:hidden;
  background:var(--glass);border:1px solid var(--glass-b);
  transition:var(--ease);
  box-shadow:0 8px 40px rgba(0,0,0,.3);
}
.shop-feat-card:hover{
  border-color:rgba(210,255,0,.3);
  transform:translateY(-5px);
  box-shadow:0 16px 56px rgba(0,0,0,.4),0 0 0 1px rgba(210,255,0,.1);
}
.shop-feat-img{
  height:400px;background-size:cover;background-position:center top;
  position:relative;overflow:hidden;
}
.shop-feat-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(18,0,43,.7) 0%,rgba(18,0,43,.1) 50%,transparent 100%);
}
.badge-new{
  position:absolute;top:20px;left:20px;z-index:1;
  background:var(--lime);color:var(--viola-dark);
  font-family:var(--font-h);font-weight:900;
  font-size:10px;letter-spacing:2px;
  padding:6px 16px;border-radius:50px;
  box-shadow:0 4px 16px rgba(210,255,0,.35);
}
.shop-feat-body{padding:30px}
.shop-feat-eyebrow{margin-bottom:10px}
.shop-feat-tag{
  font-size:11px;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--lime);
}
.shop-feat-body h3{
  font-family:var(--font-h);font-weight:800;font-size:24px;
  margin-bottom:10px;line-height:1.2;
}
.shop-feat-body p{color:var(--text-sec);font-size:14px;line-height:1.65;margin-bottom:24px}
.shop-feat-cta{
  display:inline-flex;align-items:center;gap:8px;
}
.shop-feat-cta svg{transition:transform .2s ease}
.shop-feat-cta:hover svg{transform:translateX(4px)}

.shop-smalls{display:flex;flex-direction:column;gap:14px}
.shop-sm-card{
  display:grid;grid-template-columns:120px 1fr;
  border-radius:var(--radius);overflow:hidden;
  background:var(--glass);border:1px solid var(--glass-b);
  transition:var(--ease);
  box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.shop-sm-card:hover{
  border-color:rgba(210,255,0,.3);
  transform:translateX(5px);
  box-shadow:0 8px 28px rgba(0,0,0,.3);
}
.shop-sm-img{
  background-size:cover;background-position:center top;
  transition:transform .4s ease;
}
.shop-sm-card:hover .shop-sm-img{transform:scale(1.05)}
.shop-sm-body{
  padding:18px 20px;display:flex;flex-direction:column;
  justify-content:center;gap:10px;
}
.shop-sm-body span{
  font-family:var(--font-h);font-weight:700;font-size:15px;
}
.shop-sm-link{
  display:inline-flex;align-items:center;gap:5px;
  color:var(--lime);font-weight:700;font-size:12px;
  letter-spacing:.3px;transition:var(--ease);
}
.shop-sm-link svg{transition:transform .2s ease}
.shop-sm-link:hover{color:var(--oro)}
.shop-sm-link:hover svg{transform:translateX(3px)}

.shop-view-all{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:var(--radius);
  border:1px solid var(--glass-b);background:var(--glass);
  color:var(--text-sec);font-weight:600;font-size:13px;
  transition:var(--ease);margin-top:4px;
}
.shop-view-all:hover{
  border-color:rgba(210,255,0,.3);color:var(--lime);
  transform:translateY(-2px);
}
.shop-view-all svg{transition:transform .2s ease}
.shop-view-all:hover svg{transform:translateX(4px)}

/* ─── SHOP PAGE ─── */
.shop-hero{
  position:relative;padding:clamp(80px,10vw,130px) 0 clamp(48px,6vw,80px);
  background:linear-gradient(160deg,var(--viola-mid),var(--viola-dark));
  overflow:hidden;
}
.shop-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 80% 50%,rgba(191,112,240,.18),transparent);
}
.shop-hero-inner{position:relative;z-index:1;max-width:600px}

.shop-filters{
  display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px;
}
.filter-btn{
  padding:8px 22px;border-radius:50px;
  border:1px solid var(--glass-b);
  background:var(--glass);
  font-family:var(--font-h);font-weight:600;font-size:13px;
  color:var(--text-sec);
  transition:var(--ease);cursor:pointer;
}
.filter-btn:hover,.filter-btn.active{
  background:var(--lime);border-color:var(--lime);
  color:var(--viola-dark);
}

.products-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.product-card{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);overflow:hidden;
  transition:var(--ease);
}
.product-card:hover{
  border-color:rgba(210,255,0,.3);
  transform:translateY(-5px);
  box-shadow:var(--shadow-s);
}
.product-img{
  height:260px;background-size:cover;background-position:center top;
  position:relative;overflow:hidden;
}
.product-img::after{
  content:'';position:absolute;inset:0;
  background:rgba(18,0,43,.15);
  transition:var(--ease);
}
.product-card:hover .product-img::after{background:rgba(18,0,43,.05)}
.product-tag{
  position:absolute;top:12px;left:12px;z-index:1;
  background:var(--viola);color:var(--text);
  font-size:10px;font-weight:700;letter-spacing:1.5px;
  padding:4px 12px;border-radius:50px;text-transform:uppercase;
}
.product-tag.sale{background:var(--oro);color:var(--viola-dark)}
.product-body{padding:18px 20px}
.product-body h3{
  font-family:var(--font-h);font-weight:700;
  font-size:15px;margin-bottom:4px;
}
.product-body .cat{
  color:var(--text-muted);font-size:12px;
  text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;
}
.product-footer{
  display:flex;align-items:center;justify-content:space-between;
  gap:8px;
}
.price{
  font-family:var(--font-h);font-weight:800;
  font-size:20px;color:var(--lime);
}
.price-old{
  font-size:13px;color:var(--text-muted);
  text-decoration:line-through;margin-top:2px;
}
.add-cart{
  width:40px;height:40px;border-radius:50%;
  background:var(--lime);color:var(--viola-dark);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
  transition:var(--ease);
}
.add-cart:hover{background:var(--oro);transform:scale(1.12)}

/* Cart counter */
.cart-btn{
  position:relative;
  display:flex;align-items:center;gap:8px;
  background:var(--glass);border:1px solid var(--glass-b);
  padding:8px 18px;border-radius:50px;
  font-weight:600;font-size:13px;
  transition:var(--ease);cursor:pointer;color:var(--text);
}
.cart-btn:hover{border-color:var(--lime);color:var(--lime)}
.cart-count{
  position:absolute;top:-4px;right:-4px;
  width:18px;height:18px;border-radius:50%;
  background:var(--lime);color:var(--viola-dark);
  font-size:10px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:var(--ease);
}
.cart-count.show{opacity:1}

/* Cart Drawer */
.cart-drawer{
  position:fixed;top:0;right:-420px;bottom:0;
  width:400px;z-index:2000;
  background:var(--viola-mid);
  border-left:1px solid var(--glass-b);
  box-shadow:-20px 0 60px rgba(0,0,0,.5);
  transition:right .4s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
}
.cart-drawer.open{right:0}
.cart-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 28px;border-bottom:1px solid var(--glass-b);
}
.cart-header h3{font-family:var(--font-h);font-weight:800;font-size:20px}
.cart-close{
  width:36px;height:36px;border-radius:50%;
  background:var(--glass);color:var(--text);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;transition:var(--ease);cursor:pointer;
}
.cart-close:hover{background:rgba(255,255,255,.12)}
.cart-body{flex:1;overflow-y:auto;padding:20px 28px}
.cart-empty{
  text-align:center;padding:60px 0;
  color:var(--text-sec);
}
.cart-empty .icon{font-size:48px;margin-bottom:16px}
.cart-items{display:flex;flex-direction:column;gap:16px}
.cart-item{
  display:grid;grid-template-columns:72px 1fr auto;
  gap:14px;align-items:center;
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius-s);padding:14px;
}
.cart-item-img{
  width:72px;height:72px;border-radius:8px;
  background-size:cover;background-position:center;
}
.cart-item-name{font-weight:600;font-size:14px;margin-bottom:4px}
.cart-item-price{color:var(--lime);font-weight:700;font-size:14px}
.remove-item{
  color:var(--text-muted);font-size:18px;
  cursor:pointer;transition:var(--ease);
  background:none;border:none;
}
.remove-item:hover{color:var(--text)}
.cart-footer{
  padding:20px 28px;border-top:1px solid var(--glass-b);
}
.cart-total{
  display:flex;justify-content:space-between;
  font-family:var(--font-h);font-weight:700;
  font-size:18px;margin-bottom:20px;
}
.cart-total span:last-child{color:var(--lime)}
.cart-overlay{
  display:none;position:fixed;inset:0;z-index:1999;
  background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
}
.cart-overlay.show{display:block}

/* ─── AREA ISTRUTTORI — LOGIN ─── */
.login-page{
  min-height:100vh;display:flex;align-items:center;
  justify-content:center;padding:80px 24px;
  background:linear-gradient(145deg,var(--viola-dark),var(--viola-mid));
}
.login-wrap{
  width:100%;max-width:460px;
}
.login-card{
  background:var(--glass);
  border:1px solid var(--glass-b);
  border-radius:var(--radius-xl);
  padding:48px 44px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(20px);
}
.login-logo{text-align:center;margin-bottom:8px}
.login-logo img{height:52px;margin:0 auto}
.login-card h2{
  font-family:var(--font-h);font-weight:900;
  font-size:26px;text-align:center;margin-bottom:6px;
}
.login-card .sub{
  color:var(--text-sec);text-align:center;
  font-size:14px;margin-bottom:36px;
}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text-sec)}
.field input{
  width:100%;padding:14px 18px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--glass-b);
  border-radius:var(--radius-s);
  color:var(--text);font-size:15px;outline:none;
  transition:var(--ease);
}
.field input:focus{border-color:rgba(210,255,0,.5);background:rgba(255,255,255,.09)}
.field input::placeholder{color:var(--text-muted)}
.login-forgot{
  text-align:right;font-size:13px;
  color:var(--lavanda);margin-top:-8px;margin-bottom:24px;
  display:block;
}
.login-forgot:hover{color:var(--lime)}
.login-note{
  text-align:center;font-size:13px;
  color:var(--text-muted);margin-top:20px;
}
.login-note a{color:var(--lavanda)}
.login-note a:hover{color:var(--lime)}

/* ─── DASHBOARD ISTRUTTORI ─── */
.dashboard{display:none}
.dashboard.show{display:block}
.login-view{display:block}
.login-view.hide{display:none}

.dash-hero{
  background:linear-gradient(135deg,var(--viola),var(--viola-mid));
  border-bottom:1px solid var(--glass-b);
  padding:calc(var(--nav-h) + 48px) 0 48px;
}
.dash-welcome h1{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(28px,4vw,44px);margin-bottom:8px;
}
.dash-welcome p{color:var(--text-sec);font-size:16px}
.dash-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:16px;margin-top:36px;
}
.dash-stat{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);padding:20px 24px;
  display:flex;align-items:center;gap:16px;
}
.dash-stat-ico{
  width:48px;height:48px;border-radius:12px;
  background:rgba(210,255,0,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.dash-stat-val{font-family:var(--font-h);font-weight:800;font-size:22px;line-height:1}
.dash-stat-lbl{color:var(--text-sec);font-size:12px;margin-top:4px}

.videos-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;margin-top:8px;
}
.video-card{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);overflow:hidden;
  transition:var(--ease);cursor:pointer;
}
.video-card:hover{border-color:rgba(210,255,0,.3);transform:translateY(-4px);box-shadow:var(--shadow-s)}
.video-thumb{
  height:160px;position:relative;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.video-thumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.video-thumb-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--viola) 0%,var(--lavanda) 100%);
  opacity:.7;
}
.play-btn{
  position:relative;z-index:1;
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.2);
  backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;
  border:2px solid rgba(255,255,255,.4);
  transition:var(--ease);
}
.video-card:hover .play-btn{background:var(--lime);border-color:var(--lime)}
.video-card:hover .play-btn span{filter:brightness(0)}
.video-badge{
  position:absolute;top:10px;right:10px;z-index:1;
  background:var(--lime);color:var(--viola-dark);
  font-size:9px;font-weight:800;letter-spacing:1px;
  padding:3px 10px;border-radius:50px;text-transform:uppercase;
}
.video-body{padding:14px 16px}
.video-body h4{font-family:var(--font-h);font-weight:700;font-size:14px;margin-bottom:4px}
.video-meta{
  display:flex;align-items:center;gap:12px;
  color:var(--text-sec);font-size:12px;
}
.video-meta span{display:flex;align-items:center;gap:4px}

.dash-section{padding:56px 0}
.dash-section-hd{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:28px;
}
.dash-section-hd h2{
  font-family:var(--font-h);font-weight:800;font-size:24px;
}

/* Profile sidebar */
.dash-grid{
  display:grid;grid-template-columns:280px 1fr;
  gap:32px;align-items:start;
}
.profile-card{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);padding:28px;
  text-align:center;
}
.profile-avatar{
  width:80px;height:80px;border-radius:50%;
  background:linear-gradient(135deg,var(--viola),var(--lavanda));
  display:flex;align-items:center;justify-content:center;
  font-size:32px;margin:0 auto 14px;
  border:3px solid rgba(210,255,0,.3);
}
.profile-card h3{font-family:var(--font-h);font-weight:700;font-size:17px;margin-bottom:4px}
.profile-card .role{
  color:var(--lime);font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:1px;
  margin-bottom:20px;
}
.profile-info{text-align:left;border-top:1px solid var(--glass-b);padding-top:20px}
.prof-row{
  display:flex;flex-direction:column;gap:2px;
  padding:10px 0;border-bottom:1px solid var(--glass-b);
}
.prof-row:last-child{border-bottom:none}
.prof-row span:first-child{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.prof-row span:last-child{font-size:14px;font-weight:500}

/* ─── CONTACT ─── */
.contact-section{position:relative;overflow:hidden}
.contact-glow{
  position:absolute;
  width:600px;height:600px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(191,112,240,.12) 0%,transparent 70%);
  top:-100px;left:-200px;
  pointer-events:none;
}
.contact-grid{
  display:grid;grid-template-columns:1fr 1.2fr;
  gap:56px;align-items:start;
}
.contact-info-card{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius-xl);padding:40px 36px;
  position:relative;overflow:hidden;
}
.contact-info-card::before{
  content:'';position:absolute;
  top:-60px;right:-60px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(210,255,0,.07),transparent 70%);
  pointer-events:none;
}
.contact-brand{
  display:flex;align-items:flex-start;gap:14px;
  margin-bottom:32px;
}
.contact-brand-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--lime);flex-shrink:0;
  margin-top:6px;
  box-shadow:0 0 0 4px rgba(210,255,0,.15);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{box-shadow:0 0 0 4px rgba(210,255,0,.15)}
  50%{box-shadow:0 0 0 8px rgba(210,255,0,.06)}
}
.contact-brand h3{
  font-family:var(--font-h);font-weight:800;
  font-size:24px;margin-bottom:4px;
}
.contact-brand .sub{color:var(--text-sec);font-size:13px;line-height:1.5}
.contact-items{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.contact-item{
  display:flex;align-items:center;gap:14px;
  color:var(--text-sec);font-size:14px;
  padding:12px 14px;border-radius:var(--radius-s);
  background:rgba(255,255,255,.03);border:1px solid transparent;
  transition:var(--ease);
}
.contact-item-link{
  cursor:pointer;
}
.contact-item-link:hover{
  border-color:rgba(210,255,0,.2);
  background:rgba(210,255,0,.04);
  color:var(--lime);
}
.contact-item .ico{
  width:40px;height:40px;border-radius:10px;
  background:rgba(210,255,0,.08);border:1px solid rgba(210,255,0,.12);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--lime);
  transition:var(--ease);
}
.contact-item:hover .ico{background:rgba(210,255,0,.14)}
.contact-divider{
  height:1px;background:var(--glass-b);
  margin-bottom:24px;
}
.socials{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.socials:last-child{margin-bottom:0}
.soc-btn{
  display:flex;align-items:center;gap:8px;
  padding:9px 18px;border-radius:50px;
  border:1px solid var(--glass-b);background:var(--glass);
  font-size:13px;font-weight:600;color:var(--text);
  transition:var(--ease);
}
.soc-btn:hover{border-color:var(--lime);color:var(--lime);background:rgba(210,255,0,.05)}
.contact-response-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:50px;
  background:rgba(255,255,255,.04);border:1px solid var(--glass-b);
  font-size:12px;color:var(--text-sec);
}
.response-dot{
  width:7px;height:7px;border-radius:50%;
  background:#22c55e;flex-shrink:0;
  box-shadow:0 0 6px rgba(34,197,94,.6);
  animation:pulse-dot 1.5s ease-in-out infinite;
}

.contact-form{
  display:flex;flex-direction:column;gap:18px;
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius-xl);padding:40px 36px;
}
.fgroup{display:flex;flex-direction:column;gap:7px}
.fgroup label{
  font-size:12px;font-weight:600;
  color:var(--text-muted);
  letter-spacing:.6px;text-transform:uppercase;
}
.fgroup input,.fgroup select,.fgroup textarea{
  width:100%;padding:14px 18px;
  background:rgba(255,255,255,.05);border:1px solid var(--glass-b);
  border-radius:var(--radius-s);color:var(--text);
  font-size:14px;outline:none;transition:var(--ease);
  -webkit-appearance:none;
}
.fgroup input::placeholder,.fgroup textarea::placeholder{color:var(--text-muted)}
.fgroup select option{background:var(--viola-dark)}
.fgroup input:focus,.fgroup select:focus,.fgroup textarea:focus{
  border-color:rgba(210,255,0,.4);
  background:rgba(210,255,0,.04);
}
.fgroup textarea{resize:vertical;min-height:120px}
.contact-submit{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin-top:4px;
}
.contact-submit svg{transition:transform .2s ease}
.contact-submit:hover svg{transform:translateX(4px)}

/* ─── FOOTER ─── */
.footer{
  background:var(--viola-dark);
  border-top:1px solid var(--glass-b);
  padding:52px 0 32px;
}
.footer-grid{
  display:grid;grid-template-columns:240px 1fr 1fr 1fr;
  gap:48px;margin-bottom:48px;
}
.footer-brand img{height:60px;margin-bottom:16px}
.footer-brand p{color:var(--text-sec);font-size:14px;line-height:1.7}
.footer-col h4{
  font-family:var(--font-h);font-weight:700;
  font-size:13px;text-transform:uppercase;letter-spacing:1.5px;
  margin-bottom:18px;color:var(--text-muted);
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{color:var(--text-sec);font-size:14px;transition:var(--ease)}
.footer-col ul a:hover{color:var(--lime)}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:28px;border-top:1px solid var(--glass-b);
  gap:16px;flex-wrap:wrap;
}
.footer-bottom p,.footer-bottom a{color:var(--text-muted);font-size:13px}
.footer-bottom a:hover{color:var(--lime)}
.footer-socials{display:flex;gap:12px}
.footer-soc{
  width:36px;height:36px;border-radius:50%;
  background:var(--glass);border:1px solid var(--glass-b);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;transition:var(--ease);
}
.footer-soc:hover{background:var(--lime);border-color:var(--lime)}

/* ─── SCROLL REVEAL SYSTEM ─── */
.rv{
  opacity:0;
  transition-property:opacity,transform;
  transition-timing-function:cubic-bezier(0.22,1,0.36,1);
  transition-duration:var(--rv-dur,700ms);
  transition-delay:var(--rv-delay,0ms);
  will-change:opacity,transform;
}
.rv.rv-up    {transform:translateY(44px)}
.rv.rv-down  {transform:translateY(-22px)}
.rv.rv-left  {transform:translateX(54px)}
.rv.rv-right {transform:translateX(-54px)}
.rv.rv-scale {transform:scale(0.88) translateY(14px)}
.rv.is-in{
  opacity:1 !important;
  transform:none !important;
}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1!important;transform:none!important;transition:none!important}
}

/* Legacy — usato da altre pagine */
.fade-up{
  opacity:0;transform:translateY(28px);
  transition:opacity .6s ease,transform .6s ease;
}
.fade-up.in{opacity:1;transform:translateY(0)}

/* ─── NOTIFICATION TOAST ─── */
.toast{
  position:fixed;bottom:28px;right:28px;z-index:9999;
  background:var(--lime);color:var(--viola-dark);
  padding:14px 24px;border-radius:var(--radius-s);
  font-family:var(--font-h);font-weight:700;font-size:14px;
  box-shadow:var(--shadow-s);
  transform:translateY(80px);opacity:0;
  transition:var(--ease);
}
.toast.show{transform:translateY(0);opacity:1}

/* ─── PAGE HERO (generic) ─── */
.page-hero{
  padding:calc(var(--nav-h) + 64px) 0 72px;
  background:linear-gradient(160deg,var(--viola-mid),var(--viola-dark));
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 90% 50%,rgba(210,255,0,.07),transparent);
}
.page-hero-inner{position:relative;z-index:1;max-width:740px}
.page-hero h1{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(40px,6vw,72px);
  line-height:.95;letter-spacing:-1.5px;
  text-transform:uppercase;margin-bottom:22px;
}
.page-hero p{color:var(--text-sec);font-size:17px;line-height:1.75;max-width:540px}

/* ─── DIVENTA HERO IMAGE ─── */
.diventa-hero{
  position:relative;
  min-height:60vh;display:flex;align-items:center;
  overflow:hidden;
}
.diventa-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center 30%;
}
.diventa-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(130deg,rgba(18,0,43,.95),rgba(58,0,111,.8));
}
.diventa-hero-content{
  position:relative;z-index:2;
  padding:calc(var(--nav-h) + 64px) 0 80px;
  max-width:720px;
}
.diventa-hero-content h1{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(44px,7vw,82px);
  line-height:.95;letter-spacing:-2px;
  text-transform:uppercase;margin-bottom:24px;
}
.diventa-hero-content p{
  color:var(--text-sec);font-size:18px;line-height:1.75;
  max-width:520px;margin-bottom:40px;
}

/* ─── PRICING ─── */
.price-card{
  background:var(--glass);border:2px solid var(--glass-b);
  border-radius:var(--radius-xl);padding:44px 40px;
  text-align:center;transition:var(--ease);
  position:relative;
}
.price-card.featured{
  border-color:var(--lime);
  background:rgba(58,0,111,.5);
}
.price-card.featured::before{
  content:'PIÙ SCELTO';
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--lime);color:var(--viola-dark);
  font-family:var(--font-h);font-weight:900;font-size:10px;letter-spacing:2px;
  padding:5px 18px;border-radius:50px;
}
.price-plan{
  font-family:var(--font-h);font-weight:800;font-size:16px;
  text-transform:uppercase;letter-spacing:2px;
  margin-bottom:8px;color:var(--text-sec);
}
.price-amount{
  font-family:var(--font-h);font-weight:900;
  font-size:64px;line-height:1;color:var(--lime);
  margin-bottom:4px;
}
.price-amount sup{font-size:28px;vertical-align:top;margin-top:12px}
.price-period{color:var(--text-muted);font-size:14px;margin-bottom:32px}
.price-features{
  list-style:none;text-align:left;
  display:flex;flex-direction:column;gap:14px;
  margin-bottom:36px;
}
.price-features li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:15px;color:var(--text-sec);
}
.price-features li::before{
  content:'✓';color:var(--lime);font-weight:900;
  flex-shrink:0;margin-top:1px;
}
.price-features li.no{color:var(--text-muted)}
.price-features li.no::before{content:'✕';color:var(--text-muted)}
.price-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:28px;max-width:860px;margin:0 auto;
}

/* ─── FAQ ─── */
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);overflow:hidden;
  transition:var(--ease);
}
.faq-item.open{border-color:rgba(210,255,0,.3)}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 28px;cursor:pointer;
  font-family:var(--font-h);font-weight:600;font-size:16px;
  transition:var(--ease);gap:16px;
}
.faq-q:hover{color:var(--lime)}
.faq-icon{
  flex-shrink:0;width:28px;height:28px;border-radius:50%;
  background:var(--glass);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;transition:var(--ease);
}
.faq-item.open .faq-icon{transform:rotate(45deg);background:rgba(210,255,0,.15);color:var(--lime)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .4s ease,padding .3s ease;
  color:var(--text-sec);font-size:15px;line-height:1.8;
  padding:0 28px;
}
.faq-item.open .faq-a{max-height:300px;padding-bottom:24px}

/* ─── RESPONSIVE ─── */
@media (max-width:1100px){
  .method-grid{grid-template-columns:repeat(2,1fr)}
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:900px){
  .method-visual{grid-template-columns:1fr;gap:40px}
  .method-badge{right:0}
  .method-img{height:380px}
  .eduardo-grid{grid-template-columns:1fr;gap:40px}
  .edu-imgs{height:auto}
  .edu-main{width:100%;height:auto}
  .shop-prev-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .contact-info-card{padding:32px 28px}
  .contact-form{padding:32px 28px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .gets-grid{grid-template-columns:1fr}
  .dash-grid{grid-template-columns:1fr}
  .videos-grid{grid-template-columns:repeat(2,1fr)}
  .dash-stats{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:1fr}
}
@media (max-width:768px){
  :root{--pad-sec:clamp(48px,8vw,72px) 0}
  .nav-links{
    position:fixed;top:var(--nav-h);left:0;right:0;
    flex-direction:column;
    background:rgba(18,0,43,.98);
    backdrop-filter:blur(20px);
    padding:24px;gap:6px;
    transform:translateY(-110%);opacity:0;pointer-events:none;
    transition:var(--ease);
    border-bottom:1px solid var(--glass-b);
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:all}
  .nav-lang{margin-left:0;width:100%}
  .lang-btn{width:100%;justify-content:center}
  .lang-menu{position:static;opacity:1;transform:none;pointer-events:all;
    min-width:0;width:100%;margin-top:8px;box-shadow:none;display:none}
  .nav-lang.open .lang-menu{display:block}
  .hamburger{display:flex}
  .hero-title{letter-spacing:-1px}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{width:100%}
  .method-grid{grid-template-columns:1fr;gap:14px}
  .features-grid{grid-template-columns:1fr}
  .step{grid-template-columns:60px 1fr;gap:20px}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .videos-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .shop-feat-img{height:280px}
  .shop-sm-card{grid-template-columns:100px 1fr}
  .contact-info-card{padding:28px 22px}
  .contact-form{padding:28px 22px}
  .cart-drawer{width:100%;right:-100%}
}
@media (max-width:480px){
  .products-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .videos-grid{grid-template-columns:1fr}
  .dash-stats{grid-template-columns:1fr}
  .login-card{padding:36px 28px}
}

/* ═══════════════════════════════════════════
   LUCIDE ICONS
   ═══════════════════════════════════════════ */
[data-lucide],
[data-lucide] svg {
  display:inline-block;flex-shrink:0;
  vertical-align:-0.125em;
}
/* Lucide replaces <i data-lucide> with <svg> — size via context */
.get-icon svg{width:24px;height:24px;stroke-width:1.75}
.contact-item .ico svg{width:19px;height:19px;stroke-width:1.75}
.soc-btn svg{width:15px;height:15px;flex-shrink:0;vertical-align:-2px}
.footer-soc svg{width:17px;height:17px}
.footer-brand .footer-soc svg{stroke:var(--viola-dark)}
.dash-stat-ico svg{width:26px;height:26px;stroke-width:1.5}
.play-btn svg{width:20px;height:20px;margin-left:3px}
.add-cart svg{width:17px;height:17px;stroke-width:2.5}
.cart-btn svg{width:16px;height:16px;vertical-align:-2px}
.cart-close svg{width:18px;height:18px}
.stat-icon svg{width:40px;height:40px;stroke-width:1.5;color:var(--viola-dark)}
.profile-avatar svg{width:36px;height:36px;stroke-width:1.5;color:rgba(255,255,255,.8)}
.nav-icon svg{width:14px;height:14px;vertical-align:-1px;margin-right:4px}

/* ═══════════════════════════════════════════
   SCROLL PROGRESS BAR
   ═══════════════════════════════════════════ */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--lime),var(--oro),var(--lavanda));
  z-index:10000;
  transition:width .08s linear;
  pointer-events:none;
}

/* ═══════════════════════════════════════════
   HERO WORD REVEAL ANIMATION
   ═══════════════════════════════════════════ */
.word-wrap{display:inline-block;overflow:hidden;vertical-align:bottom}
.word-inner{
  display:inline-block;
  transform:translateY(110%);
  opacity:0;
  transition:transform .75s cubic-bezier(.16,1,.3,1), opacity .75s ease;
}
.word-inner.in{transform:translateY(0);opacity:1}

/* ═══════════════════════════════════════════
   PRODUCT CAROUSEL
   ═══════════════════════════════════════════ */
.product-carousel{
  position:relative;overflow:hidden;
  height:290px;
  background:var(--viola-mid);
  cursor:pointer;
}
.carousel-track{
  display:flex;height:100%;
  transition:transform .42s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
.carousel-track img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  flex-shrink:0;display:block;
}
.carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(18,0,43,.78);
  border:1px solid rgba(255,255,255,.22);
  color:var(--text);
  display:flex;align-items:center;justify-content:center;
  z-index:3;opacity:0;
  transition:var(--ease);cursor:pointer;
  backdrop-filter:blur(8px);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
.carousel-prev{left:8px}
.carousel-next{right:8px}
.product-carousel:hover .carousel-arrow{opacity:1}
/* always slightly visible on touch devices */
@media (hover:none){.carousel-arrow{opacity:.72}}
.carousel-arrow:hover,.carousel-arrow:active{background:var(--lime);color:var(--viola-dark);border-color:var(--lime)}
.carousel-arrow svg{width:16px;height:16px;flex-shrink:0}

.carousel-dots{
  position:absolute;bottom:12px;left:50%;transform:translateX(-50%);
  display:flex;gap:5px;z-index:2;
}
.dot{
  width:6px;height:6px;border-radius:3px;
  background:rgba(255,255,255,.38);
  transition:var(--ease);cursor:pointer;
  /* enlarged hit area for touch */
  padding:8px;
  margin:-8px;
  box-sizing:content-box;
}
.dot.active{background:var(--lime);width:18px}

.carousel-counter{
  position:absolute;bottom:10px;right:10px;
  font-size:10px;font-weight:700;
  color:rgba(255,255,255,.65);
  background:rgba(18,0,43,.55);
  padding:3px 8px;border-radius:20px;
  z-index:2;letter-spacing:.4px;
  backdrop-filter:blur(6px);
}

/* ─── Card cursor + click hint ─── */
.product-card{cursor:pointer}
.product-card .product-body{user-select:none}

/* ═══════════════════════════════════════════
   PRODUCT MODAL
   ═══════════════════════════════════════════ */
.product-modal{
  position:fixed;inset:0;z-index:3000;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  pointer-events:none;opacity:0;
  transition:opacity .3s ease;
}
.product-modal.open{pointer-events:all;opacity:1}

.modal-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.88);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.modal-content{
  position:relative;z-index:1;
  background:var(--viola-mid);
  border:1px solid var(--glass-b);
  border-radius:var(--radius-xl);
  max-width:980px;width:100%;
  max-height:90vh;overflow-y:auto;
  transform:translateY(24px) scale(.97);
  transition:transform .38s cubic-bezier(.16,1,.3,1);
  scrollbar-width:thin;
  scrollbar-color:var(--glass-b) transparent;
}
.product-modal.open .modal-content{transform:translateY(0) scale(1)}

.modal-close{
  position:absolute;top:16px;right:16px;z-index:4;
  width:38px;height:38px;border-radius:50%;
  background:var(--glass);border:1px solid var(--glass-b);
  color:var(--text);
  display:flex;align-items:center;justify-content:center;
  transition:var(--ease);cursor:pointer;
}
.modal-close:hover{background:var(--lime);color:var(--viola-dark);border-color:var(--lime)}
.modal-close svg{width:17px;height:17px}

.modal-body{
  display:grid;
  grid-template-columns:1fr 360px;
  min-height:520px;
}
.modal-gallery{
  position:relative;
  background:var(--viola-card);
  border-radius:var(--radius-xl) 0 0 var(--radius-xl);
  overflow:hidden;
  display:flex;flex-direction:column;
}
.modal-main-img{
  flex:1;position:relative;overflow:hidden;
  min-height:360px;
}
.modal-main-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
  transition:opacity .22s ease;
}
.modal-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(18,0,43,.78);
  border:1px solid rgba(255,255,255,.22);
  color:var(--text);
  display:flex;align-items:center;justify-content:center;
  z-index:2;transition:var(--ease);cursor:pointer;
  backdrop-filter:blur(8px);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
.modal-prev{left:14px}
.modal-next{right:14px}
.modal-arrow:hover,.modal-arrow:active{background:var(--lime);color:var(--viola-dark);border-color:var(--lime)}
.modal-arrow svg{width:18px;height:18px}

.modal-img-counter{
  position:absolute;bottom:14px;right:14px;
  background:rgba(18,0,43,.72);
  color:rgba(255,255,255,.8);
  font-size:11px;font-weight:700;
  padding:4px 10px;border-radius:20px;
  backdrop-filter:blur(6px);
  z-index:2;letter-spacing:.3px;
}

.modal-thumbs{
  display:flex;gap:8px;
  padding:12px 16px;
  overflow-x:auto;
  scrollbar-width:none;
  background:rgba(0,0,0,.25);
  flex-shrink:0;
}
.modal-thumbs::-webkit-scrollbar{display:none}
.modal-thumb{
  width:58px;height:58px;border-radius:8px;
  overflow:hidden;flex-shrink:0;
  border:2px solid transparent;
  cursor:pointer;transition:var(--ease);
}
.modal-thumb img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
}
.modal-thumb.active{border-color:var(--lime)}
.modal-thumb:hover:not(.active){border-color:rgba(210,255,0,.45);transform:scale(1.04)}

.modal-info{
  padding:40px 36px;
  display:flex;flex-direction:column;
  justify-content:center;
  gap:0;
}
.modal-gender-tag{
  display:inline-block;
  background:rgba(210,255,0,.1);
  color:var(--lime);
  border:1px solid rgba(210,255,0,.28);
  padding:4px 14px;border-radius:50px;
  font-size:10px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;
  margin-bottom:16px;align-self:flex-start;
}
.modal-title{
  font-family:var(--font-h);font-weight:900;
  font-size:clamp(20px,2.5vw,30px);
  line-height:1.1;margin-bottom:6px;
}
.modal-cat-label{
  color:var(--text-muted);font-size:11px;
  text-transform:uppercase;letter-spacing:1.8px;
  margin-bottom:28px;
}
.modal-price-wrap{
  display:flex;align-items:baseline;gap:6px;
  margin-bottom:32px;
}
.modal-price{
  font-family:var(--font-h);font-weight:900;
  font-size:46px;color:var(--lime);line-height:1;
}
.modal-add-cart-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 28px;
  min-height:52px;
  background:var(--lime);color:var(--viola-dark);
  border:none;border-radius:50px;
  font-family:var(--font-h);font-weight:800;font-size:14px;
  letter-spacing:.4px;text-transform:uppercase;
  cursor:pointer;transition:var(--ease);
  width:100%;margin-bottom:14px;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
.modal-add-cart-btn:hover,.modal-add-cart-btn:active{background:var(--oro);transform:translateY(-2px);box-shadow:0 12px 36px rgba(210,255,0,.25)}
.modal-add-cart-btn svg{width:17px;height:17px;flex-shrink:0}
.modal-shipping{
  text-align:center;color:var(--text-muted);
  font-size:12px;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.modal-shipping svg{width:13px;height:13px;color:var(--lime)}

/* ─── Modal responsive ─── */
@media (max-width:768px){
  .product-modal{padding:12px 0 0;align-items:flex-end}
  .modal-content{
    border-radius:var(--radius-xl) var(--radius-xl) 0 0;
    max-height:92vh;
  }
  .modal-body{grid-template-columns:1fr;grid-template-rows:auto auto}
  .modal-gallery{border-radius:var(--radius-xl) var(--radius-xl) 0 0}
  .modal-main-img{min-height:260px}
  .modal-info{padding:24px 20px 32px}
  .modal-price{font-size:38px}
  /* sticky cart button on mobile */
  .modal-info{
    position:relative;
  }
  .modal-add-cart-btn{
    position:sticky;bottom:0;
    margin-left:-20px;margin-right:-20px;
    border-radius:0;
    padding:18px;
    font-size:15px;
  }
}
@media (max-width:480px){
  .modal-content{max-height:96vh}
  .modal-main-img{min-height:220px}
  .modal-info{padding:20px 16px 0}
  .modal-add-cart-btn{
    margin-left:-16px;margin-right:-16px;
  }
}

/* ═══════════════════════════════════════════
   HERO SCROLL CHEVRON
   ═══════════════════════════════════════════ */
.hero-scroll svg{
  width:24px;height:24px;
  color:var(--lime);
  animation:scrollBounce 2s ease-in-out infinite;
}
@keyframes scrollBounce{
  0%,100%{transform:translateY(0);opacity:.6}
  50%{transform:translateY(8px);opacity:1}
}

/* ═══════════════════════════════════════════
   STATS COUNTER
   ═══════════════════════════════════════════ */
[data-count]{display:inline-block}

/* ═══════════════════════════════════════════
   CARD SPOTLIGHT (mouse-follow glow)
   ═══════════════════════════════════════════ */
.spotlight{
  position:relative;overflow:hidden;
}
.spotlight::before{
  content:'';
  position:absolute;
  width:200px;height:200px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(210,255,0,.1) 0%,transparent 70%);
  transform:translate(var(--mx,50%),var(--my,50%)) translate(-50%,-50%);
  pointer-events:none;
  transition:opacity .2s ease;
  opacity:0;
  z-index:0;
}
.spotlight:hover::before{opacity:1}
.spotlight>*{position:relative;z-index:1}

/* ═══════════════════════════════════════════
   AURORA SECTION DECORATION
   ═══════════════════════════════════════════ */
.aurora-section{position:relative;overflow:hidden}
.aurora-section::before{
  content:'';
  position:absolute;
  width:700px;height:700px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(191,112,240,.12) 0%,transparent 65%);
  top:-200px;right:-200px;
  pointer-events:none;
  animation:auroraFloat 14s ease-in-out infinite alternate;
}
.aurora-section::after{
  content:'';
  position:absolute;
  width:500px;height:500px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(210,255,0,.07) 0%,transparent 65%);
  bottom:-150px;left:-100px;
  pointer-events:none;
  animation:auroraFloat 10s ease-in-out infinite alternate-reverse;
}
@keyframes auroraFloat{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(40px,-40px) scale(1.15)}
}

/* ═══════════════════════════════════════════
   HERO GRADIENT BLOB
   ═══════════════════════════════════════════ */
.hero::after{
  content:'';
  position:absolute;
  bottom:-80px;right:-80px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(191,112,240,.14),transparent 70%);
  z-index:1;pointer-events:none;
  animation:blobPulse 8s ease-in-out infinite;
}
@keyframes blobPulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.12)}
}

/* ═══════════════════════════════════════════
   STEP NUMBER GRADIENT
   ═══════════════════════════════════════════ */
.step-num{
  background:linear-gradient(135deg,var(--lime),var(--oro));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ═══════════════════════════════════════════
   PRICE CARD SHIMMER
   ═══════════════════════════════════════════ */
.price-card.featured{overflow:hidden}
.price-card.featured::after{
  content:'';
  position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(105deg,transparent 35%,rgba(210,255,0,.06) 50%,transparent 65%);
  animation:cardShimmer 4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes cardShimmer{
  0%{transform:translateX(-100%)}
  60%,100%{transform:translateX(150%)}
}

/* ═══════════════════════════════════════════
   ENHANCED BUTTON EFFECTS
   ═══════════════════════════════════════════ */
.btn-primary:active{transform:translateY(0) scale(.98)}
.btn{position:relative;overflow:hidden}
.btn::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(255,255,255,.12);
  opacity:0;border-radius:inherit;
  transition:opacity .2s ease;
}
.btn:active::after{opacity:1}

/* ═══════════════════════════════════════════
   FORM FOCUS GLOW
   ═══════════════════════════════════════════ */
.fgroup input:focus,.fgroup select:focus,.fgroup textarea:focus,
.field input:focus{
  box-shadow:0 0 0 3px rgba(210,255,0,.12);
}

/* ═══════════════════════════════════════════
   VIDEO CARD PLAY BUTTON
   ═══════════════════════════════════════════ */
.video-card:hover .play-btn{
  background:var(--lime);
  border-color:var(--lime);
  transform:scale(1.12);
}
.video-card:hover .play-btn svg{color:var(--viola-dark)}

/* ═══════════════════════════════════════════
   CHECKOUT PULSE
   ═══════════════════════════════════════════ */
#checkoutBtn{
  position:relative;
  animation:ctaPulse 3s ease-in-out infinite;
}
@keyframes ctaPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(210,255,0,.35)}
  50%{box-shadow:0 0 0 10px rgba(210,255,0,0)}
}

/* ═══════════════════════════════════════════
   NOTIFY BAR ICON
   ═══════════════════════════════════════════ */
.notify-bar .notify-icon{
  width:42px;height:42px;border-radius:12px;
  background:rgba(210,255,0,.12);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--lime);
}
.notify-bar .notify-icon svg{width:22px;height:22px}

/* ═══════════════════════════════════════════
   VIDEO META ICONS
   ═══════════════════════════════════════════ */
.video-meta svg{width:13px;height:13px;vertical-align:-1px;opacity:.7}

/* ═══════════════════════════════════════════
   PROFILE AVATAR
   ═══════════════════════════════════════════ */
.profile-avatar{
  background:linear-gradient(135deg,var(--viola),var(--lavanda));
}
.profile-avatar svg{width:36px;height:36px;stroke-width:1.5;color:rgba(255,255,255,.9)}

/* ═══════════════════════════════════════════
   MISC ICON SIZES
   ═══════════════════════════════════════════ */
.login-logo svg{display:none} /* logo is img, not icon */
.hero-badge svg{width:6px;height:6px} /* pulsing dot — use CSS instead */
.feat-card .feat-icon{
  width:52px;height:52px;border-radius:14px;
  background:rgba(210,255,0,.1);border:1px solid rgba(210,255,0,.12);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;color:var(--lime);
}
.feat-card .feat-icon svg{width:26px;height:26px;stroke-width:1.75}

/* ═══════════════════════════════════════════
   VIDEO SECTION LAYOUT
   ═══════════════════════════════════════════ */
.video-container-wrap {
  position: relative;
  max-width: 960px;
  margin: 0 auto;
  padding: 12px;
  background: var(--glass);
  border: 1px solid var(--glass-b);
  border-radius: var(--radius-xl);
  box-shadow: 0 30px 90px rgba(0,0,0,.45);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.video-wrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 aspect ratio */
  height: 0;
  overflow: hidden;
  border-radius: var(--radius);
}
.video-wrapper iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  border: none;
}

/* ═══════════════════════════════════════════
   COLORED SOCIAL BUTTONS & ICONS
   ═══════════════════════════════════════════ */
.instagram {
  color: #E1306C !important;
  border-color: rgba(225, 48, 108, 0.3) !important;
}
.instagram:hover {
  background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%) !important;
  color: #fff !important;
  border-color: transparent !important;
}
.facebook {
  color: #1877F2 !important;
  border-color: rgba(24, 119, 242, 0.3) !important;
}
.facebook:hover {
  background: #1877F2 !important;
  color: #fff !important;
  border-color: #1877F2 !important;
}
.youtube {
  color: #FF0000 !important;
  border-color: rgba(255, 0, 0, 0.3) !important;
}
.youtube:hover {
  background: #FF0000 !important;
  color: #fff !important;
  border-color: #FF0000 !important;
}
.whatsapp {
  color: #25D366 !important;
  border-color: rgba(37, 211, 102, 0.3) !important;
}
.whatsapp:hover {
  background: #25D366 !important;
  color: #fff !important;
  border-color: #25D366 !important;
}

/* Redefine contact section social buttons to have colored backgrounds by default */
.soc-btn.instagram {
  background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: 0 6px 18px rgba(225, 48, 108, 0.35);
}
.soc-btn.instagram:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(225, 48, 108, 0.5);
  filter: brightness(1.08);
}
.soc-btn.facebook {
  background: #1877F2 !important;
  color: #fff !important;
  border-color: #1877F2 !important;
  box-shadow: 0 6px 18px rgba(24, 119, 242, 0.35);
}
.soc-btn.facebook:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(24, 119, 242, 0.5);
  filter: brightness(1.08);
}
.soc-btn.whatsapp {
  background: #25D366 !important;
  color: #fff !important;
  border-color: #25D366 !important;
  box-shadow: 0 6px 18px rgba(37, 211, 102, 0.35);
}
.soc-btn.whatsapp:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(37, 211, 102, 0.5);
  filter: brightness(1.08);
}

/* Ensure hover transition matches the original */
.soc-btn.instagram, .soc-btn.facebook, .soc-btn.whatsapp, .soc-btn.youtube,
.footer-soc.instagram, .footer-soc.facebook, .footer-soc.youtube {
  transition: all 0.3s ease;
}


/* ═══════════════════════════════════════════════
   COMPLIANCE — Checkbox · Cookie Banner · Policy
   ═══════════════════════════════════════════════ */

/* ─── FORM CHECKBOX ─── */
.fgroup-check{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 16px;border-radius:var(--radius-s);
  background:rgba(255,255,255,.03);border:1px solid var(--glass-b);
  cursor:pointer;transition:var(--ease);
}
.fgroup-check:hover{border-color:rgba(210,255,0,.2);background:rgba(210,255,0,.03)}
.fgroup-check.error{border-color:rgba(255,80,80,.45);background:rgba(255,80,80,.04)}
.fgroup-check input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;min-width:18px;
  border:1.5px solid rgba(255,255,255,.3);border-radius:4px;
  background:transparent;cursor:pointer;position:relative;
  transition:var(--ease);margin-top:1px;
}
.fgroup-check input[type="checkbox"]:checked{background:var(--lime);border-color:var(--lime)}
.fgroup-check input[type="checkbox"]:checked::after{
  content:'';position:absolute;left:4px;top:1px;
  width:6px;height:10px;
  border:2px solid var(--viola-dark);border-top:none;border-left:none;
  transform:rotate(45deg);
}
.fgroup-check label{
  font-size:13px;color:var(--text-sec);line-height:1.55;cursor:pointer;
  text-transform:none;letter-spacing:0;font-weight:400;
}
.fgroup-check label a{color:var(--lavanda);text-decoration:underline;transition:color .2s}
.fgroup-check label a:hover{color:var(--lime)}
.fgroup-check label strong{color:rgba(255,80,80,.9)}

/* ─── COOKIE BANNER ─── */
.cookie-banner{
  position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(140px);
  width:calc(100% - 32px);max-width:840px;
  z-index:9999;opacity:0;pointer-events:none;
  transition:transform .45s cubic-bezier(0.22,1,0.36,1),opacity .35s ease;
}
.cookie-banner.show{
  transform:translateX(-50%) translateY(0);
  opacity:1;pointer-events:all;
}
.cookie-inner{
  display:flex;align-items:center;gap:16px;
  background:rgba(16,4,40,.97);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border:1px solid rgba(210,255,0,.2);
  border-radius:20px;padding:14px 18px;
  box-shadow:0 8px 48px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.04),inset 0 1px 0 rgba(255,255,255,.07);
}
.cookie-icon{
  width:38px;height:38px;border-radius:11px;flex-shrink:0;
  background:rgba(210,255,0,.1);border:1px solid rgba(210,255,0,.2);
  display:flex;align-items:center;justify-content:center;color:var(--lime);
}
.cookie-text{flex:1;min-width:0}
.cookie-text strong{
  display:block;font-family:var(--font-h);font-weight:700;
  font-size:13px;color:var(--text);margin-bottom:2px;
}
.cookie-text p{font-size:12px;color:var(--text-sec);line-height:1.5;margin:0}
.cookie-text p a{color:var(--lavanda);text-decoration:underline;transition:color .2s}
.cookie-text p a:hover{color:var(--lime)}
.cookie-actions{display:flex;gap:8px;flex-shrink:0}
.cookie-btn-necessary{
  padding:8px 16px;border-radius:50px;
  border:1px solid rgba(255,255,255,.14);
  background:transparent;color:var(--text-sec);
  font-family:var(--font-h);font-weight:600;font-size:12px;
  cursor:pointer;transition:var(--ease);white-space:nowrap;
}
.cookie-btn-necessary:hover{border-color:rgba(255,255,255,.3);color:var(--text)}
.cookie-btn-accept{
  padding:8px 20px;border-radius:50px;border:none;
  background:var(--lime);color:var(--viola-dark);
  font-family:var(--font-h);font-weight:700;font-size:12px;
  cursor:pointer;transition:var(--ease);white-space:nowrap;
}
.cookie-btn-accept:hover{filter:brightness(1.08);transform:scale(1.03)}
@media(max-width:600px){
  .cookie-banner{bottom:12px;width:calc(100% - 20px)}
  .cookie-inner{flex-wrap:wrap;gap:10px;padding:14px 16px}
  .cookie-icon{display:none}
  .cookie-actions{width:100%}
  .cookie-btn-necessary,.cookie-btn-accept{flex:1;text-align:center}
}

/* ─── FOOTER LEGAL ─── */
.footer-bottom{
  border-top:1px solid var(--glass-b);
  padding-top:24px;
  display:flex;flex-direction:column;gap:10px;align-items:center;
  text-align:center;
}
.footer-bottom>p{color:var(--text-muted);font-size:12px}
.footer-legal{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}
.footer-legal a{color:var(--text-muted);font-size:12px;transition:color .2s;text-decoration:underline}
.footer-legal a:hover{color:var(--lime)}
.footer-legal span{color:rgba(255,255,255,.2);font-size:10px}

/* ─── POLICY PAGES ─── */
.policy-hero{
  padding:clamp(100px,12vw,150px) 0 clamp(40px,5vw,64px);
  background:linear-gradient(160deg,var(--viola-mid),var(--viola-dark));
  border-bottom:1px solid var(--glass-b);
}
.policy-hero .tag{display:inline-block;margin-bottom:16px}
.policy-hero h1{font-family:var(--font-h);font-weight:900;font-size:clamp(32px,5vw,52px);line-height:1.1;margin-bottom:12px}
.policy-hero p{color:var(--text-sec);font-size:15px}
.policy-body{padding:clamp(48px,6vw,88px) 0}
.policy-content{max-width:780px;margin:0 auto}
.policy-content h2{
  font-family:var(--font-h);font-weight:800;font-size:22px;
  margin:48px 0 14px;color:var(--lime);
}
.policy-content h3{
  font-family:var(--font-h);font-weight:700;font-size:17px;
  margin:28px 0 10px;
}
.policy-content p{color:var(--text-sec);font-size:15px;line-height:1.8;margin-bottom:14px}
.policy-content ul,.policy-content ol{
  padding-left:24px;margin-bottom:16px;
}
.policy-content li{color:var(--text-sec);font-size:15px;line-height:1.75;margin-bottom:6px}
.policy-content strong{color:var(--text);font-weight:600}
.policy-content a{color:var(--lavanda);text-decoration:underline}
.policy-content a:hover{color:var(--lime)}
.policy-box{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);padding:24px 28px;margin:24px 0;
}
.policy-box p{margin-bottom:0}
.policy-update{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;color:var(--text-muted);
  background:var(--glass);border:1px solid var(--glass-b);
  padding:6px 14px;border-radius:50px;margin-bottom:32px;
}
@media(max-width:768px){
  .cookie-inner{flex-direction:column;align-items:flex-start;gap:16px}
  .footer-bottom{align-items:flex-start;text-align:left}
  .footer-legal{justify-content:flex-start}
}

/* ═══════════════════════════════════════
   AREA ISTRUTTORI — auth reale (Supabase)
   ═══════════════════════════════════════ */
.hidden{display:none!important}

/* Alert */
.alert{
  border-radius:var(--radius-s);padding:13px 16px;margin-bottom:18px;
  font-size:13.5px;line-height:1.55;border:1px solid;
}
.alert-error{background:rgba(255,80,80,.1);border-color:rgba(255,80,80,.35);color:#ff9d9d}
.alert-success{background:rgba(210,255,0,.08);border-color:rgba(210,255,0,.3);color:var(--lime)}
.alert-warn{background:rgba(255,198,0,.08);border-color:rgba(255,198,0,.35);color:var(--oro)}

/* Empty state */
.empty-state{
  grid-column:1/-1;text-align:center;padding:48px 24px;
  background:var(--glass);border:1px dashed var(--glass-b);
  border-radius:var(--radius);color:var(--text-sec);font-size:15px;line-height:1.7;
}

/* Thumb fallback (nessuna copertina) */
.video-thumb-fallback{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);font-size:46px;font-weight:900;color:rgba(255,255,255,.16);
  background:linear-gradient(135deg,var(--viola-mid),var(--viola));
}
.draft-tag{
  display:inline-block;font-size:10px;font-weight:700;letter-spacing:1px;
  text-transform:uppercase;color:var(--oro);border:1px solid rgba(255,198,0,.4);
  border-radius:50px;padding:1px 8px;margin-left:6px;vertical-align:middle;
}

/* Player modale */
.player-modal{
  position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.93);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.player-modal.open{display:flex}
.player-box{width:min(960px,100%)}
.player-hd{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:16px;margin-bottom:14px;
}
.player-hd h3{font-family:var(--font-h);font-weight:800;font-size:20px}
.player-hd span{color:var(--text-sec);font-size:13px}
.player-close{
  background:none;border:1px solid rgba(255,255,255,.25);color:#fff;
  width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:15px;
  flex-shrink:0;transition:var(--ease);
}
.player-close:hover{border-color:var(--lime);color:var(--lime)}
.player-frame{
  position:relative;width:100%;aspect-ratio:16/9;background:#000;
  border-radius:var(--radius-s);overflow:hidden;border:1px solid var(--glass-b);
}
.player-frame iframe,.player-frame video{
  position:absolute;inset:0;width:100%;height:100%;border:0;
}

/* Blocchi impostazioni profilo */
.settings-block{
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius);padding:22px 24px;margin-bottom:16px;
}
.settings-block h4{
  font-family:var(--font-h);font-weight:700;font-size:15px;
  display:flex;align-items:center;gap:8px;margin-bottom:6px;
}
.settings-block h4 svg{width:16px;height:16px;color:var(--lime)}
.settings-block>p{color:var(--text-sec);font-size:13.5px;line-height:1.6;margin-bottom:14px}
.settings-form{display:flex;gap:10px;flex-wrap:wrap}
.settings-form input{
  flex:1;min-width:200px;background:rgba(255,255,255,.06);
  border:1px solid var(--glass-b);border-radius:var(--radius-s);
  padding:12px 14px;color:var(--text);font-family:var(--font-b);font-size:14px;
}
.settings-form input:focus{outline:none;border-color:rgba(210,255,0,.5);background:rgba(255,255,255,.09)}
.settings-form input::placeholder{color:var(--text-muted)}
.settings-form-col{flex-direction:column}
.settings-form-col input{width:100%}
.settings-form-col .btn{align-self:flex-start}

/* Gestione admin */
.admin-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:0 16px;margin-bottom:8px;
}
.admin-row{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:var(--glass);border:1px solid var(--glass-b);
  border-radius:var(--radius-s);padding:14px 18px;margin-bottom:10px;flex-wrap:wrap;
}
.admin-row-info{display:flex;flex-direction:column;gap:2px}
.admin-row-info strong{font-family:var(--font-h);font-size:14px}
.admin-row-info span{color:var(--text-sec);font-size:12.5px}
.admin-row-actions{display:flex;gap:8px;flex-wrap:wrap}
.btn-sm{padding:8px 16px;font-size:12.5px}
.btn-danger:hover{border-color:#ff5050;color:#ff8080}

/* Badge contenuti dimostrativi */
.video-badge-demo{background:var(--oro);color:var(--viola-dark)}
