/**
 * Cadastro de cupom — fluxos QR, chave e dados.
 * Espaçamentos e fontes em px (#cadastrocupom.cc-css-island).
 */

@keyframes cc-fluxo-fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes cc-fluxo-slideIn {
  from {
    opacity: 0;
    transform: translateX(12px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes cc-fluxo-shake {
  0%,
  100% {
    transform: translateX(0);
  }
  20%,
  60% {
    transform: translateX(-6px);
  }
  40%,
  80% {
    transform: translateX(6px);
  }
}

@keyframes cc-fluxo-spin {
  to {
    transform: rotate(360deg);
  }
}

#cadastrocupom.cc-css-island .cc-flow {
  max-width: 896px;
  margin-left: auto;
  margin-right: auto;
}

#cadastrocupom.cc-css-island .cc-fluxo-muted {
  color: var(--c-black);
  font-size: 14px;
}

#cadastrocupom.cc-css-island .cc-fluxo-optin label span {
  font-weight: 600;
  font-size: 17px;
  line-height: 1.45;
}

#cadastrocupom.cc-css-island .cc-flow__step {
  animation: cc-fluxo-slideIn 0.35s ease both;
}

#cadastrocupom.cc-css-island .cc-flow__step[hidden] {
  display: none !important;
}

@media (prefers-reduced-motion: reduce) {
  #cadastrocupom.cc-css-island .cc-flow__step {
    animation: none;
  }
}

#cadastrocupom.cc-css-island .cc-fluxo-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--c-bluelight1);
  transition: opacity 0.2s ease;
}

#cadastrocupom.cc-css-island .cc-fluxo-back:hover {
  opacity: 0.8;
}

#cadastrocupom.cc-css-island .cc-fluxo-back:focus-visible {
  outline: 2px solid var(--c-black);
  outline-offset: 2px;
  border-radius: 4px;
}

#cadastrocupom.cc-css-island .cc-fluxo-card {
  background: var(--cc-card-bg);
  border-radius: 16px;
  /* box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1); */
  padding: 25px 15px;
  max-width: 600px;
  margin: auto;
}

@media (min-width: 768px) {
  #cadastrocupom.cc-css-island .cc-fluxo-card {
    padding: 32px;
  }
}

#cadastrocupom.cc-css-island .cc-fluxo-card__title {
  font-size: 26px;
  font-weight: 700;
  color: var(--c-black);
  text-align: center;
  margin: 0 0 24px;
  line-height: 1.25;
}

@media (min-width: 768px) {
  #cadastrocupom.cc-css-island .cc-fluxo-card__title {
    font-size: 27px;
    margin-bottom: 24px;
  }
}

#cadastrocupom.cc-css-island .cc-fluxo-tabs {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

/* Abas: btn-white (espera) /   (ativo) — ver overload.css */
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.cc-fluxo-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  height: auto;
  min-height: 48px;
  padding: 1.2rem 1.25rem 0.9rem 1.25rem;
  font-size: 1.8rem;
  font-weight: 700;
  text-transform: uppercase;
}

#cadastrocupom.cc-css-island .cc-fluxo-tab:focus-visible {
  outline: 2px solid var(--cc-highlight);
  outline-offset: 2px;
}

/*
 * Abas QR: overload.css força .btn-white svg path { stroke: white } (invisível no fundo branco)
 * e não cobre <circle>/<line>/<polyline>. Aqui alinhamos traço ao texto de cada variante.
 */
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white svg path,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white svg circle,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white svg polyline,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white svg line,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white:hover svg path,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white:hover svg circle,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white:hover svg polyline,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white:hover svg line,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white:focus svg path,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white:focus svg circle,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white:focus svg polyline,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn.btn-white:focus svg line {
  stroke: var(--c-yellow1) !important;
}

#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn svg path,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn svg circle,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn svg polyline,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn svg line,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn:hover svg path,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn:hover svg circle,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn:hover svg polyline,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn:hover svg line,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn:focus svg path,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn:focus svg circle,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn:focus svg polyline,
#cadastrocupom.cc-css-island .cc-fluxo-tabs .btn:focus svg line {
  stroke: var(--c-white) !important;
}

/* Mesmo padrão do CTA flutuante (components/wc-cta + CSS base da campanha), fora da .barra-participe */
#cadastrocupom.cc-css-island .btn.barra-participe-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.85rem;
  width: 100%;
  margin-top: 24px;
  text-decoration: none;
  padding: 1.8rem 2.5rem 1.6rem 2.5rem;
}

#cadastrocupom.cc-css-island .btn.barra-participe-cta span {
  position: relative;
  z-index: 1;
  line-height: 1;
  color: var(--c-yellow1);
}

#cadastrocupom.cc-css-island .btn.barra-participe-cta:hover span,
#cadastrocupom.cc-css-island .btn.barra-participe-cta:focus-visible span {
  color: var(--c-white);
}

#cadastrocupom.cc-css-island .btn.barra-participe-cta i {
  position: relative;
  z-index: 1;
  flex-shrink: 0;
  font-size: 1.4rem;
  line-height: 1;
  transition: transform 0.3s ease, color 0.3s ease;
  color: var(--c-yellow1);
}

#cadastrocupom.cc-css-island .btn.barra-participe-cta:hover i,
#cadastrocupom.cc-css-island .btn.barra-participe-cta:focus-visible i {
  transform: translateX(4px);
  color: var(--c-white);
}

@media (max-width: 991px) {
  #cadastrocupom.cc-css-island .btn.barra-participe-cta {
    font-size: 1.6rem;
    padding: 1.2rem 1.8rem;
  }
}

#cadastrocupom.cc-css-island .cc-fluxo-video-wrap {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #0a0a0a;
  border-radius: 20px;
  overflow: hidden;
}

#cadastrocupom.cc-css-island .cc-fluxo-video-wrap video {
  position: relative;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#cadastrocupom.cc-css-island .cc-fluxo-scan-frame {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

#cadastrocupom.cc-css-island .cc-fluxo-scan-frame-inner {
  width: min(256px, 72%);
  max-width: 100%;
  aspect-ratio: 1;
  height: auto;
  border: 3px solid rgba(255, 255, 255, 0.92);
  border-radius: 8px;
  position: relative;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.15);
}

#cadastrocupom.cc-css-island .cc-fluxo-corner {
  position: absolute;
  width: 32px;
  height: 32px;
  border-color: #fff;
  border-style: solid;
}

#cadastrocupom.cc-css-island .cc-fluxo-corner--tl {
  top: 0;
  left: 0;
  border-width: 4px 0 0 4px;
}

#cadastrocupom.cc-css-island .cc-fluxo-corner--tr {
  top: 0;
  right: 0;
  border-width: 4px 4px 0 0;
}

#cadastrocupom.cc-css-island .cc-fluxo-corner--bl {
  bottom: 0;
  left: 0;
  border-width: 0 0 4px 4px;
}

#cadastrocupom.cc-css-island .cc-fluxo-corner--br {
  bottom: 0;
  right: 0;
  border-width: 0 4px 4px 0;
}

#cadastrocupom.cc-css-island .cc-fluxo-success-overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  background: rgb(0 133 38 / 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  animation: cc-fluxo-fadeIn 0.35s ease;
}

#cadastrocupom.cc-css-island .cc-fluxo-success-overlay__text {
  text-align: center;
  color: #fff;
}

#cadastrocupom.cc-css-island .cc-fluxo-success-overlay__text p {
  margin: 0;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.35;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-zone {
  border: 2px dashed var(--c-black);
  border-radius: 8px;
  padding: 48px 16px;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s ease;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-zone:hover {
  border-color: var(--c-black);
  background: #f8da48;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-zone.is-err {
  border-color: #dc2626;
  background: #fef2f2;
}

#cadastrocupom.cc-css-island .cc-fluxo-field--cupom-foto {
  margin-top: 28px;
}

#cadastrocupom.cc-css-island .cc-fluxo-cupom-foto-hint {
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--c-black);
  opacity: 0.9;
}

#cadastrocupom.cc-css-island .cc-fluxo-dados-upload-with-file {
  padding: 8px 0 0;
}

#cadastrocupom.cc-css-island .cc-fluxo-dados-upload-preview-img {
  margin-bottom: 16px;
}

#cadastrocupom.cc-css-island .cc-fluxo-dados-upload-filename {
  margin: 0 0 16px;
  font-size: 17px;
  font-weight: 600;
  color: var(--c-black);
  word-break: break-word;
}

#cadastrocupom.cc-css-island .cc-fluxo-dados-upload-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 8px;
}

#cadastrocupom.cc-css-island .cc-fluxo-dados-upload-actions .btn {
  margin: 0;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-zone img {
  max-height: 384px;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  border-radius: 8px;
  display: block;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-zone p {
  margin: 0;
  color: var(--c-black);
  text-align: center;
  margin-bottom: 3rem;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-hint {
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 8px !important;
  line-height: 1.35;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-sub {
  opacity: 0.8;
  font-size: 17px;
  line-height: 1.45;
}

#cadastrocupom.cc-css-island .cc-fluxo-alert {
  margin-top: 24px;
  padding: 16px;
  background: #fee2e2;
  border: 1px solid #f87171;
  border-radius: 8px;
  display: flex;
  align-items: flex-start;
  /* align-items: flex-end; */
  gap: 12px;
  color: #991b1b;
  font-size: 16px;
  line-height: 1.45;
  animation: cc-fluxo-shake 0.4s ease;
  align-content: center;
  position: relative;
}

#cadastrocupom.cc-css-island .cc-fluxo-alert p {
  position: relative;
  font-size: 1.6rem!important;
  margin-bottom: 0rem!important;
  top: 4px;
}
@media (max-width: 991px) {
  #cadastrocupom.cc-css-island .cc-fluxo-alert p {
    top: inherit;
  }
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas {
  margin-top: 24px;
  padding: 16px;
  background: var(--cc-surface);
  border-radius: 8px;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas h3 {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 900;
  color: var(--c-black);
  line-height: 1.35;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas ul {
  margin: 0;
  padding-left: 20px;
  color: var(--c-black);
  opacity: 0.85;
  font-size: 16px;
  line-height: 1.5;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas li {
  margin-bottom: 4px;
}

/* Bloco “Dicas para melhor leitura” (QR): fundo cinza, sem marcadores, ícone de alerta */
#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura {
  background: var(--c-yellow2);
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__title {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0 0 0px;
  /* margin: 0 0 12px; */
  justify-content: center;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__title-icon {
  flex-shrink: 0;
  margin-top: -1px;
  font-size: 1em;
  line-height: 1.3;
  color: #000000;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__list li {
  margin-bottom: 0px;
  padding-left: 0;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__list li:last-child {
  margin-bottom: 0;
}

/* Dicas do passo QR: bloco sem <ul> (evita marcadores órfãos se o CSS do fluxo falhar ao carregar) */
#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__items {
  margin: 0;
  padding: 0;
  text-align: center;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__line {
  margin: 0 0 5px;
  font-size: 16px;
  line-height: 1.1;
  color: var(--c-black);
  text-align: center;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__line:last-child {
  margin-bottom: 0;
}

#cadastrocupom.cc-css-island .cc-fluxo-dicas--leitura .cc-fluxo-dicas__line--muted {
  opacity: 0.78;
}

/* Chave de acesso */
#cadastrocupom.cc-css-island .cc-fluxo-label {
  display: block;
  color: var(--c-black);
  font-weight: 600;
  font-size: 13px;
  line-height: 1;
  margin-bottom: 8px;
  text-transform: uppercase;
  text-align: left;
}
#cc-fluxo-form-chave .cc-fluxo-label {
  text-align: center;
}

#cc-fluxo-form-chave .float-placeholder {
  display: none!important;
}

/* Padrão de campo = #cadastro.cadastro-pessoal #frm-cadastro .form-control (circleform.css) */
#cadastrocupom.cc-css-island .cc-fluxo-input-chave,
#cadastrocupom.cc-css-island .cc-fluxo-field input,
#cadastrocupom.cc-css-island .cc-fluxo-field select {
  width: 100%;
  box-sizing: border-box;
  height: 50px;
  padding: 1.3rem 2rem 1rem 2rem;
  border-radius: 0.4rem !important;
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1;
  text-transform: none;
  color: #ffffff !important;
  -webkit-text-fill-color: rgba(255, 255, 255, 0.86) !important;
  background: #0000b2 !important;
  border: 1px solid #0823b3 !important;
  outline: none;
  transition: all 0.3s ease;
  margin: 0px 0px 6px 0px!important;
}

#cadastrocupom.cc-css-island .cc-fluxo-input-chave {
  text-align: center;
  letter-spacing: 0.05em;
}

/* Chave de acesso: mesmo layout do cadastro pessoal (campo azul) */
#cadastrocupom.cc-css-island #cc-fluxo-chave-input {
  height: 50px;
  padding: 1.3rem 2rem 1rem 2rem;
  margin: 15px 0 6px 0;
  border-radius: 0.4rem !important;
  border: 1px solid #0823b3 !important;
  background: #0000b2 !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffffdb !important;
  line-height: 1;
  font-size: 1.5rem;
  font-family: var(--font-sans);
  font-weight: 400;
  text-align: left;
  letter-spacing: normal;
  box-shadow: none !important;
}

#cadastrocupom.cc-css-island #cc-fluxo-chave-input:hover,
#cadastrocupom.cc-css-island #cc-fluxo-chave-input:active {
  background: #0000b2 !important;
  border: 1px solid #0823b3 !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffffdb !important;
  box-shadow: none !important;
  transform: none !important;
}

#cadastrocupom.cc-css-island #cc-fluxo-chave-input::placeholder,
#cadastrocupom.cc-css-island #cc-fluxo-chave-input::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 1);
  opacity: 1;
}

#cadastrocupom.cc-css-island #cc-fluxo-chave-input:focus:not(.is-invalid),
#cadastrocupom.cc-css-island #cc-fluxo-chave-input.is-valid {
  background: #0104bf !important;
  border: 1px solid #1035ea !important;
  border-bottom: 1px solid #fed300 !important;
  outline: none !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  box-shadow: none !important;
  transform: none !important;
}

#cadastrocupom.cc-css-island #cc-fluxo-chave-input:-webkit-autofill,
#cadastrocupom.cc-css-island #cc-fluxo-chave-input:-webkit-autofill:hover,
#cadastrocupom.cc-css-island #cc-fluxo-chave-input:-webkit-autofill:focus,
#cadastrocupom.cc-css-island #cc-fluxo-chave-input:-webkit-autofill:active {
  -webkit-text-fill-color: #ffffff !important;
  -webkit-box-shadow: 0 0 0 30px #0104bf inset !important;
  box-shadow: 0 0 0 30px #0104bf inset !important;
  border: 1px solid #1035ea !important;
  border-bottom: 1px solid #fed300 !important;
}

#cadastrocupom.cc-css-island .cc-fluxo-input-chave:focus:not(.is-invalid),
#cadastrocupom.cc-css-island .cc-fluxo-input-chave:not(:placeholder-shown):not(.is-invalid),
#cadastrocupom.cc-css-island .cc-fluxo-input-chave.is-valid,
#cadastrocupom.cc-css-island .cc-fluxo-field input:focus:not(.is-err),
#cadastrocupom.cc-css-island .cc-fluxo-field input:not(:placeholder-shown):not(.is-err),
#cadastrocupom.cc-css-island .cc-fluxo-field input.is-ok,
#cadastrocupom.cc-css-island .cc-fluxo-field select:focus,
#cadastrocupom.cc-css-island .cc-fluxo-field select:has(option:checked:not([value=""])) {
  background: #0104bf !important;
  border: 1px solid #1035ea !important;
  border-bottom: 1px solid #fed300 !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  opacity: 1!important;
}

#cadastrocupom.cc-css-island .cc-fluxo-field input:not(:placeholder-shown):not(.is-err),
#cadastrocupom.cc-css-island .cc-fluxo-field select:has(option:checked:not([value=""])) {
  opacity: 1!important;
}



#cadastrocupom.cc-css-island .cc-fluxo-input-chave:-webkit-autofill,
#cadastrocupom.cc-css-island .cc-fluxo-input-chave:-webkit-autofill:hover,
#cadastrocupom.cc-css-island .cc-fluxo-input-chave:-webkit-autofill:focus,
#cadastrocupom.cc-css-island .cc-fluxo-input-chave:-webkit-autofill:active,
#cadastrocupom.cc-css-island .cc-fluxo-field input:-webkit-autofill,
#cadastrocupom.cc-css-island .cc-fluxo-field input:-webkit-autofill:hover,
#cadastrocupom.cc-css-island .cc-fluxo-field input:-webkit-autofill:focus,
#cadastrocupom.cc-css-island .cc-fluxo-field input:-webkit-autofill:active {
  -webkit-text-fill-color: #ffffff !important;
  -webkit-box-shadow: 0 0 0 30px #0104bf inset !important;
  box-shadow: 0 0 0 30px #0104bf inset !important;
  border: 1px solid #1035ea !important;
  border-bottom: 1px solid #fed300 !important;
}

#cadastrocupom.cc-css-island .cc-fluxo-input-chave::placeholder,
#cadastrocupom.cc-css-island .cc-fluxo-field input::placeholder,
#cadastrocupom.cc-css-island .cc-fluxo-input-chave::-webkit-input-placeholder,
#cadastrocupom.cc-css-island .cc-fluxo-field input::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 1);
  opacity: 1;
}

#cadastrocupom.cc-css-island .cc-fluxo-input-chave.is-invalid {
  border-color: var(--c-yellow1) !important;
}

#cadastrocupom.cc-css-island .cc-fluxo-field input.is-err {
  /* border-color: var(--c-yellow1) !important; */
}

#cadastrocupom.cc-css-island .cc-fluxo-field input:disabled,
#cadastrocupom.cc-css-island .cc-fluxo-field select:disabled {
  opacity: 0.5;
  background: #ffffff !important;
}

/* CNPJ / cupom: somente leitura (valor vindo do fluxo) */
#cadastrocupom.cc-css-island .cc-fluxo-field input[readonly] {
  opacity: 0.92;
  cursor: not-allowed;
}

/* Mês e ano: bloqueados, mantendo o visual verde do campo */
#cadastrocupom.cc-css-island .cc-fluxo-field select#cc-fluxo-mes:disabled,
#cadastrocupom.cc-css-island .cc-fluxo-field select#cc-fluxo-ano:disabled {
  /* opacity: 0.5!important; */
  opacity: 1;
  cursor: not-allowed;
  background: #0104bf!important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}

#cadastrocupom.cc-css-island .cc-fluxo-label .cc-fluxo-label-note {
  display: block;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.35;
  margin-top: 6px;
  text-transform: none;
  letter-spacing: normal;
}

#cadastrocupom.cc-css-island .cc-fluxo-chave-meta {
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 16px;
  line-height: 1.4;
}

#cadastrocupom.cc-css-island .cc-fluxo-chave-meta span.ok {
  color: var(--c-green1);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 16px;
  font-weight: 600;
}

#cadastrocupom.cc-css-island .cc-fluxo-progress {
  margin-top: 8px;
  height: 8px;
  background: var(--c-white);
  border-radius: 9999px;
  overflow: hidden;
}

#cadastrocupom.cc-css-island .cc-fluxo-progress-bar {
  height: 100%;
  background: #00a51d;
  /* background: var(--cc-brand); */
  transition: width 0.3s ease;
}

#cadastrocupom.cc-css-island .cc-fluxo-progress-bar.is-valid {
  background: var(--c-green1);
}

/* Continuar: btn-white (desabilitado) /   (habilitado) — overload.css */
#cadastrocupom.cc-css-island .cc-fluxo-btn-continuar.btn {
  width: 100%;
  margin-top: 32px;
  font-size: 1.8rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--c-white);
  background: var(--c-blue1);
}

#cadastrocupom.cc-css-island .cc-fluxo-btn-continuar.btn:hover,
#cadastrocupom.cc-css-island .cc-fluxo-btn-continuar.btn:focus-visible,
#cadastrocupom.cc-css-island .cc-fluxo-btn-continuar.btn:active {
  color: var(--c-white)!important;
  filter: brightness(1.5)!important;
}

#cadastrocupom.cc-css-island .cc-fluxo-btn-continuar.btn:hover
#cadastrocupom.cc-css-island .cc-fluxo-btn-continuar.btn:active {
  color: var(--c-white)!important;
  filter: brightness(1.5)!important;
}

#cadastrocupom.cc-css-island .cc-fluxo-btn-continuar.btn:disabled {
  opacity: 0.45;
  color: var(--c-black);
}

#cadastrocupom.cc-css-island .cc-fluxo-exemplo {
  border: 2px dashed var(--c-black);
  border-radius: 8px;
  padding: 20px;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s ease;
  margin-top: 20px;

}

#cadastrocupom.cc-css-island .cc-fluxo-exemplo p {
  margin: 0;
  color: var(--c-black);
  font-size: 16px;
  line-height: 1.45;
}

#cadastrocupom.cc-css-island .cc-fluxo-exemplo .mono {
  text-align: center;
  letter-spacing: 0.04em;
  font-size: 13px;
  word-break: break-all;
  line-height: 1.4;
}

@media (min-width: 768px) {
  #cadastrocupom.cc-css-island .cc-fluxo-exemplo .mono {
    font-size: 15px;
  }
}

/* Formulário dados do cupom */
#cadastrocupom.cc-css-island .cc-fluxo-form-row--2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 24px;
  margin-bottom: 24px;
  align-items: start;
}

@media (max-width: 640px) {
  #cadastrocupom.cc-css-island .cc-fluxo-form-row--2 {
    grid-template-columns: 1fr;
  }
}

#cadastrocupom.cc-css-island .cc-fluxo-form-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

@media (max-width: 640px) {
  #cadastrocupom.cc-css-island .cc-fluxo-form-grid-3 {
    grid-template-columns: 1fr;
  }
}

#cadastrocupom.cc-css-island .cc-fluxo-field-hint {
  margin: 8px 0 0;
  font-size: 15px;
  line-height: 1.4;
  display: flex;
  align-items: center;
  gap: 6px;
}

#cadastrocupom.cc-css-island .cc-fluxo-field-hint.ok {
  color: #16a34a;
  font-weight: 600!important;
}

#cadastrocupom.cc-css-island .cc-fluxo-field-hint.err {
  color: var(--c-error2);
}

#cadastrocupom.cc-css-island .cc-fluxo-field-hint.err span {
  color: var(--c-error2);
}

#cadastrocupom.cc-css-island .cc-fluxo-optin {
  position: relative;
  padding-left: 32px;
  text-align: left;
}

#cadastrocupom.cc-css-island .cc-fluxo-optin.is-err {
  /* border-color: #ef4444; */
  /* background: #fef2f2; */
}

#cadastrocupom.cc-css-island .cc-fluxo-optin label {
  color: var(--c-black);
  cursor: pointer;
  display: block;
  padding-left: 0px;
  position: relative;
  font-size: 1.6rem;
}

/* Sem ícone de check: só cor do quadrado (card-bg → bluelight1) */
#cadastrocupom.cc-css-island .cc-fluxo-optin input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  position: absolute;
  left: 0;
  top: 3px;
  width: 20px;
  height: 20px;
  margin: 0;
  border: 2px solid rgb(0 0 0 / 0.22);
  border-radius: 4px;
  background: var(--cc-card-bg);
  cursor: pointer;
}

#cadastrocupom.cc-css-island .cc-fluxo-optin input[type="checkbox"]:checked {
  background: var(--c-blue1);
  border-color: var(--c-blue1);
}

#cadastrocupom.cc-css-island .cc-fluxo-optin input[type="checkbox"]:focus-visible {
  outline: 2px solid var(--cc-highlight);
  outline-offset: 2px;
}

#cadastrocupom.cc-css-island .cc-fluxo-submit.btn {
  width: 100%;
  margin-top: 24px;
  font-size: 1.8rem;
  font-weight: 700;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--c-white);
  background: var(--c-blue1);
}

#cadastrocupom.cc-css-island .cc-fluxo-submit.btn:hover,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn:focus-visible,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn:active {
  filter: brightness(1.5);
}

#cadastrocupom.cc-css-island .cc-fluxo-submit.btn span {
  color: var(--c-white);
}

#cadastrocupom.cc-css-island .cc-fluxo-submit .cc-fluxo-submit-loading {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

#cadastrocupom.cc-css-island .cc-fluxo-submit.btn.is-loading,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn.is-loading:hover,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn.is-loading:focus-visible,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn.is-loading:active {
  background: var(--c-blue1);
  color: var(--c-white);
  filter: none;
}

#cadastrocupom.cc-css-island .cc-fluxo-submit.btn span:disabled,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn span:disabled:hover,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn span:disabled:focus-visible,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn span:disabled:active,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn span:hover,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn span:focus-visible,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn span:active {
  color: var(--c-white);
  filter: brightness(1.5);
}

#cadastrocupom.cc-css-island .cc-fluxo-submit.btn:hover span,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn:focus-visible span,
#cadastrocupom.cc-css-island .cc-fluxo-submit.btn:active span{
  color: var(--c-white)!important;
  filter: brightness(1.5);
}

#cadastrocupom.cc-css-island .cc-fluxo-submit .cc-fluxo-spinner {
  width: 24px;
  height: 24px;
  animation: cc-fluxo-spin 0.8s linear infinite;
}

#cadastrocupom.cc-css-island .cc-fluxo-footnote {
  margin-top: 24px;
  padding: 16px;
  background: var(--c-yellow2);
  /* background: var(--cc-surface); */
  border-radius: 8px;
}

#cadastrocupom.cc-css-island .cc-fluxo-footnote p {
  margin: 0;
  font-size: 16px;
  line-height: 1.45;
  color: var(--c-black);
}

#cadastrocupom.cc-css-island .cc-fluxo-relative {
  position: relative;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-preview-wrap {
  position: relative;
  display: inline-block;
  max-width: 100%;
}

#cadastrocupom.cc-css-island .cc-fluxo-upload-preview-wrap .cc-fluxo-success-overlay {
  border-radius: 8px;
}
