/* Layout geral */
.nlc-wrapper {
    margin: 30px 0;
    padding: 20px;
    border: 1px solid #eee;
    border-radius: 6px;
    background: #fff;
}

.nlc-title {
    font-size: 22px;
    margin-bottom: 18px;
}

.nlc-columns {
    display: flex;
    gap: 20px;
    align-items: flex-start;
}

/* Colunas 40/60 */
.nlc-controls {
    flex: 0 0 40%;
    max-width: 40%;
}

.nlc-preview-column {
    flex: 0 0 60%;
    max-width: 60%;
}

@media (max-width: 768px) {
    .nlc-columns {
        flex-direction: column;
    }
    .nlc-controls,
    .nlc-preview-column {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

/* Campos */
.nlc-field {
    margin-bottom: 18px;
}

.nlc-label {
    display: block;
    background: #ff5c2a;
    color: #ffffff;
    padding: 8px 12px;
    border-radius: 4px;
    margin-bottom: 6px;
    font-weight: 600;
}

.nlc-field input[type="text"],
.nlc-field input[type="number"] {
    width: 100%;
    padding: 6px 8px;
    border: 1px solid #ddd;
    border-radius: 3px;
}

.nlc-field small {
    display: block;
    margin-top: 4px;
    color: #777;
}

/* Swatches cores */
.nlc-swatch-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.nlc-swatch {
    display: inline-flex;
    align-items: center;
    border: 1px solid #ddd;
    border-radius: 3px;
    padding: 4px 6px;
    cursor: pointer;
    background: #fff;
}

.nlc-swatch input {
    display: none;
}

.nlc-swatch-color {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 1px solid #ccc;
    margin-right: 6px;
}

.nlc-swatch-label {
    font-size: 12px;
}

/* Estado selecionado */
.nlc-swatch input:checked + .nlc-swatch-color,
.nlc-font-option input:checked + span {
    box-shadow: 0 0 0 2px #ff5c2a inset;
}

/* Fontes */
.nlc-font-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.nlc-font-option {
    border: 1px solid #ddd;
    border-radius: 3px;
    padding: 4px 8px;
    cursor: pointer;
    background: #fff;
    display: inline-flex;
    align-items: center;
}

.nlc-font-option input {
    display: none;
}

/* Fundos */
.nlc-bg-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.nlc-bg-option {
    border: 1px solid #ddd;
    border-radius: 3px;
    padding: 3px;
    cursor: pointer;
    background: #fff;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    font-size: 11px;
}

.nlc-bg-option input {
    display: none;
}

.nlc-bg-thumb {
    width: 80px;
    height: 60px;
    background-size: cover;
    background-position: center;
    border-radius: 3px;
    margin-bottom: 3px;
}

/* Preview */
.nlc-preview-wrapper {
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 0 0 8px rgba(0,0,0,0.08);
}

.nlc-preview-bg {
    position: relative;
    background-size: cover;
    background-position: center;
    min-height: 520px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.nlc-text-container {
    text-align: center;
}

#nlc_text_preview {
    font-size: 46px;
}

/* Medidas */
.nlc-measures {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,0.6);
    color: #fff;
    padding: 4px 8px;
    border-radius: 3px;
    font-size: 12px;
}

.nlc-measures-top {
    top: 10%;
}

.nlc-measures-bottom {
    bottom: 10%;
}

.nlc-note {
    font-size: 11px;
    margin-top: 6px;
    color: #777;
}

/* Preço estimado */
.nlc-price-estimate {
    margin-top: 10px;
    padding: 10px 20px;
    background: #c8e8b6;
    border-radius: 28px;
    text-align: center;
    font-size: 14px;
    color: #ffffff;
}

.nlc-price-estimate strong {
    font-weight: 600;
    margin-right: 4px;
}


/* Cores dinâmicas (configuráveis no admin) */
.nlc-wrapper .nlc-label{
    background: var(--nlc-label-bg, #ff5a2a) !important;
    color: var(--nlc-label-color, #ffffff) !important;
}
.nlc-wrapper .nlc-price-estimate{
    background: var(--nlc-price-bg, #cfeec0) !important;
    color: var(--nlc-price-color, #ffffff) !important;
}


.nlc-note{ text-align:center !important; }

/* Valor estimado: título via ::before (sem label) */
.nlc-field-estimate .nlc-price-estimate{
    position: relative;
    padding-top: 28px; /* espaço para o título */
    text-align: center;
}
.nlc-field-estimate .nlc-price-estimate::before{
    content: "Valor estimado do letreiro";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.2;
    opacity: .95;
    color: inherit; /* usa a mesma cor do texto do preço */
}

.nlc-price-estimate strong{ color: inherit !important; }
.nlc-price-estimate .nlc-price-currency, .nlc-price-estimate #nlc_price_estimate{ color: inherit !important; }


/* Refinos visuais: Valor estimado (mais centralizado e com menos "área verde") */
.nlc-field-estimate .nlc-price-estimate{
    max-width: 520px;
    margin: 14px auto 0 auto;
    padding: 18px 16px 14px 16px; /* reduz altura, mantém respiro */
    border-radius: 18px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    line-height: 1.1;
}

.nlc-field-estimate .nlc-price-estimate::before{
    position: static;         /* tira do absoluto para centralizar perfeito */
    display: block;
    margin: 0;
    padding: 0;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.2;
    opacity: .95;
}

/* Linha do preço (R$ + valor) centralizada e consistente */
.nlc-field-estimate .nlc-price-estimate .nlc-price-currency,
.nlc-field-estimate .nlc-price-estimate #nlc_price_estimate{
    font-size: 16px;
    font-weight: 700;
    line-height: 1.2;
}



/* Correção: manter 'R$' e valor na mesma linha */
.nlc-field-estimate .nlc-price-row{
    display: inline-flex;
    align-items: baseline;
    justify-content: center;
    gap: 6px;
    width: 100%;
}

/* ================================
   JG Produto Neon — Minimalista Premium
   (somente visual / sem mexer em lógica)
=================================== */

.nlc-wrapper{
  --nlc-radius: 14px;
  --nlc-soft-border: rgba(0,0,0,.08);
  --nlc-soft-shadow: 0 10px 28px rgba(0,0,0,.06);
  --nlc-focus: rgba(0,0,0,.12);
}

.nlc-columns{
  gap: 26px !important;
  align-items: flex-start !important;
}

.nlc-field{
  background: #fff !important;
  border: 1px solid var(--nlc-soft-border) !important;
  border-radius: var(--nlc-radius) !important;
  padding: 14px 14px 16px 14px !important;
  box-shadow: 0 2px 10px rgba(0,0,0,.03) !important;
  margin-bottom: 14px !important;
}

.nlc-label{
  border-radius: 10px !important;
  padding: 10px 12px !important;
  font-weight: 700 !important;
  letter-spacing: .2px !important;
  margin: 0 0 12px 0 !important;
}

.nlc-field input[type="text"],
.nlc-field input[type="number"],
.nlc-field select,
.nlc-field textarea{
  width: 100% !important;
  height: 46px !important;
  border-radius: 12px !important;
  border: 1px solid var(--nlc-soft-border) !important;
  background: #fff !important;
  padding: 0 14px !important;
  box-shadow: none !important;
  outline: none !important;
  transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease;
}

.nlc-field textarea{
  height: auto !important;
  padding: 12px 14px !important;
  min-height: 100px !important;
}

.nlc-field input:focus,
.nlc-field select:focus,
.nlc-field textarea:focus{
  border-color: var(--nlc-focus) !important;
  box-shadow: 0 0 0 4px rgba(0,0,0,.06) !important;
}

.nlc-help,
.nlc-field small,
.nlc-field .description{
  color: rgba(0,0,0,.55) !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  margin-top: 8px !important;
}

.nlc-options{
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

.nlc-options label{
  border: 1px solid var(--nlc-soft-border) !important;
  border-radius: 999px !important;
  padding: 9px 12px !important;
  background: #fff !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

.nlc-options label:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0,0,0,.06) !important;
}

.nlc-options input:checked + span,
.nlc-options label.is-active{
  font-weight: 700 !important;
}

.nlc-color-dot{
  width: 14px !important;
  height: 14px !important;
  border-radius: 50% !important;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.85), 0 3px 10px rgba(0,0,0,.10) !important;
}

.nlc-preview-bg{
  border-radius: 16px !important;
  overflow: hidden !important;
  border: 1px solid var(--nlc-soft-border) !important;
  box-shadow: var(--nlc-soft-shadow) !important;
}

.nlc-measure{
  border-radius: 10px !important;
  padding: 8px 10px !important;
  background: rgba(0,0,0,.55) !important;
  backdrop-filter: blur(6px);
}

.nlc-field-estimate{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.nlc-field-estimate .nlc-price-estimate{
  max-width: 520px !important;
  margin: 14px auto 0 auto !important;
  border-radius: 18px !important;
  padding: 18px 18px 16px 18px !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  box-shadow: 0 10px 28px rgba(0,0,0,.06) !important;
}

.nlc-field-estimate .nlc-price-estimate::before{
  font-size: 13px !important;
  letter-spacing: .2px !important;
  opacity: .95 !important;
}

.nlc-field-estimate .nlc-price-row{
  margin-top: 2px !important;
}

.nlc-note{
  text-align: center !important;
  color: rgba(0,0,0,.55) !important;
  font-size: 12px !important;
}

@media (max-width: 900px){
  .nlc-columns{
    gap: 18px !important;
  }
  .nlc-field{
    padding: 12px 12px 14px 12px !important;
  }
}

/* Oculta o preço padrão do WooCommerce apenas em produtos Neon */
body.single-product.nlc-neon-enabled .single-product-summary .price,
body.single-product.nlc-neon-enabled .summary .price{
  display: none !important;
}



/* Slot para quantidade + botão comprar (abaixo do preço estimado) */
.nlc-addtocart-slot{
    display: flex;
    gap: 12px;
    align-items: center;
    justify-content: center;
    margin-top: 14px;
}

.nlc-addtocart-slot .quantity{
    margin: 0 !important;
}

.nlc-addtocart-slot .single_add_to_cart_button{
    margin: 0 !important;
    width: auto;
}

@media (max-width: 768px){
    .nlc-addtocart-slot{
        flex-wrap: wrap;
    }
    .nlc-addtocart-slot .single_add_to_cart_button{
        width: 100%;
    }
}


/* Nota de limite de caracteres */
.nlc-maxchars-note{display:block;margin-top:6px;opacity:.85;}
