/* ===== FELIXFIT — Landing Page ===== */
:root{
  --navy-900:#060920;
  --navy-800:#0a0e2c;
  --navy-700:#0e1440;
  --pink:#ff1f8e;
  --pink-soft:#ff7ac0;
  --blue:#2d7dff;
  --cyan:#27c5ff;
  --purple:#7b4dff;
  --green:#c6ff00;
  --txt:#eaf0ff;
  --txt-dim:#9aa6cf;
  --grad:linear-gradient(90deg,#27c5ff,#2d7dff,#7b4dff,#ff1f8e);
  --grad-btn:linear-gradient(95deg,#2d7dff,#7b4dff 45%,#ff1f8e);
  --radius:18px;
  --shadow:0 24px 60px rgba(0,0,0,.5);
  --maxw:1280px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--navy-900);color:var(--txt);line-height:1.6;overflow-x:hidden}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative}
a{text-decoration:none;color:inherit}
img,svg{max-width:100%}
h1,h2,h3,h4{font-family:'Montserrat',sans-serif}

.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.neon-green{color:var(--green);text-shadow:0 0 16px rgba(198,255,0,.5)}

/* ===== Decorations ===== */
.dot-grid{position:absolute;width:130px;height:130px;opacity:.5;z-index:0;
  background-image:radial-gradient(rgba(124,124,255,.45) 1.6px,transparent 1.6px);background-size:14px 14px}
.dg-tl{top:90px;left:24px}.dg-br{right:24px;bottom:30px}
.neon-ring{position:absolute;border-radius:50%;border:1.5px solid rgba(124,124,255,.4);z-index:0}
.nr-1{width:14px;height:14px;top:150px;right:46%;box-shadow:0 0 12px rgba(124,124,255,.6)}
.nr-2{width:26px;height:26px;bottom:120px;right:80px;border-color:rgba(255,31,142,.5)}
.nr-3{width:60px;height:60px;top:60px;left:44%;border-color:rgba(255,122,192,.5)}
.nr-4{width:30px;height:30px;top:120px;right:60px;border-color:rgba(124,77,255,.6)}
.arc-line{position:absolute;left:-10%;top:-40px;width:55%;height:240px;border-radius:50%;
  border-top:2px solid transparent;border-left:2px solid transparent;
  background:radial-gradient(120% 120% at 0 100%,transparent 69%,rgba(45,125,255,.5) 70%,transparent 72%);z-index:0}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;font-weight:700;border:none;
  cursor:pointer;border-radius:999px;padding:13px 26px;font-size:15px;transition:.25s;color:#fff}
.btn:hover{transform:translateY(-2px)}
.btn-lg{padding:16px 32px;font-size:16px}
.btn-grad{background:var(--grad-btn);box-shadow:0 10px 30px rgba(255,31,142,.35)}
.btn-grad:hover{box-shadow:0 16px 42px rgba(124,77,255,.55)}
.btn-pill-glow{position:relative}
.btn-wpp{background:rgba(11,17,48,.7);border:1.5px solid rgba(124,77,255,.5)}
.btn-wpp:hover{border-color:var(--pink)}
.btn-wpp .btn-wa{width:22px;height:22px;color:#fff}
.btn-outline{background:rgba(255,255,255,.02);border:1.5px solid rgba(124,124,255,.45);color:var(--txt);padding:11px 22px;font-size:14px}
.btn-outline:hover{border-color:var(--pink);box-shadow:0 0 24px rgba(255,31,142,.25)}
.btn-ig{width:18px;height:18px;color:var(--pink)}

/* ===== Frame (moldura externa arredondada) ===== */
.frame{position:relative;border-radius:30px;padding:46px;
  background:linear-gradient(180deg,rgba(20,28,70,.55),rgba(8,12,38,.7));
  border:1.5px solid transparent;
  background-clip:padding-box;box-shadow:var(--shadow)}
.frame::before{content:"";position:absolute;inset:0;border-radius:30px;padding:1.5px;
  background:linear-gradient(120deg,rgba(45,125,255,.7),rgba(124,77,255,.2) 40%,rgba(255,31,142,.7));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(6,9,32,.55);
  backdrop-filter:blur(14px);border-bottom:1px solid rgba(124,124,255,.12);transition:.3s}
.site-header.scrolled{background:rgba(6,9,32,.95)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:96px;gap:20px}
.brand{position:relative;z-index:3;line-height:0}
.brand img{display:block;height:200px;margin:8px 0 -112px;filter:drop-shadow(0 12px 30px rgba(255,31,142,.35))}
.main-nav{display:flex;gap:28px}
.main-nav a{font-size:15px;color:var(--txt-dim);font-weight:500;transition:.2s}
.main-nav a:hover{color:#fff}
.header-cta{padding:10px 22px;font-size:14px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer}
.nav-toggle span{width:26px;height:3px;background:#fff;border-radius:2px}

/* ===== Hero ===== */
.hero{position:relative;padding:70px 0 80px;background:
  radial-gradient(900px 520px at 75% 25%,rgba(124,77,255,.28),transparent 60%),
  radial-gradient(700px 520px at 12% 85%,rgba(45,125,255,.18),transparent 60%),
  linear-gradient(180deg,var(--navy-900),var(--navy-800));overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr 1.1fr;gap:46px;align-items:center}
.hero-logo-img{height:140px;margin-bottom:26px}
.hero h1{font-weight:800;font-size:clamp(38px,4.6vw,60px);line-height:1.04;letter-spacing:-1px}
.hero-lead{margin:22px 0 28px;color:var(--txt-dim);font-size:17px;max-width:440px}
.hero-features{list-style:none;display:flex;gap:30px;flex-wrap:wrap;margin-bottom:32px}
.hero-features li{display:flex;gap:10px;align-items:center}
.hf-ico{width:34px;height:34px;color:var(--cyan);flex-shrink:0}
.hero-features li:nth-child(2) .hf-ico{color:var(--purple)}
.hero-features li:nth-child(3) .hf-ico{color:var(--pink)}
.hero-features strong{display:block;font-family:'Montserrat';font-size:13px;letter-spacing:1px;color:#fff}
.hero-features em{font-style:normal;font-size:11.5px;color:var(--txt-dim)}

/* Hero story cards */
.hero-cards{display:flex;gap:16px;justify-content:center;align-items:center}
.story{position:relative;width:31%;border-radius:24px;overflow:hidden;background-size:cover;background-position:center;
  box-shadow:var(--shadow);border:2px solid rgba(124,160,255,.35);display:flex;align-items:flex-end;padding:16px}
.story::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,14,44,.1),rgba(10,14,44,.75))}
.s1{height:380px;background-color:#241a45;border-color:rgba(124,160,255,.4)}
.s2{height:470px;background-color:#3a1140;border-color:rgba(255,31,142,.6);box-shadow:0 0 50px rgba(255,31,142,.35),var(--shadow)}
.s3{height:360px;background-color:#101a40;border-color:rgba(255,31,142,.4)}
.story figcaption{position:relative;z-index:2;font-family:'Montserrat';font-weight:800;font-size:14px;line-height:1.25}
.neon-words{position:relative;z-index:2;font-family:'Montserrat';font-weight:800;font-size:17px;line-height:1.55;
  color:var(--pink-soft);text-shadow:0 0 14px rgba(255,31,142,.9),0 0 4px rgba(255,31,142,.9);margin-left:auto;text-align:right}

/* ===== Section heads ===== */
.section-head{text-align:center;margin-bottom:46px}
.section-head h2{font-weight:900;font-size:clamp(34px,4.8vw,56px);letter-spacing:-1px}
.section-head p{color:var(--txt-dim);font-size:17px;margin-top:6px}

/* ===== Produtos ===== */
.produtos{position:relative;padding:140px 0 86px;background:
  radial-gradient(700px 400px at 100% 0,rgba(45,125,255,.14),transparent),var(--navy-900);overflow:hidden}
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.product-card{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));
  border:1px solid rgba(124,124,255,.2);border-radius:var(--radius);padding:18px;text-align:center;transition:.3s;position:relative;overflow:hidden}
.product-card::before{content:"";position:absolute;top:0;left:18px;right:18px;height:3px;border-radius:3px;background:var(--grad);opacity:.85}
.product-card:hover{transform:translateY(-6px);border-color:var(--pink);box-shadow:0 22px 48px rgba(255,31,142,.22)}
.prod-stage{height:210px;border-radius:14px;display:flex;align-items:flex-end;justify-content:center;gap:6px;
  margin-bottom:16px;background:radial-gradient(120% 80% at 50% 100%,rgba(124,77,255,.22),transparent 70%);position:relative}
.prod-stage::after{content:"";position:absolute;bottom:14px;left:18%;right:18%;height:14px;border-radius:50%;
  background:radial-gradient(closest-side,rgba(255,31,142,.45),transparent)}
.legwarmer{height:185px;filter:drop-shadow(0 8px 14px rgba(0,0,0,.5))}
.legwarmer.small{height:160px}
.sock{height:135px;filter:drop-shadow(0 8px 14px rgba(0,0,0,.5))}

/* Fotos reais dos produtos */
.prod-photo{height:185px;object-fit:contain;filter:drop-shadow(0 10px 18px rgba(0,0,0,.55));
  transition:transform .3s ease}
.prod-photo.big{height:200px}
.prod-photo.sock-photo{height:140px}
.product-card:hover .prod-photo{transform:translateY(-4px)}
.prod-stage{position:relative;z-index:5}
.socks-stage{gap:0}.socks-stage .sock{margin:0 -8px}
.product-card h3{font-size:18px;font-weight:800;line-height:1.15;margin-bottom:14px}
.swatches{display:flex;gap:8px;justify-content:center;margin-bottom:18px}
.swatches i{width:18px;height:18px;border-radius:50%;background:var(--c);border:2px solid rgba(255,255,255,.55);box-shadow:0 0 8px rgba(0,0,0,.4)}

/* sock/legwarmer color variants */
/* Polainas */
.lw-rose       {color:#ff1f8e; --ink:#2a0016}                      /* Pink */
.lw-rosabebe   {color:#ffc7dc; --ink:#3a0020}                      /* Rosa bebê */
.lw-black      {color:#15171f; --ink:#cfd4e6}                      /* Preta */
.lw-white      {color:#f2f4fb; --ink:#1a1d28}                      /* Branca */
.lw-neon-rosa  {color:#ff3aa0; --ink:#2a0016}                      /* Neon Rosa */
.lw-neon-verde {color:#5dff2d; --ink:#0e2400}                      /* Neon Verde */
.lw-neon-amarela{color:#fff200; --ink:#2a2400}                     /* Neon Amarela */
/* compat: classes antigas usadas no HTML decorativo do hero/CTA */
.lw-neon       {color:#5dff2d; --ink:#0e2400}
.lw-rose2      {color:#ff4fa3; --ink:#2a0016}
.lw-pinksoft   {color:#ffc7dc; --ink:#3a0020}

/* Meias */
.sk-white {color:#f2f4fb; --ink:#1a1d28; --toe:#2d7dff}            /* Branca */
.sk-black {color:#15171f; --ink:#e6e9f5; --toe:#ff1f8e}            /* Preta */
.sk-gray  {color:#7e8597; --ink:#f0f2fa; --toe:#15171f}            /* Cinza */
/* compat */
.sk-pink  {color:#ff1f8e; --ink:#2a0016; --toe:#c6ff00}

/* ===== Benefícios ===== */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:44px;padding:28px 32px;
  border:1px solid rgba(124,124,255,.22);border-radius:var(--radius);background:linear-gradient(180deg,rgba(45,125,255,.06),transparent)}
.benefit{display:flex;gap:16px;align-items:flex-start}
.benefit:nth-child(1){border-right:1px solid rgba(124,124,255,.15)}
.benefit:nth-child(2){border-right:1px solid rgba(124,124,255,.15)}
.benefit{padding-right:18px}
.b-ico{width:42px;height:42px;flex-shrink:0;color:var(--cyan)}
.benefit:nth-child(2) .b-ico{color:var(--purple)}
.benefit:nth-child(3) .b-ico{color:var(--pink)}
.benefit strong{display:block;font-family:'Montserrat';font-size:15px;margin-bottom:4px}
.benefit p{color:var(--txt-dim);font-size:14px}

/* ===== Depoimentos (CLARO) ===== */
.depoimentos{position:relative;padding:80px 0;overflow:hidden;
  background:linear-gradient(180deg,#eef1fb,#e6e9f8);color:#0c1330}
.depo-logo{position:absolute;top:40px;right:40px;height:120px;z-index:2}
.depoimentos .neon-ring{border-color:rgba(255,31,142,.35)}
.depo-grid{display:grid;grid-template-columns:1.02fr 1fr;gap:46px}
.depo-left h2{font-style:italic;font-weight:900;font-size:clamp(36px,4.6vw,56px);color:#0c1330}
.depo-left h2 .grad-text{font-style:italic}
.depo-intro{color:#4a5680;margin:12px 0 28px;font-size:16px;max-width:420px}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.review{position:relative;background:#fff;border-radius:18px;padding:42px 16px 16px;text-align:center;
  box-shadow:0 14px 30px rgba(40,30,90,.1);border:1px solid #e7e9f5}
.review .avatar{position:absolute;top:-26px;left:50%;transform:translateX(-50%);width:64px;height:64px;border-radius:50%;
  background-size:cover;background-position:center;background-color:#2a3050;border:3px solid #fff;
  box-shadow:0 0 0 2px var(--pink),0 8px 18px rgba(0,0,0,.2)}
.quote-mark{display:block;font-family:Georgia,serif;font-size:34px;line-height:0;color:var(--pink);margin:6px 0 4px;font-weight:700}
.stars{color:var(--pink);letter-spacing:3px;font-size:15px;margin-bottom:6px}
.rev-name{display:block;font-size:16px;color:#0c1330;margin-bottom:8px;font-family:'Montserrat';font-weight:800}
.review blockquote{font-size:13px;color:#566089;margin-bottom:14px;line-height:1.5}
.verified{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:#4a5680;font-weight:600;
  border:1px solid #d8dcee;border-radius:999px;padding:5px 12px}
.trust-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px;background:#fff;border-radius:16px;
  padding:18px 20px;box-shadow:0 10px 24px rgba(40,30,90,.08)}
.trust-row div{display:flex;align-items:center;gap:10px;font-size:13px;color:#3a4566;font-weight:600;flex:1;min-width:160px}
.t-ico{width:30px;height:30px;color:var(--purple)}
.trust-row div:nth-child(1) .t-ico{color:var(--blue)}
.trust-row div:nth-child(3) .t-ico{color:var(--pink)}

.ig-banner{display:flex;gap:14px;align-items:center;padding:14px 20px;border-radius:999px;
  border:1.5px solid rgba(255,31,142,.4);background:#fff;margin-bottom:16px;box-shadow:0 10px 24px rgba(40,30,90,.08)}
.ig-ico{width:38px;height:38px;color:var(--pink);flex-shrink:0}
.ig-banner span{color:#0c1330;font-size:15px}
.ig-banner strong{color:var(--pink)}
.ig-banner em{font-style:normal;font-size:12.5px;color:#6b7398}
.ig-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.ig-cell{position:relative;aspect-ratio:1;border-radius:14px;background-size:cover;background-position:center;
  background-color:#1a1f3d;box-shadow:0 8px 18px rgba(40,30,90,.12)}
.ig-cell svg{position:absolute;top:8px;right:8px;width:18px;height:18px;color:rgba(255,255,255,.85)}
.ig-cell:nth-child(1){background-color:#2a3050}.ig-cell:nth-child(2){background-color:#7da800}
.ig-cell:nth-child(3){background-color:#ff1f8e}.ig-cell:nth-child(4){background-color:#15171f}
.ig-cell:nth-child(5){background-color:#b32f7a}.ig-cell:nth-child(6){background-color:#1a1030}
.ig-cell:nth-child(7){background-color:#ff2d9b}.ig-cell:nth-child(8){background-color:#9bd400}
.ig-more{margin-top:16px;width:100%;background:#fff;color:#0c1330;border-color:rgba(255,31,142,.4)}
.depo-foot{text-align:center;color:#7b84a8;font-size:13px;margin-top:34px}

/* ===== CTA Final ===== */
.cta-final{position:relative;padding:80px 0;overflow:hidden;background:
  radial-gradient(800px 520px at 80% 35%,rgba(124,77,255,.25),transparent),
  linear-gradient(180deg,var(--navy-900),var(--navy-800))}
.cta-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.cta-copy h2{font-weight:900;font-size:clamp(38px,5vw,60px);line-height:1.06}
.cta-copy p{color:var(--txt-dim);font-size:17px;margin:18px 0 26px;max-width:440px}
.cta-buttons{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.cta-badges{display:flex;gap:22px;flex-wrap:wrap;font-size:13px;color:var(--txt-dim)}
.cta-badges span{display:inline-flex;align-items:center;gap:7px}
.cta-badges svg{width:20px;height:20px;color:var(--cyan)}
.cta-badges span:nth-child(2) svg{color:var(--purple)}
.cta-badges span:nth-child(3) svg{color:var(--pink)}
.cta-visual{position:relative;height:330px}
.podium{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);width:300px;height:60px;border-radius:50%;
  background:radial-gradient(closest-side,rgba(124,77,255,.8),rgba(255,31,142,.3),transparent);filter:blur(2px);
  box-shadow:0 0 60px rgba(124,77,255,.6)}
.cta-lw{position:absolute;bottom:60px;height:175px}
.lw1{left:34%;bottom:74px}.lw2{left:48%;bottom:80px;height:185px}
.lw3{left:62%;bottom:78px;height:180px}.lw4{left:76%;bottom:70px}
.cta-sk{position:absolute;bottom:46px;height:120px}
.sk1{left:20%}.sk2{left:33%;bottom:42px}.sk3{left:47%;bottom:40px}

/* ===== Footer ===== */
.site-footer{background:var(--navy-900);padding:58px 0 0;border-top:1px solid rgba(124,124,255,.15)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1.5fr;gap:34px}
.foot-logo{height:100px;margin-bottom:14px}
.foot-brand p{color:var(--txt-dim);font-size:14px}
.foot-col h4{font-size:14px;letter-spacing:1px;margin-bottom:16px;color:#fff}
.foot-col>a{display:block;color:var(--txt-dim);font-size:14px;margin-bottom:10px;transition:.2s}
.foot-col>a:hover{color:var(--pink)}
.fline{display:flex;gap:10px;align-items:flex-start;color:var(--txt-dim);font-size:14px;margin-bottom:14px}
.fline svg{width:22px;height:22px;color:var(--cyan);flex-shrink:0;margin-top:2px}
.fline small{color:#7b84a8}
.social{display:flex;gap:12px;margin-bottom:10px}
.social a{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(124,124,255,.3)}
.social svg{width:22px;height:22px;color:var(--pink)}
.news-title{margin-top:22px}
.newsletter{display:flex;gap:8px;margin-top:6px}
.newsletter input{flex:1;padding:12px 16px;border-radius:999px;border:1px solid rgba(124,124,255,.3);
  background:rgba(255,255,255,.05);color:#fff;font-size:14px}
.newsletter input::placeholder{color:var(--txt-dim)}
.newsletter button{padding:12px 20px;font-size:13px;white-space:nowrap}
.news-note{display:block;color:#7b84a8;font-size:12px;margin-top:10px}
.news-note a{color:var(--cyan)}
.news-msg{display:block;color:var(--green);font-size:13px;margin-top:8px;min-height:16px}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:24px 24px;margin-top:38px;
  border-top:1px solid rgba(124,124,255,.15);color:var(--txt-dim);font-size:13px}
.foot-strip{display:flex;align-items:center;justify-content:center;gap:14px;padding:14px;font-family:'Montserrat';
  font-weight:700;letter-spacing:3px;font-size:13px;color:#fff;background:linear-gradient(90deg,#0e1440,#2d1450,#0e1440)}
.foot-strip i{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.foot-strip i.pink{background:var(--pink);box-shadow:0 0 8px var(--pink)}

/* WhatsApp float */
.wpp-float{position:fixed;right:22px;bottom:22px;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,#25d366,#128c4a);display:flex;align-items:center;justify-content:center;
  z-index:60;box-shadow:0 10px 30px rgba(37,211,102,.5);animation:pulse 2.5s infinite}
.wpp-float svg{width:32px;height:32px;color:#fff}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* Reveal */
.reveal{opacity:0;transform:translateY(30px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:980px){
  .hero-grid,.depo-grid,.cta-grid{grid-template-columns:1fr}
  .hero-cards{margin-top:8px}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .benefits{grid-template-columns:1fr;gap:18px}
  .benefit{border-right:none!important;padding-right:0}
  .reviews{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .main-nav,.header-cta{display:none}
  .nav-toggle{display:flex}
  .depo-logo{display:none}
  .main-nav.open{display:flex;position:absolute;top:96px;left:0;right:0;flex-direction:column;
    background:var(--navy-800);padding:20px 24px;gap:16px;border-bottom:1px solid rgba(124,124,255,.2)}
  .frame{padding:28px}
  .cta-visual{height:280px}
}
@media(max-width:560px){
  .product-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero h1{font-size:34px}
  .story.s1,.story.s3{height:300px}.story.s2{height:340px}
  .foot-bottom{flex-direction:column}
}

/* =================== LOJA =================== */
.product-card .price{font-family:'Montserrat';font-weight:900;font-size:24px;color:#fff;margin-bottom:12px;line-height:1.15}
.product-card .add-btn{width:100%;font-size:14px}

/* selo promocional */
.promo-bar{display:inline-block;margin-top:14px;padding:8px 18px;border-radius:999px;font-size:14px;color:#fff;
  background:linear-gradient(95deg,rgba(45,125,255,.18),rgba(255,31,142,.18));border:1px solid rgba(255,31,142,.4)}
.promo-bar b{color:var(--green)}

/* ---- KITS ---- */
.kits-head{margin-top:64px}
.kits-grid{margin-top:8px}
.kit-card{position:relative;border-color:rgba(255,31,142,.3)}
.kit-card::before{opacity:1;height:4px}
.kit-card .prod-stage .sock{height:96px}
.kit-card .prod-stage .legwarmer.small{height:150px}
.kit-flag{position:absolute;top:12px;right:12px;z-index:3;background:linear-gradient(95deg,#7b4dff,#ff1f8e);
  color:#fff;font-size:11px;font-weight:800;padding:5px 11px;border-radius:999px;box-shadow:0 6px 16px rgba(255,31,142,.45)}
.kit-flag.big{background:linear-gradient(95deg,#2d7dff,#7b4dff,#ff1f8e);font-size:12px}
.kit-sub{display:block;font-family:'Inter';font-weight:600;font-size:12px;color:var(--txt-dim);margin-top:4px}
.featured-kit{border-color:var(--pink);box-shadow:0 0 30px rgba(255,31,142,.18)}
.price .p-de{display:inline-block;font-family:'Inter';font-weight:600;font-size:14px;color:#7b84a8;
  text-decoration:line-through;text-decoration-color:var(--pink);margin-right:2px}

/* ---- Modal multi-componente ---- */
.pm-img.multi{flex-wrap:wrap;gap:6px;align-content:flex-end;padding:14px}
.pm-img.multi svg.legwarmer{height:92px}
.pm-img.multi svg.sock{height:66px}
.pm-img.multi .prod-photo{height:92px}
.pm-img.multi .prod-photo.sock-photo{height:66px}
.pm-comp{padding:12px 0;border-bottom:1px dashed rgba(124,124,255,.2)}
.pm-comp:last-of-type{border-bottom:none}
.pm-comp-title{font-family:'Montserrat';font-weight:800;font-size:13px;color:var(--pink-soft);margin-bottom:8px;
  text-transform:uppercase;letter-spacing:.5px}
.pm-de{font-family:'Inter';font-weight:600;font-size:15px;color:#7b84a8;text-decoration:line-through;
  text-decoration-color:var(--pink);margin-right:4px}

/* tag KIT no carrinho */
.ci-img{position:relative}
.ci-kit{position:absolute;top:-6px;left:-6px;background:var(--grad-btn);color:#fff;font-size:9px;font-weight:800;
  padding:2px 6px;border-radius:6px;box-shadow:0 3px 8px rgba(255,31,142,.5)}

/* modal alto com muitos componentes: rola dentro */
#productModal .modal-card{max-height:92vh}
#pmOptions{max-height:46vh;overflow-y:auto}

/* ---- Carrossel horizontal (marquee controlado por JS) ---- */
.product-grid.marquee{display:block;overflow:hidden;padding:10px 0;position:relative;
  -webkit-mask:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);
          mask:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.marquee-track{display:flex;width:max-content;will-change:transform;cursor:grab;
  touch-action:pan-y;user-select:none;-webkit-user-select:none}
.marquee-track.rev{}
.marquee-track.grabbing{cursor:grabbing}
.product-grid.marquee .product-card{flex:0 0 256px;margin-right:22px;pointer-events:auto}

/* controles do marquee */
.mq-ctrl{position:absolute;top:6px;right:10px;z-index:6;display:flex;align-items:center;gap:4px;
  background:rgba(11,12,18,.78);border:1px solid rgba(255,255,255,.12);border-radius:20px;
  padding:4px 6px;backdrop-filter:blur(8px);box-shadow:0 4px 14px rgba(0,0,0,.4)}
.mq-btn{width:30px;height:30px;border-radius:50%;border:0;background:transparent;color:#fff;
  cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:.15s}
.mq-btn:hover{background:rgba(255,31,142,.25);color:var(--pink,#ff1f8e)}
.mq-btn:focus-visible{outline:2px solid var(--pink,#ff1f8e);outline-offset:1px}
.mq-btn svg{width:16px;height:16px;fill:currentColor}
.mq-speed{font-size:11.5px;font-weight:700;color:var(--pink-soft,#ff7ac0);min-width:30px;text-align:center;
  font-variant-numeric:tabular-nums}
.product-grid.marquee.paused .mq-ctrl{border-color:rgba(255,31,142,.4)}

/* botão de add dentro do track continua clicável — track só inicia drag se mover */
@media(max-width:560px){
  .product-grid.marquee .product-card{flex-basis:80vw;margin-right:16px}
  .mq-ctrl{top:2px;right:4px;padding:3px 4px;gap:2px}
  .mq-btn{width:26px;height:26px}
  .mq-speed{font-size:10.5px;min-width:24px}
}
@media(prefers-reduced-motion:reduce){
  .marquee-track{transform:none !important}
  .mq-ctrl{display:none}
}

/* Cart button */
.cart-btn{position:relative;background:rgba(255,255,255,.05);border:1.5px solid rgba(124,124,255,.35);
  width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.25s}
.cart-btn:hover{border-color:var(--pink);box-shadow:0 0 20px rgba(255,31,142,.3)}
.cart-btn svg{width:24px;height:24px;color:#fff}
.cart-count{position:absolute;top:-8px;right:-8px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;
  background:var(--grad-btn);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(255,31,142,.5);transform:scale(0);transition:.25s}
.cart-count.show{transform:scale(1)}

/* Overlay */
.overlay{position:fixed;inset:0;background:rgba(4,6,20,.7);backdrop-filter:blur(3px);opacity:0;visibility:hidden;
  transition:.3s;z-index:80}
.overlay.show{opacity:1;visibility:visible}

/* Cart drawer */
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;z-index:90;display:flex;flex-direction:column;
  background:linear-gradient(180deg,#0b1030,#080b22);border-left:1px solid rgba(124,124,255,.25);
  box-shadow:-20px 0 60px rgba(0,0,0,.6);transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.cart-drawer.open{transform:none}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:22px 22px 16px;border-bottom:1px solid rgba(124,124,255,.18)}
.cart-head h3{font-size:20px;font-weight:800}
.close-x{background:rgba(255,255,255,.06);border:none;color:#fff;width:34px;height:34px;border-radius:10px;cursor:pointer;font-size:15px;transition:.2s}
.close-x:hover{background:var(--pink)}
.cart-body{flex:1;overflow-y:auto;padding:18px 22px}
.cart-empty{text-align:center;color:var(--txt-dim);padding:60px 10px}
.cart-empty svg{width:54px;height:54px;color:rgba(124,124,255,.5);margin-bottom:14px}
.cart-empty small{color:#6b74a0;font-size:13px}

.cart-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid rgba(124,124,255,.12)}
.ci-img{width:64px;height:64px;border-radius:12px;background:radial-gradient(circle at 50% 40%,rgba(124,77,255,.25),rgba(8,12,38,.6));
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-img svg{height:52px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.5))}
.ci-img .prod-photo{height:56px;object-fit:contain;filter:drop-shadow(0 4px 6px rgba(0,0,0,.5))}
.ci-info{flex:1;min-width:0}
.ci-name{font-weight:700;font-size:14px}
.ci-meta{font-size:12px;color:var(--txt-dim);margin:2px 0 8px}
.ci-bottom{display:flex;align-items:center;justify-content:space-between}
.ci-qty{display:flex;align-items:center;gap:0;border:1px solid rgba(124,124,255,.3);border-radius:8px;overflow:hidden}
.ci-qty button{background:rgba(255,255,255,.05);border:none;color:#fff;width:26px;height:26px;cursor:pointer;font-size:15px}
.ci-qty button:hover{background:var(--purple)}
.ci-qty span{min-width:28px;text-align:center;font-size:13px;font-weight:700}
.ci-price{font-weight:800;font-size:15px}
.ci-remove{background:none;border:none;color:#7b84a8;cursor:pointer;width:26px;height:26px}
.ci-remove svg{width:18px;height:18px}
.ci-remove:hover{color:var(--pink)}

.cart-frete{margin-top:18px;padding-top:18px;border-top:1px solid rgba(124,124,255,.18)}
.cart-frete>label{display:block;font-size:13px;font-weight:700;margin-bottom:10px;color:var(--txt-dim)}
.frete-row{display:flex;gap:8px}
.frete-row input{flex:1;padding:11px 14px;border-radius:10px;border:1px solid rgba(124,124,255,.3);background:rgba(255,255,255,.05);color:#fff;font-size:14px}
.frete-row .btn{padding:11px 18px}
.frete-result{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.frete-opt{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 14px;border-radius:10px;
  border:1px solid rgba(124,124,255,.25);cursor:pointer;font-size:13px;transition:.2s}
.frete-opt:hover{border-color:var(--purple)}
.frete-opt.active{border-color:var(--pink);background:rgba(255,31,142,.08)}
.frete-opt b{font-size:14px}
.frete-opt .fo-price{font-weight:800;color:var(--green)}
.frete-addr{font-size:12px;color:var(--txt-dim);margin-top:4px}
.frete-msg{font-size:12.5px;color:var(--pink-soft)}

.cart-foot{padding:18px 22px;border-top:1px solid rgba(124,124,255,.18);background:rgba(8,12,38,.6)}
.cart-line{display:flex;justify-content:space-between;font-size:14px;color:var(--txt-dim);margin-bottom:8px}
.cart-line.total{font-size:19px;font-weight:800;color:#fff;margin:10px 0 14px;padding-top:10px;border-top:1px solid rgba(124,124,255,.18)}
.cart-foot .btn{width:100%}

/* Modals */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:20px;
  background:rgba(4,6,20,.75);backdrop-filter:blur(4px)}
.modal.open{display:flex;animation:fadein .25s}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.modal-card{position:relative;width:480px;max-width:100%;max-height:92vh;overflow-y:auto;border-radius:22px;padding:28px;
  background:linear-gradient(180deg,#0e1440,#0a0e2c);border:1px solid rgba(124,124,255,.3);box-shadow:var(--shadow);animation:pop .3s}
.modal-card.wide{width:620px}
@keyframes pop{from{transform:translateY(20px) scale(.97)}to{transform:none}}
.modal-card .close-x{position:absolute;top:16px;right:16px}
.modal-title{font-size:22px;font-weight:800;margin-bottom:18px}

.pm-body{display:flex;gap:22px}
.pm-img{width:160px;flex-shrink:0;border-radius:16px;background:radial-gradient(circle at 50% 35%,rgba(124,77,255,.28),rgba(8,12,38,.7));
  display:flex;align-items:flex-end;justify-content:center;padding:16px;min-height:200px}
.pm-img svg.legwarmer{height:175px}.pm-img svg.sock{height:120px}
.pm-img .prod-photo{height:175px;object-fit:contain;filter:drop-shadow(0 10px 18px rgba(0,0,0,.55))}
.pm-img .prod-photo.sock-photo{height:120px}
.pm-info{flex:1}
.pm-info h3{font-size:20px;font-weight:800;line-height:1.2}
.pm-price{font-family:'Montserrat';font-weight:900;font-size:26px;margin:6px 0 16px;color:#fff}
.pm-field{margin-bottom:14px}
.pm-field>label{display:block;font-size:12px;font-weight:700;color:var(--txt-dim);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.opt-row{display:flex;gap:8px;flex-wrap:wrap}
.opt{padding:8px 14px;border-radius:9px;border:1.5px solid rgba(124,124,255,.3);background:rgba(255,255,255,.03);
  color:#fff;font-size:13px;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:7px}
.opt:hover{border-color:var(--purple)}
.opt.active{border-color:var(--pink);background:rgba(255,31,142,.1)}
.opt .dot{width:14px;height:14px;border-radius:50%;background:var(--c);border:1px solid rgba(255,255,255,.4)}
.qty{display:inline-flex;align-items:center;border:1.5px solid rgba(124,124,255,.3);border-radius:10px;overflow:hidden}
.qty button{background:rgba(255,255,255,.05);border:none;color:#fff;width:38px;height:38px;font-size:18px;cursor:pointer}
.qty button:hover{background:var(--purple)}
.qty span{min-width:44px;text-align:center;font-weight:700}
#pmAdd{width:100%;margin-top:8px}

/* Checkout */
.cf-sub{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--cyan);margin:6px 0 12px}
.cf-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.checkout-form input{padding:12px 14px;border-radius:10px;border:1px solid rgba(124,124,255,.3);
  background:rgba(255,255,255,.05);color:#fff;font-size:14px;width:100%}
.checkout-form input::placeholder{color:var(--txt-dim)}
.checkout-form input:focus{outline:none;border-color:var(--pink)}
.span2{grid-column:span 2}
.pay-opts{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.pay-opt{text-align:left;padding:14px 16px;border-radius:12px;border:1.5px solid rgba(124,124,255,.3);
  background:rgba(255,255,255,.03);color:#fff;cursor:pointer;transition:.2s;display:flex;flex-direction:column;gap:2px}
.pay-opt:hover{border-color:var(--purple)}
.pay-opt.active{border-color:var(--pink);background:rgba(255,31,142,.08);box-shadow:0 0 20px rgba(255,31,142,.15)}
.pay-opt strong{font-size:15px}
.pay-opt small{font-size:12px;color:var(--txt-dim)}
.checkout-summary{padding:16px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid rgba(124,124,255,.2);margin-bottom:16px}
#coConfirm{width:100%}
.cf-secure{text-align:center;font-size:12px;color:var(--txt-dim);margin-top:12px}

/* Pix */
.pix-card{width:420px;text-align:center}
.pix-amount{font-family:'Montserrat';font-weight:900;font-size:30px;color:var(--green);margin-bottom:16px}
.pix-qr{width:220px;height:220px;border-radius:14px;background:#fff;padding:8px;margin:0 auto 18px;display:block}
.pix-label{display:block;font-size:12px;color:var(--txt-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.pix-copy{display:flex;gap:8px;margin-bottom:14px}
.pix-copy input{flex:1;padding:11px 12px;border-radius:10px;border:1px solid rgba(124,124,255,.3);
  background:rgba(255,255,255,.05);color:#fff;font-size:12px;overflow:hidden;text-overflow:ellipsis}
.pix-hint{font-size:12.5px;color:var(--txt-dim);margin-bottom:16px;line-height:1.5}
#pixSentBtn{width:100%}

/* Toast */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);z-index:120;
  background:linear-gradient(95deg,#7b4dff,#ff1f8e);color:#fff;padding:13px 22px;border-radius:999px;font-size:14px;
  font-weight:600;box-shadow:0 12px 30px rgba(255,31,142,.4);opacity:0;visibility:hidden;transition:.3s}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* Cartão */
.card-fields{margin:-6px 0 18px;padding:16px;border-radius:12px;border:1px dashed rgba(124,124,255,.35);background:rgba(45,125,255,.05)}
.card-fields .cf-grid{margin-bottom:0}
.checkout-form select{padding:12px 14px;border-radius:10px;border:1px solid rgba(124,124,255,.3);
  background:rgba(255,255,255,.05);color:#fff;font-size:14px;width:100%}
.checkout-form select option{background:#0e1440}
.card-secure{font-size:11.5px;color:var(--txt-dim);margin-top:10px}

/* Status (polling) */
.pay-status{display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;color:var(--pink-soft);
  font-weight:600;margin:6px 0 14px}
.spin{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,122,192,.35);border-top-color:var(--pink);
  display:inline-block;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Sucesso / pendente */
.pay-success{text-align:center;padding:14px 6px}
.ps-ico{width:74px;height:74px;border-radius:50%;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;
  font-size:36px;background:rgba(124,77,255,.18);color:#fff}
.ps-ico.ok{background:linear-gradient(135deg,#2d7dff,#7b4dff,#ff1f8e);box-shadow:0 0 40px rgba(255,31,142,.5);font-weight:900}
.pay-success h3{font-size:22px;font-weight:800;margin-bottom:8px}
.pay-success p{color:var(--txt-dim);font-size:14px;margin-bottom:20px}
.pay-success .btn{width:100%}

@media(max-width:560px){
  .pm-body{flex-direction:column}
  .pm-img{width:100%;min-height:150px}
  .cf-grid{grid-template-columns:1fr}
  .span2{grid-column:auto}
}
