/* Widget de veículo, kits e bloco de compra. */

/* ================= WIDGET VEÍCULO (MACENA) — estilo LP (branco + #E11D48) ================= */

/* NÃO precisa @font-face aqui (você já usa Inter na LP) */
/* Mantém tudo harmonizado com a página */

#widget-macena{
  color:#111;
  box-sizing:border-box;
  margin: 14px auto 0;
  max-width: 560px;
  width: 100%;
}

#widget-macena *{ box-sizing:border-box; }

#widget-macena .macena-container{
  background:#fff;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(17,17,17,.10);
  box-shadow: 0 10px 30px rgba(17,17,17,.06);
}

#widget-macena .vehiclePanelIntro{
  margin-bottom: 14px;
}

#widget-macena .panelTitle .accent{
  color:#E11D48;
}

/* Título */
#widget-macena h2{
  text-align:center;
  margin: 2px 0 6px 0;
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color:#111;
}

#widget-macena .subtitle{
  text-align:center;
  margin: 0 0 16px 0;
  font-size: .92rem;
  color: rgba(17,17,17,.62);
}

#widget-macena .vehicleJourney{
  margin: 0 0 18px 0;
}

#widget-macena .vehicleJourney__rail{
  position: relative;
  padding: 42px 0 0;
}

#widget-macena .vehicleJourney__rail::before{
  content:"";
  position: absolute;
  left: 14px;
  right: 14px;
  top: 36px;
  height: 14px;
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.72)),
    linear-gradient(90deg, rgba(225,29,72,.08), rgba(59,130,246,.08), rgba(22,163,74,.08));
  border: 1px solid rgba(17,17,17,.10);
  box-shadow: inset 0 2px 8px rgba(17,17,17,.07);
}

#widget-macena .vehicleJourney__fill{
  position: absolute;
  left: 14px;
  right: 14px;
  top: 36px;
  height: 14px;
  border-radius: 999px;
  transform-origin: left center;
  transform: scaleX(var(--vehicle-progress, .08));
  background: linear-gradient(90deg, #fde7ee 0%, #fecdd3 22%, #dbeafe 48%, #a7f3d0 78%, #16A34A 100%);
  box-shadow: 0 6px 18px rgba(34,197,94,.16);
  transition: transform .55s cubic-bezier(.22,1,.36,1);
}

#widget-macena .vehicleJourney__car{
  position: absolute;
  top: 4px;
  width: 64px;
  height: 36px;
  left: calc(14px + ((100% - 92px) * var(--vehicle-car-progress, .08)));
  transform: translateY(0);
  transition: left .55s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
  filter: drop-shadow(0 8px 14px rgba(17,17,17,.16));
}

#widget-macena .vehicleJourney__car-body{
  position: absolute;
  left: 4px;
  right: 4px;
  bottom: 8px;
  height: 16px;
  border-radius: 12px 14px 8px 8px;
  background: linear-gradient(180deg, #ffe173 0%, #ffc933 58%, #f59e0b 100%);
  border: 1px solid rgba(180,83,9,.26);
}

#widget-macena .vehicleJourney__car-top{
  position: absolute;
  left: 16px;
  right: 12px;
  bottom: 18px;
  height: 12px;
  border-radius: 14px 16px 6px 6px;
  background: linear-gradient(180deg, #ffe88c 0%, #ffd24f 100%);
  border: 1px solid rgba(180,83,9,.18);
  transform: skewX(-18deg);
}

#widget-macena .vehicleJourney__car-window{
  position: absolute;
  top: 12px;
  height: 8px;
  background: linear-gradient(180deg, #dbeafe, #93c5fd);
  border: 1px solid rgba(30,64,175,.14);
}

#widget-macena .vehicleJourney__car-window--front{
  left: 34px;
  width: 13px;
  border-radius: 2px 6px 4px 2px;
  transform: skewX(-18deg);
}

#widget-macena .vehicleJourney__car-window--rear{
  left: 22px;
  width: 10px;
  border-radius: 6px 2px 2px 4px;
  transform: skewX(-18deg);
}

#widget-macena .vehicleJourney__wheel{
  position: absolute;
  bottom: 2px;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: radial-gradient(circle at 50% 50%, #fff 0 26%, #475569 28% 60%, #111827 62% 100%);
  border: 1px solid rgba(17,17,17,.14);
}

#widget-macena .vehicleJourney__wheel--front{ right: 12px; }
#widget-macena .vehicleJourney__wheel--rear{ left: 12px; }

#widget-macena .vehicleJourney__stages{
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  align-items: start;
}

#widget-macena .vehicleProgress__step{
  position: relative;
  display: grid;
  justify-items: center;
  gap: 4px;
  padding-top: 32px;
  color: rgba(17,17,17,.54);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .01em;
  text-align: center;
}

#widget-macena .vehicleProgress__step strong,
#widget-macena .vehicleProgress__step em{
  position: relative;
  z-index: 2;
  font-style: normal;
}

#widget-macena .vehicleProgress__step strong{
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(17,17,17,.10);
  box-shadow: 0 6px 18px rgba(17,17,17,.06);
}

#widget-macena .vehicleProgress__step em{
  font-size: .7rem;
}

#widget-macena .vehicleProgress__step.is-active{
  color: #b3123a;
}

#widget-macena .vehicleProgress__step.is-active strong{
  background: linear-gradient(180deg, #fff1f4, #ffe3ea);
  border-color: rgba(225,29,72,.24);
  box-shadow: 0 10px 24px rgba(225,29,72,.18);
}

#widget-macena .vehicleProgress__step.is-complete{
  color: #15803D;
}

#widget-macena .vehicleProgress__step.is-complete strong{
  background: linear-gradient(180deg, #effdf5, #dcfce7);
  border-color: rgba(22,163,74,.26);
  box-shadow: 0 10px 24px rgba(22,163,74,.16);
}

#widget-macena .vehicleProgress__step.is-complete strong::after{
  content:"";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 10px;
  height: 6px;
  border-left: 2px solid #15803D;
  border-bottom: 2px solid #15803D;
  transform: rotate(-45deg) translate(1px, -1px);
}

#widget-macena .vehicleProgress__step.is-pulse strong{
  animation: stepPulse .42s ease;
}

#widget-macena .vehicleFieldsFlow{
  display: grid;
  gap: 0;
  padding: 16px 14px;
  border-radius: 24px;
  background:
    radial-gradient(circle at top left, rgba(254,205,211,.52), transparent 34%),
    radial-gradient(circle at top right, rgba(191,219,254,.40), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.94));
  border: 1px solid rgba(225,29,72,.10);
  box-shadow: 0 18px 40px rgba(17,17,17,.07);
}

/* Form */
#widget-macena .form-group{
  position: relative;
  margin-bottom: 0;
  padding: 14px 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(17,17,17,.08);
  box-shadow: 0 8px 18px rgba(17,17,17,.04);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
}

#widget-macena .form-group--vehicle{
  margin-bottom: 0;
}

#widget-macena .form-group--vehicle.is-active,
#widget-macena .form-group--colorStage.is-active{
  border-color: rgba(225,29,72,.24);
  box-shadow: 0 14px 28px rgba(225,29,72,.12);
  background: linear-gradient(180deg, rgba(255,245,247,.96), rgba(255,255,255,.92));
}

#widget-macena .form-group--vehicle.is-active label{
  color: #B3123A;
}

#widget-macena .form-group--vehicle.is-complete,
#widget-macena .form-group--colorStage.is-complete{
  border-color: rgba(22,163,74,.22);
  box-shadow: 0 16px 32px rgba(22,163,74,.12);
  background: linear-gradient(180deg, rgba(240,253,244,.96), rgba(255,255,255,.92));
}

#widget-macena .form-group--vehicle.is-complete label,
#widget-macena .form-group--colorStage.is-complete label{
  color: #15803D;
}

#widget-macena .flowStepTag{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 4px 10px;
  margin-bottom: 10px;
  border-radius: 999px;
  background: rgba(17,17,17,.05);
  color: rgba(17,17,17,.56);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

#widget-macena .form-group--vehicle.is-active .flowStepTag,
#widget-macena .form-group--colorStage.is-active .flowStepTag{
  background: rgba(225,29,72,.11);
  color: #b3123a;
}

#widget-macena .form-group--vehicle.is-complete .flowStepTag,
#widget-macena .form-group--colorStage.is-complete .flowStepTag{
  background: rgba(22,163,74,.12);
  color: #15803D;
}

#widget-macena .form-group label{
  font-size: .78rem;
  font-weight: 800;
  margin-bottom: 8px;
  display:block;
  color: rgba(17,17,17,.72);
  text-transform: uppercase;
  letter-spacing: .06em;
}

#widget-macena .color-prompt{
  margin: 2px 0 0;
  font-size: .86rem;
  color: rgba(17,17,17,.60);
  line-height: 1.35;
}

#widget-macena .colorStageIntro{
  display: grid;
  gap: 2px;
  margin-bottom: 12px;
}

#widget-macena .formConnector{
  position: relative;
  height: 28px;
}

#widget-macena .formConnector span{
  position: absolute;
  left: 50%;
  top: 0;
  width: 2px;
  height: 100%;
  transform: translateX(-50%);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(225,29,72,.10), rgba(59,130,246,.10), rgba(22,163,74,.10));
}

#widget-macena .formConnector span::after{
  content:"";
  position: absolute;
  left: 50%;
  bottom: 2px;
  width: 8px;
  height: 8px;
  border-right: 2px solid rgba(17,17,17,.28);
  border-bottom: 2px solid rgba(17,17,17,.28);
  transform: translateX(-50%) rotate(45deg);
}

#widget-macena .form-group--vehicle.is-complete + .formConnector span{
  background: linear-gradient(180deg, rgba(22,163,74,.18), rgba(34,197,94,.58));
  box-shadow: 0 0 0 4px rgba(22,163,74,.07);
}

#widget-macena .form-group--vehicle.is-active + .formConnector span{
  background: linear-gradient(180deg, rgba(225,29,72,.18), rgba(244,63,94,.54));
  box-shadow: 0 0 0 4px rgba(225,29,72,.07);
}

#widget-macena .fieldShell{
  position: relative;
}

#widget-macena .fieldShell::before{
  content:"";
  position:absolute;
  inset: 0;
  border-radius: 12px;
  pointer-events:none;
  box-shadow: inset 0 0 0 1px transparent;
  transition: box-shadow .2s ease;
}

#widget-macena .fieldShell.is-pulse select{
  border-color: rgba(225,29,72,.65);
  box-shadow: 0 0 0 5px rgba(225,29,72,.12), 0 12px 28px rgba(225,29,72,.10);
}

#widget-macena .fieldShell.is-active::before{
  box-shadow: inset 0 0 0 1px rgba(225,29,72,.28), 0 0 0 5px rgba(225,29,72,.09);
}

#widget-macena .fieldShell.is-complete::before{
  box-shadow: inset 0 0 0 1px rgba(22,163,74,.28), 0 0 0 5px rgba(22,163,74,.09);
}

#widget-macena .fieldShell::after{
  content:"";
  position:absolute;
  top: 50%;
  right: 14px;
  width: 10px;
  height: 10px;
  border-right: 2px solid rgba(17,17,17,.48);
  border-bottom: 2px solid rgba(17,17,17,.48);
  transform: translateY(-65%) rotate(45deg);
  pointer-events:none;
}

/* Selects (bem clean, com foco vermelho) */
#widget-macena select,
#widget-macena input{
  width:100%;
  height: 46px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(17,17,17,.18);
  background:#fff;
  font-size: 1rem;
  color:#111;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
  -webkit-appearance: none;
  appearance: none;
}

#widget-macena select{
  padding-right: 42px;
}

#widget-macena select:focus,
#widget-macena input:focus{
  border-color: rgba(225,29,72,.55);
  box-shadow: 0 0 0 4px rgba(225,29,72,.15);
}

#widget-macena select:disabled{
  background: rgba(17,17,17,.04);
  color: rgba(17,17,17,.45);
  cursor:not-allowed;
}

#widget-macena .vehicle-search-box{
  display:flex;
  gap:10px;
}

#widget-macena .vehicle-search-group{
  position: relative;
}

#widget-macena .vehicle-search-clear{
  width:auto;
  min-width:88px;
  border: 1px solid rgba(17,17,17,.18);
  background:#fff;
  color:#111;
  border-radius: 12px;
  padding: 0 14px;
  cursor:pointer;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}

#widget-macena .vehicle-search-clear:hover{
  transform: translateY(-1px);
}

#widget-macena .vehicle-search-results{
  display:grid;
  gap:10px;
  margin-top:12px;
}

#widget-macena .vehicle-search-result{
  width:100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(17,17,17,.10);
  background:#fff;
  text-align:left;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  box-shadow: 0 8px 18px rgba(17,17,17,.05);
}

#widget-macena .vehicle-search-result:hover{
  transform: translateY(-1px);
  border-color: rgba(225,29,72,.30);
  box-shadow: 0 10px 22px rgba(17,17,17,.08);
}

#widget-macena .vehicle-search-result strong,
#widget-macena .vehicle-search-result span{
  display:block;
}

#widget-macena .vehicle-search-result span{
  margin-top:4px;
  color: rgba(17,17,17,.62);
  font-size:.88rem;
}

#widget-macena .vehicle-search-result mark{
  background: rgba(225,29,72,.12);
  color: inherit;
  padding: 0 .1em;
  border-radius: .2em;
}

#widget-macena .vehicle-search-hint,
#widget-macena .vehicle-search-empty{
  color: rgba(17,17,17,.62);
  font-size: .82rem;
}

#widget-macena .vehicle-search-hint{
  margin-top: 8px;
}

#widget-macena .vehicle-search-empty{
  padding: 2px 2px 0;
}

/* Bolinhas de cor */
#widget-macena .color-selector-container{
  display:flex;
  gap: 14px;
  justify-content:center;
  padding: 8px 0 2px;
  transition: opacity .2s ease;
}

#widget-macena .color-selector-container.disabled{
  opacity:.35;
  pointer-events:none;
}

#widget-macena .color-selector-container.is-active{
  animation: colorGlow .55s ease;
}

#widget-macena .color-btn{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 2px solid rgba(17,17,17,.14);
  position: relative;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  box-shadow: 0 6px 16px rgba(17,17,17,.10);
}

#widget-macena .color-btn:hover{
  transform: translateY(-1px) scale(1.04);
}

/* cores */
#widget-macena .bg-preto{ background:#111111; }
#widget-macena .bg-cinza{ background:#5a5a5a; }
#widget-macena .bg-bege{ background:#C8AD7F; }

/* selecionado (cor da loja) */
#widget-macena .color-btn.selected{
  border-color: rgba(225,29,72,.90);
  box-shadow: 0 0 0 5px rgba(225,29,72,.18), 0 10px 22px rgba(17,17,17,.10);
  transform: scale(1.08);
}

/* check no selecionado */
#widget-macena .color-btn.selected::after{
  content:"";
  position:absolute;
  inset: 10px;
  border-radius: 999px;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.85);
  opacity: .9;
}

/* label cor selecionada */
#widget-macena .color-label{
  text-align:center;
  font-size: .90rem;
  color: rgba(17,17,17,.70);
  margin-top: 10px;
  min-height: 1.2em;
  font-weight: 700;
}

#widget-macena.is-complete .stock,
#widget-macena.is-complete #resultado{
  box-shadow: 0 14px 34px rgba(22,163,74,.08);
}

/* Resultado */
#widget-macena .resultado-box{
  margin-top: 16px;
  display: none;
  animation: fadeInMacena .35s ease;
}

#widget-macena .success-box{
  background:
    radial-gradient(circle at top left, rgba(254,205,211,.34), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,247,249,.94));
  border: 1px solid rgba(225,29,72,.18);
  color: rgba(17,17,17,.90);
  padding: 16px;
  border-radius: 18px;
  text-align:center;
  box-shadow: 0 18px 36px rgba(17,17,17,.08);
}

#widget-macena .success-icon{
  font-size: 1.6rem;
  display:block;
  margin-bottom: 6px;
}

@keyframes fadeInMacena{
  from { opacity:0; transform: translateY(-6px); }
  to   { opacity:1; transform: translateY(0); }
}

@keyframes stepPulse{
  0%{ transform: scale(1); }
  40%{ transform: scale(1.06); }
  100%{ transform: scale(1); }
}

@keyframes colorGlow{
  0%{ transform: scale(0.99); }
  55%{ transform: scale(1.02); }
  100%{ transform: scale(1); }
}

/* Mobile refinado */
@media (max-width: 420px){
  #widget-macena .macena-container{ padding: 14px; border-radius: 16px; }
  #widget-macena h2{ font-size: 1.05rem; }
  #widget-macena .vehicleJourney__rail{ padding-top: 36px; }
  #widget-macena .vehicleJourney__rail::before,
  #widget-macena .vehicleJourney__fill{ left: 8px; right: 8px; top: 32px; height: 12px; }
  #widget-macena .vehicleJourney__car{ width: 52px; height: 30px; top: 6px; left: calc(8px + ((100% - 68px) * var(--vehicle-car-progress, .08))); }
  #widget-macena .vehicleJourney__stages{ gap: 4px; }
  #widget-macena .vehicleProgress__step{ padding-top: 26px; }
  #widget-macena .vehicleProgress__step strong{ width: 24px; height: 24px; font-size: .7rem; }
  #widget-macena .vehicleProgress__step em{ font-size: .63rem; }
  #widget-macena .vehicleFieldsFlow{ padding: 12px; }
  #widget-macena .form-group{ padding: 12px; border-radius: 16px; }
  #widget-macena select{ height: 44px; border-radius: 12px; }
  #widget-macena input{ height: 44px; border-radius: 12px; }
  #widget-macena .color-btn{ width: 42px; height: 42px; }
  #widget-macena .formConnector{ height: 22px; }
}
/* Validador Social */
    .macena-social-proof {
        font-family: 'Poppins', sans-serif;
        position: fixed;
        bottom: 20px;
        left: 20px;
        background: white;
        padding: 12px 18px;
        border-radius: 10px;
        box-shadow: 0 5px 25px rgba(0,0,0,0.15);
        display: flex;
        align-items: center;
        gap: 12px;
        z-index: 9999;
        max-width: 320px;
        transform: translateY(150%);
        transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
        border: 1px solid #eee;
    }

    .macena-social-proof.active {
        transform: translateY(0);
    }

    .sp-icon {
        width: 40px;
        height: 40px;
        background: #6fa2ff;
        border-radius: 50%;
        display: flex;
        justify-content: center;
        align-items: center;
        color: white;
        font-size: 18px;
        flex-shrink: 0;
    }

    .sp-text h4 {
        margin: 0;
        font-size: 0.85em;
        font-weight: 600;
        color: #333;
    }

    .sp-text p {
        margin: 2px 0 0;
        font-size: 0.75em;
        color: #666;
        line-height: 1.3;
    }

    .sp-text span.product {
        color: #0056b3;
        font-weight: 600;
    }
    .macena-social-proof{
  position: fixed;
  left: 14px;
  bottom: 14px;
  z-index: 9999;
  display: flex;
  gap: 10px;
  align-items: center;

  background: #ffffff;
  color: #fff;
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: 0 14px 30px rgba(0,0,0,.22);

  transform: translateY(14px);
  opacity: 0;
  pointer-events: none;
  transition: .28s ease;
}

.macena-social-proof.is-show{
  transform: translateY(0);
  opacity: 1;
}

.macena-social-proof .sp-icon{
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #68acff; /* verde checkout */
  font-weight: 800;
}

.macena-social-proof .sp-text h4{
  margin: 0;
  font-size: 13px;
  line-height: 1.1;
}

.macena-social-proof .sp-text p{
  margin: 2px 0 0 0;
  font-size: 12px;
  opacity: .9;
}

.macena-social-proof .product{
  font-weight: 800;
}
.panelTitle span {
  font-size: 1em;   /* força o mesmo tamanho do título */
  font-weight: 800;
  color: #E11D48;
}
/* =========================
  BLOCO KIT (2 opções)
  (classes novas: nkit / nmodal)
========================= */
.nkit{
  max-width: 560px;
  margin: 0 auto;
  padding: 14px 14px 18px;
}

.nkit__head{ margin-bottom: 10px; }
.nkit__title{
  font-size: 18px;
  line-height: 1.2;
  margin: 0;
  font-weight: 800;
}
.nkit__sub{
  margin: 6px 0 0;
  font-size: 13px;
  opacity: .78;
}

.nkit__grid{
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

/* Card */
.nkitCard{
  width: 100%;
  text-align: left;
  display: grid;
  grid-template-columns: 76px 1fr auto;
  gap: 10px;
  align-items: center;

  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  border-radius: 14px;
  padding: 10px 10px;
  cursor: pointer;

  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

.nkitCard:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(0,0,0,.07);
}

.nkitCard.is-selected{
  border-color: rgba(16,185,129,.55);
  box-shadow: 0 10px 24px rgba(16,185,129,.12);
}

/* Left area (badge + thumb) */
.nkitCard__left{
  display: grid;
  gap: 8px;
  align-content: start;
}
.nkitCard__badge{
  display: inline-flex;
  width: fit-content;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .2px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(16,185,129,.14);
  color: #0f766e;
}
.nkitCard__badge--soft{
  background: rgba(99,102,241,.12);
  color: #4338ca;
}

.nkitCard__thumb{
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: #f5f6f7;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.06);
}
.nkitCard__thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Mid area */
.nkitCard__mid{ min-width: 0; }
.nkitCard__name{
  font-size: 12.5px;
  line-height: 1.25;
  font-weight: 800;
  letter-spacing: .1px;
}
.nkitCard__name span{ opacity: .45; padding: 0 3px; }
.nkitCard__name strong{ font-weight: 900; }

.nkitCard__savePill{
  display: inline-flex;
  margin-top: 7px;
  font-size: 11px;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(0,0,0,.04);
  border: 1px solid rgba(0,0,0,.06);
  font-weight: 700;
  opacity: .95;
}

/* Right area (prices) */
.nkitCard__right{
  text-align: right;
  padding-left: 6px;
}
.nkitCard__old{
  font-size: 11px;
  opacity: .55;
  text-decoration: line-through;
  font-weight: 700;
}
.nkitCard__now{
  font-size: 15px;
  font-weight: 900;
  color: #0ea75a;
  margin-top: 2px;
}

/* Seu bloco de preço (mantive seu padrão, só dei um acabamento) */
.cta__price{
  margin-top: 12px;
  padding: 12px 12px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.10);
}

.cta__priceCompare{
  font-size: 12px;
  opacity: .7;
  font-weight: 700;
}
.cta__priceCompare span{ text-decoration: line-through; }

.cta__priceMain{
  font-size: 26px;
  font-weight: 950;
  margin-top: 6px;
  letter-spacing: -0.4px;
}

.cta__priceSub{
  font-size: 12px;
  opacity: .75;
  margin-top: 4px;
  font-weight: 700;
}

/* CTA */
.nkit__cta{
  margin-top: 10px;
  display: grid;
  place-items: center;
  text-align: center;

  background: #16a34a;
  color: #fff;
  border-radius: 14px;
  padding: 14px 12px;
  font-weight: 950;
  text-decoration: none;
  letter-spacing: .2px;

  box-shadow: 0 14px 26px rgba(22,163,74,.18);
}

.nkit__cta small{
  display: block;
  margin-top: 4px;
  font-size: 11px;
  opacity: .9;
  font-weight: 700;
}

.nkit__note{
  margin: 10px 0 0;
  font-size: 12px;
  opacity: .7;
}

/* =========================
  MODAL
========================= */
.nmodal{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}
.nmodal.is-open{ display: block; }

.nmodal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.46);
}

.nmodal__card{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(520px, calc(100% - 28px));
  background: #fff;
  border-radius: 18px;
  padding: 16px 14px;
  box-shadow: 0 18px 60px rgba(0,0,0,.22);
  border: 1px solid rgba(0,0,0,.08);
}

.nmodal__close{
  position: absolute;
  right: 12px;
  top: 10px;
  border: 0;
  background: transparent;
  font-size: 18px;
  cursor: pointer;
  opacity: .7;
}

.nmodal__title{
  margin: 0;
  font-size: 18px;
  font-weight: 950;
}
.nmodal__desc{
  margin: 6px 0 0;
  font-size: 12.5px;
  opacity: .75;
}

.nmodal__summary{
  margin-top: 12px;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  padding: 10px 10px;
  background: rgba(0,0,0,.02);
}

.nrow{
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 6px;
  border-bottom: 1px dashed rgba(0,0,0,.10);
}
.nrow:last-child{ border-bottom: 0; }
.nrow span{
  font-size: 12px;
  opacity: .7;
  font-weight: 700;
}
.nrow strong{
  font-size: 12.5px;
  font-weight: 900;
}

.nmodal__actions{
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 10px;
  margin-top: 12px;
}

.nbtn{
  border-radius: 14px;
  padding: 12px 12px;
  font-weight: 900;
  border: 1px solid rgba(0,0,0,.12);
  cursor: pointer;
}
.nbtn--ghost{
  background: #fff;
}
.nbtn--solid{
  background: #111827;
  color: #fff;
  border-color: #111827;
}

.nmodal__fine{
  margin: 10px 0 0;
  font-size: 11px;
  opacity: .65;
}

/* Mobile tweaks */
@media (max-width: 380px){
  .nkitCard{ grid-template-columns: 70px 1fr auto; }
  .cta__priceMain{ font-size: 24px; }
}
.kit-card.selected{
  border: 2px solid #E11D48;
  background: rgba(225,29,72,.06);
}

.kit-badge{
  background:#E11D48;
  color:#fff;
  font-size:11px;
  font-weight:700;
  padding:4px 8px;
  border-radius:999px;
}

.kit-price{
  color:#16a34a; /* verde só no valor */
  font-weight:800;
}
/* =========================
   NKIT (Escolha seu kit)
   Cole no FINAL do seu CSS
========================= */
.nkit{
  width: 100%;
  padding: 18px 0 6px;
}

.nkit__head{
  margin-bottom: 12px;
}

.nkit__title{
  margin: 0;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.3px;
}

.nkit__sub{
  margin: 6px 0 0;
  font-size: 13px;
  opacity: .85;
}

/* Grid 2 opções */
.nkit__grid{
  display: grid;
  gap: 12px;
}

/* Card */
.nkitCard{
  width: 100%;
  display: grid;
  grid-template-columns: 62px 1fr auto;
  gap: 12px;
  align-items: center;

  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  border-radius: 16px;

  padding: 12px;
  cursor: pointer;
  text-align: left;

  transition: transform .12s ease, border-color .12s ease, background .12s ease, box-shadow .12s ease;
}

.nkitCard:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(0,0,0,.08);
}

/* Selected (o que você queria) */
.nkitCard.is-selected{
  border: 2px solid #E11D48;
  background: rgba(225,29,72,.06);
  box-shadow: 0 12px 30px rgba(225,29,72,.10);
}

/* Coluna esquerda */
.nkitCard__left{
  display: grid;
  gap: 8px;
  align-content: start;
  justify-items: start;
}

.nkitCard__badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .2px;
  color: #fff;
  background: #E11D48;
}

.nkitCard__badge--soft{
  background: rgba(225,29,72,.12);
  color: #E11D48;
}

/* Mini imagem */
.nkitCard__thumb{
  width: 48px;
  height: 48px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
}

.nkitCard__thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Meio */
.nkitCard__name{
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
}

.nkitCard__name span{
  opacity: .6;
  padding: 0 6px;
}

.nkitCard__savePill{
  margin-top: 8px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(22,163,74,.25);
  background: rgba(22,163,74,.10);
  color: #166534;
  font-size: 12px;
  font-weight: 700;
}

/* Direita */
.nkitCard__right{
  text-align: right;
  white-space: nowrap;
}

.nkitCard__old{
  font-size: 12px;
  text-decoration: line-through;
  opacity: .65;
}

.nkitCard__now{
  margin-top: 2px;
  font-size: 16px;
  font-weight: 900;
  color: #16a34a;
}

/* Deixa mais “premium” no mobile */
@media (max-width: 420px){
  .nkitCard{
    grid-template-columns: 58px 1fr auto;
    padding: 10px;
    border-radius: 14px;
  }
  .nkitCard__now{ font-size: 15px; }
}
/* =========================
   FIX BADGE (não esmagar conteúdo no mobile)
   Usa suas classes: .nkitCard__badge / .nkitCard__badge--soft
========================= */

.nkitCard{
  position: relative;
}

/* IMPORTANTE: não reservar espaço no meio (isso tava quebrando no celular) */
.nkitCard__mid{
  padding-right: 0 !important;
}

/* badge no canto direito */
.nkitCard__badge,
.nkitCard__badge--soft{
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 5;

  white-space: nowrap;
  line-height: 1;
  border-radius: 999px;
}

/* no mobile: badge menor pra não ficar “gigante” e não chamar tanta atenção */
@media (max-width: 520px){
  .nkitCard__badge,
  .nkitCard__badge--soft{
    top: 8px;
    right: 8px;
    font-size: 10px;
    padding: 5px 8px;
  }
}

/* (opcional mas recomendado) dá um respiro no topo do texto pra não encostar no badge */
.nkitCard__name{
  padding-top: 18px;
}

@media (max-width: 520px){
  .nkitCard__name{
    padding-top: 16px;
  }
}
/* =========================
   ENTREGA (NOVA) — nx-ship
========================= */
.nx-ship{
  margin-top: 12px;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  border-radius: 12px;
  padding: 10px 12px;
  box-shadow: 0 6px 18px rgba(0,0,0,.04);
}

.nx-ship__row{
  display: flex;
  gap: 10px;
  align-items: center;
}

.nx-ship__logo{
  width: 34px;
  height: 34px;
  object-fit: contain;
  flex: 0 0 auto;
}

.nx-ship__txt{ line-height: 1.15; }

.nx-ship__line1{
  font-size: 13px;
  color: rgba(0,0,0,.78);
}

.nx-ship__free{
  color: #16a34a;
  font-weight: 900;
}

.nx-ship__to{
  margin: 0 4px;
  color: rgba(0,0,0,.55);
}

.nx-ship__city{
  font-weight: 900;
  color: rgba(0,0,0,.82);
}

.nx-ship__line2{
  margin-top: 4px;
  font-size: 12.5px;
  color: rgba(0,0,0,.60);
}

@media (max-width: 360px){
  .nx-ship__line1{ font-size: 12.5px; }
  .nx-ship__line2{ font-size: 12px; }
}
.nxShip{
  margin-top: 12px;
  margin-bottom: 18px; /* ✅ separa do contador */
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  border-radius: 14px;
  padding: 10px 12px;
  box-shadow: 0 8px 22px rgba(0,0,0,.05);
}

.nxShip__row{ display:flex; gap:10px; align-items:center; }
.nxShip__logo{ width:34px; height:34px; object-fit:contain; flex:0 0 auto; }
.nxShip__txt{ line-height:1.15; }

.nxShip__line1{ font-size:13px; color: rgba(0,0,0,.78); }
.nxShip__free{ color:#16a34a; font-weight:900; }
.nxShip__to{ margin:0 4px; color: rgba(0,0,0,.55); }
.nxShip__city{ font-weight:900; color: rgba(0,0,0,.82); }

.nxShip__line2{ margin-top:4px; font-size:12.5px; color: rgba(0,0,0,.60); }

@media (max-width:360px){
  .nxShip__line1{ font-size:12.5px; }
  .nxShip__line2{ font-size:12px; }
}
/* FIX iPhone: texto do nome do kit não ficar azul */
.nkitCard { color: #111; } /* cor base do card */

.nkitCard__name,
.nkitCard__name *{
  color: #111 !important;
  -webkit-text-fill-color: #111; /* iOS/Safari */
}

/* mantém o "•" mais fraquinho */
.nkitCard__name span{
  color: rgba(17,17,17,.45) !important;
  -webkit-text-fill-color: rgba(17,17,17,.45);
}

/* se você quiser o "Sem/Com porta-malas" mais forte */
.nkitCard__name strong{
  font-weight: 800;
}

.review__media{
  width: 100%;
  aspect-ratio: 3 / 4;     /* ajuste pra bater com seus vídeos */
  object-fit: cover;        /* mantém proporção sem “zoom estranho” */
  border-radius: 14px;
  display: block;
  background: #111;
}

.review__play{
  position: absolute;
  right: 12px;
  bottom: 12px;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-weight: 900;
  cursor: pointer;
}

.review{ position: relative; }
.review.is-playing .review__play{ opacity: .25; }
.reviews__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}

.reviews__left{ min-width: 0; }
.reviews__title{
  font-size:18px;
  line-height:1.15;
  font-weight:900;
  margin:0;
  color:#0B0F14;
}
.reviews__sub{
  margin:6px 0 0;
  font-size:12px;
  color:rgba(11,15,20,.65);
}

.reviews__right{
  text-align:right;
  padding-left:10px;
  border-left:1px solid rgba(15,23,42,.10);
}

.rscore__top{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
}
.rscore__num{
  font-size:22px;
  font-weight:950;
  line-height:1;
  letter-spacing:-0.02em;
}
.rscore__stars{
  font-size:12px;
  letter-spacing:1px;
  color:#E11D48;
  transform: translateY(1px);
}
.rscore__meta{
  margin-top:6px;
  font-size:12px;
  color:rgba(11,15,20,.60);
}

/* mobile bem pequeno: mantém premium sem quebrar */
@media (max-width:360px){
  .reviews__head{ align-items:flex-start; }
  .reviews__right{ border-left:0; padding-left:0; }
}
.reviews__head{
  text-align:left;
  margin-bottom:14px;
}

.reviews__title{
  font-size:18px;
  font-weight:900;
  line-height:1.15;
  margin:0;
}

.reviews__sub{
  margin-top:6px;
  font-size:13px;
  color:rgba(11,15,20,.6);
}
