/* ═══════════════════════════════════════════════════
   Eh iD – Loja Shortcode Styles
   Escopo: .ehid-loja-wrap — não vaza para o tema WP
═══════════════════════════════════════════════════ */
.ehid-loja-wrap *,
.ehid-loja-wrap *::before,
.ehid-loja-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }

.ehid-loja-wrap {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background: #0F0F0F;
  color: #F5F0E8;
  padding: 60px 24px;
  --gold: #C9A84C;
  --gold-light: #E8C87A;
  --bg0: #0A0A0A;
  --bg1: #0F0F0F;
  --cream: #F5F0E8;
  --muted: #888;
}

/* ── Grid principal ── */
.ehid-loja-grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 32px;
  max-width: 1024px;
  margin: 0 auto;
}
@media (max-width: 900px) { .ehid-loja-grid { grid-template-columns: 1fr; } }

/* ── Cabeçalho da seção ── */
.ehid-loja-head { text-align: center; margin-bottom: 48px; }
.ehid-loja-head .lh-label { font-size: 11px; letter-spacing: .15em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.ehid-loja-head h2 { font-family: 'Playfair Display', Georgia, serif; font-size: clamp(1.6rem, 4vw, 2.2rem); font-weight: 700; color: var(--cream); margin: 12px 0 8px; }
.ehid-loja-head p { color: var(--muted); font-size: 13px; }
.ehid-gold-line { width: 64px; height: 1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); margin: 8px auto; }
.ehid-gold-line-full { width: 100%; height: 1px; background: linear-gradient(90deg, transparent, rgba(201,168,76,.4), var(--gold), rgba(201,168,76,.4), transparent); margin-bottom: 0; }

/* ── Bloco config ── */
.ehid-config-block { margin-bottom: 28px; }
.ehid-block-label { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); font-weight: 600; display: block; margin-bottom: 12px; }

/* ── Botões de modelo ── */
.ehid-model-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ehid-model-btn {
  padding: 14px 16px; border-radius: 6px; border: 1px solid rgba(201,168,76,.25);
  background: rgba(255,255,255,.03); cursor: pointer; text-align: left;
  transition: all .2s; width: 100%;
}
.ehid-model-btn.active { border-color: var(--gold); background: rgba(201,168,76,.1); }
.ehid-model-btn .mb-name { display: block; font-weight: 700; font-size: 14px; color: #888; transition: color .2s; }
.ehid-model-btn.active .mb-name { color: var(--gold-light); }
.ehid-model-btn .mb-sub  { font-size: 12px; color: #555; }
.ehid-model-btn.active .mb-sub  { color: rgba(201,168,76,.6); }
.ehid-kit-note { font-size: 12px; color: #555; margin-top: 10px; line-height: 1.6; }

/* ── Quantidade ── */
.ehid-qty-row { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.ehid-qty-input {
  width: 110px; text-align: center; font-size: 22px; font-weight: 700;
  padding: 10px 14px; background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,76,.25); border-radius: 4px; color: var(--cream);
  font-family: inherit; outline: none; transition: border-color .2s;
}
.ehid-qty-input:focus { border-color: var(--gold); }
.ehid-qty-input::-webkit-inner-spin-button { opacity: .4; }
.ehid-price-box .pl { font-size: 12px; color: #666; margin-bottom: 2px; }
.ehid-price-box .pv { font-family: 'Playfair Display', Georgia, serif; font-size: 22px; font-weight: 700; }
.ehid-price-box.unit .pv { color: var(--gold); }
.ehid-price-box.sub  .pv { color: var(--cream); }
.ehid-faixas { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.ehid-faixa {
  padding: 4px 10px; border-radius: 4px; font-size: 11px;
  border: 1px solid rgba(201,168,76,.15); color: #555; background: transparent;
}
.ehid-faixa.active { border-color: var(--gold); color: var(--gold-light); background: rgba(201,168,76,.1); }
.ehid-prazo-note { font-size: 12px; color: #555; margin-top: 8px; }
.ehid-prazo-note span { color: var(--gold); }

/* ── Arte ── */
.ehid-textarea {
  width: 100%; padding: 10px 14px; background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,76,.25); border-radius: 4px; color: var(--cream);
  font-size: 14px; font-family: inherit; outline: none; resize: vertical; min-height: 80px;
  transition: border-color .2s;
}
.ehid-textarea:focus { border-color: var(--gold); }
.ehid-upload-label {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  border: 1px solid rgba(201,168,76,.25); border-radius: 4px;
  background: rgba(255,255,255,.03); cursor: pointer; margin-top: 10px;
  transition: border-color .2s;
}
.ehid-upload-label:hover { border-color: var(--gold); }
.ehid-upload-label span { font-size: 13px; color: #666; }
.ehid-upload-label.has-file span { color: var(--gold); }
.ehid-upload-note { font-size: 11px; color: #444; margin-top: 6px; }

/* ── Botão principal ── */
.ehid-btn-gold {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 32px; font-size: 12px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; background: linear-gradient(135deg, #C9A84C, #E8C87A, #C9A84C);
  background-size: 200% auto; color: #0A0A0A; border: none; border-radius: 3px;
  cursor: pointer; transition: all .3s; box-shadow: 0 0 30px rgba(201,168,76,.2);
  width: 100%;
}
.ehid-btn-gold:hover:not(:disabled) { background-position: right center; box-shadow: 0 0 50px rgba(201,168,76,.4); }
.ehid-btn-gold:disabled { background: #333; color: #666; cursor: not-allowed; box-shadow: none; }
.ehid-btn-back {
  padding: 12px 24px; border: 1px solid rgba(201,168,76,.25); color: #888;
  background: none; border-radius: 4px; cursor: pointer; font-size: 13px;
}

/* ── Carrinho ── */
.ehid-cart-wrap { display: flex; flex-direction: column; gap: 20px; }
.ehid-card {
  background: rgba(255,255,255,.03); border: 1px solid rgba(201,168,76,.2);
  border-radius: 8px; padding: 20px;
  transition: border-color .3s;
}
.ehid-card-title { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); font-weight: 700; margin-bottom: 16px; }
.ehid-card-title small { color: #555; font-size: 10px; text-transform: none; letter-spacing: 0; font-weight: 400; margin-left: 8px; }
.ehid-cart-empty { color: #555; font-size: 13px; text-align: center; padding: 20px 0; }
.ehid-cart-item { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 12px; border-bottom: 1px solid rgba(201,168,76,.1); margin-bottom: 12px; }
.ehid-cart-item-name { color: var(--cream); font-size: 14px; font-weight: 600; }
.ehid-cart-item-sub  { color: #666; font-size: 12px; }
.ehid-cart-item-sub2 { color: #444; font-size: 11px; }
.ehid-cart-item-total { color: var(--cream); font-weight: 700; font-size: 15px; text-align: right; }
.ehid-cart-remove { color: #555; font-size: 11px; background: none; border: none; cursor: pointer; margin-top: 4px; display: block; }
.ehid-subtotal-row { display: flex; justify-content: space-between; padding-top: 4px; }
.ehid-subtotal-row span:first-child { color: #888; font-size: 13px; }
.ehid-subtotal-row span:last-child  { color: var(--cream); font-weight: 700; }

/* ── Frete ── */
.ehid-frete-row { display: flex; gap: 8px; }
.ehid-frete-input {
  flex: 1; padding: 10px 14px; background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,76,.25); border-radius: 4px; color: var(--cream);
  font-size: 14px; font-family: inherit; outline: none; transition: border-color .2s;
}
.ehid-frete-input:focus { border-color: var(--gold); }
.ehid-frete-btn {
  padding: 10px 14px; background: rgba(201,168,76,.15); border: 1px solid rgba(201,168,76,.4);
  color: var(--gold); border-radius: 4px; cursor: pointer; font-size: 12px;
  font-weight: 600; white-space: nowrap; transition: all .2s;
}
.ehid-frete-btn:hover:not(:disabled) { background: rgba(201,168,76,.25); }
.ehid-frete-btn:disabled { opacity: .5; cursor: wait; }
.ehid-frete-error { color: #e57373; font-size: 12px; margin-top: 8px; display: none; }
.ehid-frete-opcoes { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.ehid-frete-op {
  display: flex; align-items: center; gap: 10px; padding: 10px 12px;
  border: 1px solid rgba(201,168,76,.2); border-radius: 4px; cursor: pointer;
  transition: all .2s;
}
.ehid-frete-op:hover, .ehid-frete-op.selected { border-color: var(--gold); background: rgba(201,168,76,.06); }
.ehid-frete-op input[type=radio] { accent-color: var(--gold); }
.ehid-frete-op .fo-name  { color: var(--cream); font-size: 13px; font-weight: 600; flex: 1; }
.ehid-frete-op .fo-prazo { color: #666; font-size: 11px; }
.ehid-frete-op .fo-price { color: var(--gold); font-weight: 700; font-size: 14px; }

/* ── Total ── */
.ehid-total-row { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; border-top: 1px solid rgba(201,168,76,.15); margin-bottom: 16px; }
.ehid-total-label { color: var(--cream); font-weight: 700; font-size: 15px; }
.ehid-total-val   { font-family: 'Playfair Display', Georgia, serif; color: var(--gold); font-size: 22px; font-weight: 700; }
.ehid-frete-hint  { color: #555; font-size: 11px; text-align: center; margin-top: 8px; }

/* ── Seção dados ── */
.ehid-dados-wrap { max-width: 1024px; margin: 48px auto 0; padding-top: 48px; border-top: 1px solid rgba(201,168,76,.2); display: none; }
.ehid-dados-wrap.visible { display: block; }
.ehid-dados-wrap h3 { font-family: 'Playfair Display', Georgia, serif; color: var(--cream); font-size: 22px; margin-bottom: 24px; }
.ehid-dados-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .ehid-dados-grid { grid-template-columns: 1fr; } }
.ehid-dados-field { display: flex; flex-direction: column; gap: 6px; }
.ehid-dados-field.span2 { grid-column: span 2; }
@media (max-width: 600px) { .ehid-dados-field.span2 { grid-column: span 1; } }
.ehid-input-label { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.ehid-input {
  width: 100%; padding: 10px 14px; background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,76,.25); border-radius: 4px; color: var(--cream);
  font-size: 14px; font-family: inherit; outline: none; transition: border-color .2s;
}
.ehid-input:focus { border-color: var(--gold); }

/* ── Resumo ── */
.ehid-resumo-card { margin-top: 24px; }
.ehid-resumo-row  { display: flex; justify-content: space-between; margin-bottom: 8px; }
.ehid-resumo-row span:first-child { color: #888; font-size: 13px; }
.ehid-resumo-row span:last-child  { color: var(--cream); font-size: 13px; }
.ehid-resumo-total { display: flex; justify-content: space-between; padding-top: 10px; border-top: 1px solid rgba(201,168,76,.15); margin-top: 4px; }
.ehid-resumo-total span:first-child { color: var(--cream); font-weight: 700; }
.ehid-resumo-total span:last-child  { font-family: 'Playfair Display', Georgia, serif; color: var(--gold); font-size: 22px; font-weight: 700; }
.ehid-resumo-prazo { color: #555; font-size: 11px; margin-top: 10px; }
.ehid-resumo-prazo span { color: var(--gold); }
.ehid-checkout-actions { display: flex; gap: 12px; margin-top: 20px; flex-wrap: wrap; align-items: center; }
.ehid-pag-note { font-size: 11px; color: #444; margin-top: 10px; }

/* ── Cupom ── */
.ehid-cupom-wrap { margin-top: 16px; }
.ehid-cupom-row { display: flex; gap: 8px; }
.ehid-cupom-input {
  flex: 1; padding: 10px 14px; background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,76,.25); border-radius: 4px; color: var(--cream);
  font-size: 14px; font-family: inherit; outline: none; transition: border-color .2s;
  text-transform: uppercase; letter-spacing: .08em;
}
.ehid-cupom-input:focus { border-color: var(--gold); }
.ehid-cupom-btn {
  padding: 10px 14px; background: rgba(201,168,76,.15); border: 1px solid rgba(201,168,76,.4);
  color: var(--gold); border-radius: 4px; cursor: pointer; font-size: 12px;
  font-weight: 600; white-space: nowrap; transition: all .2s;
}
.ehid-cupom-btn:hover:not(:disabled) { background: rgba(201,168,76,.25); }
.ehid-cupom-btn:disabled { opacity: .5; cursor: wait; }
.ehid-cupom-ok  { color: #4caf50; font-size: 12px; margin-top: 8px; font-weight: 600; }
.ehid-cupom-err { color: #e57373; font-size: 12px; margin-top: 8px; }
.ehid-cupom-applied {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; background: rgba(76,175,80,.08); border: 1px solid rgba(76,175,80,.3);
  border-radius: 4px; margin-top: 8px;
}
.ehid-cupom-applied span { color: #4caf50; font-size: 13px; font-weight: 600; }
.ehid-cupom-remove { color: #555; background: none; border: none; cursor: pointer; font-size: 18px; line-height: 1; }
.ehid-desconto-row { display: flex; justify-content: space-between; margin-bottom: 8px; }
.ehid-desconto-row span:first-child { color: #4caf50; font-size: 13px; }
.ehid-desconto-row span:last-child  { color: #4caf50; font-size: 13px; font-weight: 600; }

/* ── Spinner ── */
@keyframes ehid-spin { to { transform: rotate(360deg); } }
.ehid-spinner { display: inline-block; width: 16px; height: 16px; border: 2px solid #0A0A0A; border-top-color: transparent; border-radius: 50%; animation: ehid-spin .7s linear infinite; }

/* ── Toast ── */
.ehid-toast {
  position: fixed; bottom: 24px; right: 24px; padding: 14px 20px;
  background: #1a1a1a; border: 1px solid var(--gold); color: var(--cream);
  font-size: 13px; border-radius: 6px; z-index: 99999;
  transform: translateY(80px); opacity: 0; transition: all .4s; max-width: 320px;
}
.ehid-toast.show { transform: translateY(0); opacity: 1; }
