/* =========================
   Ajustes recomendados pelo review — modal detalhe do produto
   - elimina scroll horizontal
   - garante filhos não estourarem largura
   - polimentos de header, price, tamanhos, accordion e imagem
   ========================= */

/* 1) mata scroll horizontal do conteúdo do modal */
#lojaDetModal .loja-det-body{
  overflow-y: auto;
  overflow-x: hidden;
}

/* evita qualquer filho estourar largura */
#lojaDetModal .loja-det-body *{
  max-width: 100%;
  box-sizing: border-box;
}

/* reforço: quando é grid/coluna, permite que elementos encolham */
#lojaDetModal .loja-det-grid,
#lojaDetModal .loja-det-media,
#lojaDetModal .loja-det-buy{
  min-width: 0;
}

/* 2) sticky no desktop (acompanha rolagem do modal) */
@media (min-width: 901px){
  #lojaDetModal .loja-det-buy{
    position: sticky;
    top: 74px; /* abaixo do header do modal */
  }
}

@media (max-width: 900px){
  #lojaDetModal .loja-det-buy{ position: relative; top: 0; }
}

/* 3) hierarquia do preço */
#lojaDetModal .loja-label{
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .75;
  font-weight: 800;
}
#lojaDetModal .loja-det-price-line{ display:flex; align-items:baseline; gap:8px; }
#lojaDetModal .price-value{ font-size: 28px; font-weight: 800; color: #0f172a; }
#lojaDetModal .price-value .currency{ font-size: 14px; font-weight:700; opacity:.75; margin-right:2px; }

/* compat: classes geradas pelo JS atual */
.loja-price-curr{ font-size:14px; font-weight:700; opacity:.78; margin-right:8px; vertical-align: baseline; }
.loja-price-amt{ font-size:26px; font-weight:800; color:#0f172a; vertical-align: baseline; }
.loja-price-amt sup{ font-size:12px; margin-left:4px; }

/* 4) tamanhos — compactos e mais premium */
#lojaDetModal .loja-det-sizes{ padding-top:6px; }
#lojaDetModal .loja-det-sizes .loja-size-list{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.loja-size-pill, #lojaDetModal .loja-size-btn{
  height: 36px;
  padding: 0 14px;
  border-radius: 10px;
  border: 1px solid rgba(15,23,42,0.12);
  background: #fff;
  font-weight: 700;
  color: #0f172a;
  transition: transform .08s ease, box-shadow .12s ease, border-color .12s ease;
  display:inline-flex; align-items:center; justify-content:center;
}
.loja-size-pill:hover, #lojaDetModal .loja-size-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(2,6,23,0.08);
  border-color: rgba(29,78,216,0.35);
}
.loja-size-pill.is-on, #lojaDetModal .loja-size-btn.is-active{
  background: rgba(29,78,216,0.10);
  border-color: rgba(29,78,216,0.55);
  color: #1d4ed8;
}

/* 5) header / fechar (botão) */
#btnLojaDetFechar, .loja-det-close{
  width: 36px; height: 36px; border-radius: 12px;
  border: 1px solid rgba(15,23,42,0.10);
  background: rgba(255,255,255,0.9);
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer;
}
#btnLojaDetFechar:hover, .loja-det-close:hover{
  box-shadow: 0 10px 22px rgba(2,6,23,0.12);
  transform: translateY(-1px);
}

/* adiciona separador sutil abaixo do header */
#lojaDetModal .loja-det-head{ border-bottom: 1px solid rgba(15,23,42,0.04); }

/* 6) accordion premium + prevenção de overflow-x no conteúdo */
#lojaDetModal .loja-det-accordion{ border-radius: 14px; overflow: hidden; }
#lojaDetModal .loja-acc-item{ padding: 18px 18px; font-weight:800; }
#lojaDetModal .loja-acc-item .acc-ico{ transition: transform .18s ease, color .12s ease; }
#lojaDetModal .loja-acc-panel{ padding: 0 18px 18px 18px; line-height:1.6; }
#lojaDetModal .loja-acc-panel.is-open{ background: #fbfdff; }

#lojaDetModal .loja-det-desc, #lojaDetModal .loja-det-desc *{
  overflow-x: hidden;
  word-break: break-word;
}

/* 7) imagem: bloco substituido abaixo pela nova galeria */

/* Mobile bar */
.loja-det-mobilebar{ position:fixed; left:0; right:0; bottom:0; background:#fff; border-top:1px solid #e2e8f0; padding:10px 14px; display:none; align-items:center; gap:12px; z-index:99; box-shadow:0 -6px 24px rgba(15,23,42,.12); }
.loja-det-mobilebar.is-on{ display:flex; }
.loja-det-mobile-price{ font-weight:800; color:#0f172a; font-size:18px; }
@media (min-width:961px){ .loja-det-mobilebar{ display:none!important; } }
@media (max-width:960px){ .loja-det-buy{ position:relative; top:0; box-shadow:0 8px 20px rgba(15,23,42,.08); } .loja-det-inner{ padding-bottom:32px; } }

/* ===== LOJA: tamanhos ===== */
.loja-size-wrap{ border:1px dashed #cbd5e1; border-radius:14px; padding:12px; background:#f8fafc; margin:14px 0; display:flex; flex-direction:column; gap:10px; }
.loja-size-head{ display:flex; flex-direction:column; gap:10px; }
.loja-size-chips{ display:flex; gap:8px; flex-wrap:wrap; }
.loja-size-chip{ display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; border:1px solid #e2e8f0; background:#fff; font-weight:800; color:#0f172a; cursor:pointer; }
.loja-size-chip input{ accent-color:#1d4ed8; }
.loja-size-chip span{ line-height:1; }

.loja-det-sizes{ display:flex; flex-direction:column; gap:8px; }
.loja-size-list{ display:flex; gap:8px; flex-wrap:wrap; }
.loja-size-pill{ border:1px solid #cbd5e1; background:#fff; border-radius:10px; padding:6px 12px; font-weight:800; color:#0f172a; cursor:pointer; transition:all .12s ease; }
.loja-size-pill.is-on{ border-color:#1d4ed8; background:#e0edff; color:#0b3a9b; }

/* ===== LOJA: editor de variações ===== */
.loja-var-wrap{ border:1px dashed #cbd5e1; border-radius:14px; padding:12px; background:#f8fafc; }
.loja-var-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.loja-var-switch{ display:flex; gap:10px; align-items:center; font-weight:800; color:#0f172a; }
.loja-var-list{ margin-top:10px; display:flex; flex-direction:column; gap:10px; }

.loja-var-row{
  border:1px solid #e6e9ef;
  background:#fff;
  border-radius:14px;
  padding:10px;
  display:grid;
  grid-template-columns: 1.2fr .55fr .6fr 1fr auto;
  gap:10px;
  align-items:center;
}
@media (max-width:860px){ .loja-var-row{ grid-template-columns:1fr; } }

.loja-var-img{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.loja-var-preview{
  width:64px; height:48px;
  border-radius:10px;
  border:1px solid #e6e9ef;
  overflow:hidden;
  background:#fff;
  display:none;
}
.loja-var-preview.is-on{ display:block; }
.loja-var-preview img{ width:100%; height:100%; object-fit:cover; display:block; }
#listaEPIs .table-epi thead th:nth-child(7),
#listaEPIs .table-epi tbody td:nth-child(7) {
  width: 8%;
  text-align: right;
  padding-right: 12px;
}

/* Listras e hover */
#listaEPIs .table-epi tbody tr:nth-child(even) {
  background: #fcfdff;
}

#listaEPIs .table-epi tbody tr:hover {
  background: #f9fbff;
}








/* =========================
   LOJA (vitrine + carrinho + conferência)
   ========================= */

.store-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin: 10px 0 14px;
}
.store-subtitle{ margin:6px 0 0; color:#64748b; font-size:13px; }

.store-hero{
  display:grid;
  grid-template-columns: 1.3fr 1fr;
  gap:12px;
  margin: 12px 0 16px;
}
@media (max-width: 980px){
  .store-hero{ grid-template-columns: 1fr; }
}
.store-hero-title{ margin:6px 0 4px; font-size:20px; color:#0f172a; }
.store-hero-desc{ margin:0; color:#475569; line-height:1.45; font-size:14px; }
.store-hero-steps{ display:flex; flex-direction:column; gap:8px; margin-top:10px; }
.store-step{
  display:flex;
  gap:10px;
  padding:10px;
  border:1px dashed #d5dbe6;
  border-radius:12px;
  background:#f8fafc;
}
.store-step-number{
  width:28px; height:28px;
  border-radius:999px;
  background:#1d4ed8;
  color:#fff;
  font-weight:800;
  display:flex; align-items:center; justify-content:center;
}
.store-step-title{ font-weight:800; color:#0f172a; }
.store-step-text{ margin:4px 0 0; color:#475569; font-size:13px; line-height:1.35; }

.store-hero-right{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap:10px;
}
.store-kpi-card{
  border:1px solid #e6e9ef;
  border-radius:14px;
  background:#fff;
  box-shadow:0 12px 28px rgba(15,23,42,0.06);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.store-kpi-label{ color:#64748b; font-size:12px; text-transform:uppercase; letter-spacing:0.3px; }
.store-kpi-value{ font-weight:900; color:#0f172a; font-size:18px; }

.store-toolbar{
  display:grid;
  grid-template-columns: 1.2fr 0.9fr auto;
  gap:10px;
  align-items:end;
  margin: 12px 0 16px;
}
@media (max-width: 980px){
  .store-toolbar{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px){
  .store-toolbar{ grid-template-columns: 1fr; }
}
.store-search-block,
.store-filter-block{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.store-label{ font-size:12px; color:#475569; font-weight:700; }
.store-hint{ font-size:12px; color:#94a3b8; }
.store-toolbar-right{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
}

.store-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, 260px);
  gap: 14px;
  justify-content: center;
}

@media (max-width: 620px){
  .store-grid{
    grid-template-columns: 1fr;
  }
}

/* ensure cards can position absolute elements (delete button) */
.store-card{ position: relative; }

/* small delete button in corner of card */
.loja-card-del{
  position: absolute;
  right: 10px;
  top: 10px;
  width:30px;
  height:30px;
  border-radius:8px;
  border:1px solid #e6edf7;
  background:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:.95;
  font-size:14px;
}
.loja-card-del:hover{
  background:#fff1f2;
  border-color:#fecdd3;
}

/* ===== LOJA TOP NAV (vitrine) ===== */
.loja-topnav{
  display:flex;
  gap:18px;
  align-items:center;
  background:#fff;
  border:1px solid #e6edf7;
  border-radius:14px;
  padding:10px 14px;
  overflow:visible;
  white-space:normal;
  flex-wrap:wrap;
  row-gap:10px;
}

.loja-topitem,
.loja-toplink{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 12px;
  border-radius:12px;
  cursor:pointer;
  color:#0f172a;
  font-weight:600;
  text-decoration:none;
}

.loja-topitem:hover{ background:rgba(15,44,130,.08); }
#loja .loja-topnav{ gap:7px; padding:5px 9px; border-radius:10px; border:1px solid #0d266e; background:#0f2c82; overflow:visible; flex-wrap:wrap; white-space:normal; row-gap:5px; justify-content:center; }
#loja .loja-topnav .store-topnav-btn{ padding:5px 9px; border-radius:12px; font-weight:700; border:1px solid transparent; color:#fff; }

.dd-arrow{ font-size:12px; opacity:.7; }

/* dropdown */
.loja-topitem.has-dd{ position: static; }
.loja-dd{
  position: fixed;
  top: var(--dd-top, 64px);
  left: var(--dd-left, 16px);
  margin-top:0;
  min-width:260px;
  max-width: min(340px, calc(100vw - 32px));
  max-height: min(70vh, 420px);
  overflow-y: auto;
  background:#fff;
  border:1px solid #e6edf7;
  border-radius:14px;
  box-shadow:0 18px 45px rgba(2,6,23,.12);
  padding:10px;
  z-index:60;
  opacity:0;
  transform: translateY(-6px) scale(.995);
  transition: opacity .16s ease, transform .18s ease, box-shadow .18s ease;
  pointer-events:none;
}

.loja-dd.is-open{
  opacity:1;
  transform: translateY(0) scale(1);
  pointer-events:auto;
  box-shadow:0 20px 50px rgba(15,23,42,.12), 0 8px 18px rgba(15,23,42,.06);
}

.loja-dd-item{
  display:block;
  padding:10px 12px;
  border-radius:10px;
  color:#0f172a;
  text-decoration:none;
  font-weight:500;
}

.loja-dd-item:hover{
  background:#f3f7ff;
  color:#1d4ed8;
}

/* mega menu (+ categorias) */
.loja-topitem.has-mega{ position:relative; }

.loja-topitem.has-mega{ position: static; }
.loja-mega{
  position: fixed;
  top: var(--mega-top, 64px);
  left: var(--mega-left, 16px);
  right: auto;
  margin-top:0;
  width:min(860px, 80vw);
  max-width: calc(100vw - 40px);
  max-height: min(80vh, 520px);
  overflow-y: auto;
  background:#fff;
  border:1px solid #e6edf7;
  border-radius:16px;
  box-shadow:0 18px 45px rgba(2,6,23,.12);
  padding:16px;
  z-index:60;

  display: grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;

  opacity:0;
  transform: translateY(-6px) scale(.995);
  transition: opacity .16s ease, transform .18s ease, box-shadow .18s ease;
  pointer-events:none;
}

.loja-mega.is-open{
  opacity:1;
  transform: translateY(0) scale(1);
  pointer-events:auto;
  box-shadow:0 20px 50px rgba(15,23,42,.12), 0 8px 18px rgba(15,23,42,.06);
}

.loja-topitem.mega-right .loja-mega{
  left: auto;
  right: 0;
}

.loja-dd::before{
  content:"";
  position:absolute;
  top:-10px;
  left:0;
  right:0;
  height:10px;
}

.loja-mega::before{
  content:"";
  position:absolute;
  top:-10px;
  left:0;
  right:0;
  height:10px;
}

.loja-mega .col{
  padding:6px;
  border-radius:12px;
}

@media (max-width: 860px){
  .loja-mega{ grid-template-columns: 1fr; min-width: 320px; }
}
@media (max-width: 560px){
  .store-grid{ grid-template-columns: repeat(1, minmax(0, 1fr)); }
}

/* Bloco antigo da loja removido para evitar conflitos de grid/cards (v2 aplicado no final) */

.store-process{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
  margin: 10px 0 16px;
}
@media (max-width: 1080px){
  .store-process{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px){
  .store-process{ grid-template-columns: repeat(1, minmax(0, 1fr)); }
}
.store-process-card{
  background:#fff;
  border:1px solid #e6e9ef;
  border-radius:14px;
  padding:12px;
  box-shadow:0 12px 26px rgba(15,23,42,0.06);
  display:flex;
  flex-direction:column;
  gap:8px;
}
.store-process-title{ font-weight:800; color:#0f172a; }
.store-process-text{ color:#475569; font-size:13px; line-height:1.45; margin:0; }
.store-bullets{
  margin:0;
  padding-left:18px;
  display:flex;
  flex-direction:column;
  gap:6px;
  color:#475569;
  font-size:13px;
}
.store-bullets li{ line-height:1.4; }

.store-grid-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  flex-wrap:wrap;
  margin: 10px 0 8px;
}
.store-grid-title{ margin:4px 0 2px; color:#0f172a; }
.store-grid-sub{ margin:0; color:#64748b; font-size:13px; }
.store-grid-tags{ display:flex; gap:8px; flex-wrap:wrap; }

.store-flow-panels{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
  margin: 14px 0 18px;
}
@media (max-width: 1080px){
  .store-flow-panels{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px){
  .store-flow-panels{ grid-template-columns: repeat(1, minmax(0, 1fr)); }
}
.store-panel-card{
  background:#fff;
  border:1px solid #e6e9ef;
  border-radius:14px;
  padding:12px;
  box-shadow:0 8px 22px rgba(15,23,42,0.05);
  display:flex;
  flex-direction:column;
  gap:8px;
}
.store-panel-card h4{ margin:0; color:#0f172a; }
.store-panel-card p{ margin:0; color:#475569; font-size:13px; line-height:1.45; }

/* overlay + drawer carrinho */
.store-overlay{
  position:fixed; inset:0;
  background: rgba(0,0,0,0.45);
  z-index: 9998;
}
.store-drawer{
  position:fixed;
  top:0; right:0;
  width:min(460px, 92vw);
  height:100dvh;
  background:#fff;
  border-left: 1px solid #e6e9ef;
  z-index: 9999;
  display:flex;
  flex-direction:column;
  box-shadow: -22px 0 60px rgba(2,6,23,0.25);
}
.store-drawer-head{
  padding:14px 14px 10px;
  border-bottom:1px solid #eef2f7;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.store-drawer-title{ font-weight:900; color:#0f172a; }
.store-drawer-sub{ font-size:12px; color:#64748b; margin-top:2px; }

.store-cart-items{
  padding:12px 14px;
  overflow:auto;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.store-cart-item{
  border:1px solid #eef2f7;
  border-radius:12px;
  padding:10px;
  display:grid;
  grid-template-columns: 1fr auto;
  gap:10px;
}
.store-cart-item .name{ font-weight:800; color:#0f172a; }
.store-cart-item .small{ font-size:12px; color:#64748b; margin-top:2px; }
.store-cart-item .qty{
  display:flex; gap:6px; align-items:center; justify-content:flex-end;
}
.store-cart-item .qty input{
  width:76px;
  text-align:right;
}
.store-cart-footer{
  border-top:1px solid #eef2f7;
  padding:12px 14px 14px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.store-cart-total{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:14px;
}
.store-orders{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:6px;
}

.store-orders-empty{
  border:1px dashed #d8e3f2;
  border-radius:20px;
  padding:28px 24px;
  background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);
  text-align:center;
  box-shadow:0 14px 34px rgba(15,23,42,.05);
}

.store-orders-empty-title{
  font-size:18px;
  font-weight:800;
  color:#0f172a;
  letter-spacing:-0.02em;
}

.store-orders-empty-subtitle{
  margin-top:8px;
  font-size:13px;
  color:#64748b;
  line-height:1.55;
}

.store-order{
  border:1px solid #e7edf6;
  border-radius:24px;
  padding:20px;
  background:linear-gradient(180deg,#ffffff 0%, #fcfdff 100%);
  box-shadow:
    0 20px 44px rgba(15,23,42,.055),
    0 6px 16px rgba(15,23,42,.03),
    inset 0 1px 0 rgba(255,255,255,.82);
  transition:
    border-color .18s ease,
    box-shadow .18s ease,
    transform .18s ease,
    background .18s ease;
}

.store-order:hover{
  transform:translateY(-1px);
  border-color:#d9e5f7;
  background:linear-gradient(180deg,#ffffff 0%, #fbfdff 100%);
  box-shadow:
    0 24px 52px rgba(15,23,42,.075),
    0 10px 22px rgba(15,23,42,.04),
    inset 0 1px 0 rgba(255,255,255,.88);
}

.store-order--highlight{
  border-color:#bfdbfe;
  box-shadow:
    0 22px 48px rgba(37,99,235,.12),
    inset 0 1px 0 rgba(255,255,255,.85);
}

.store-order-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  flex-wrap:wrap;
  padding-bottom:2px;
}

.store-order-code{
  font-size:20px;
  font-weight:900;
  color:#0f172a;
  letter-spacing:-0.03em;
  line-height:1.05;
}

.store-order-code::before{
  content:"Pedido";
  display:block;
  margin-bottom:5px;
  font-size:10px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#94a3b8;
}

.store-order-date{
  margin-top:6px;
  font-size:12px;
  color:#64748b;
  letter-spacing:.01em;
}

.store-order-head-right{
  display:flex;
  align-items:center;
  gap:10px;
  padding-top:2px;
}

.store-order-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.01em;
  border:1px solid transparent;
  white-space:nowrap;
}

.store-order-badge.is-pendente{
  background:#fff7ed;
  color:#9a3412;
  border-color:#fed7aa;
}

.store-order-badge.is-aprovado{
  background:#eff6ff;
  color:#1d4ed8;
  border-color:#bfdbfe;
}

.store-order-badge.is-separacao{
  background:#eef2ff;
  color:#4338ca;
  border-color:#c7d2fe;
}

.store-order-badge.is-enviado{
  background:#ecfeff;
  color:#0f766e;
  border-color:#a5f3fc;
}

.store-order-badge.is-recebido{
  background:#ecfdf5;
  color:#166534;
  border-color:#bbf7d0;
}

.store-order-badge.is-parcial{
  background:#fefce8;
  color:#854d0e;
  border-color:#fde68a;
}

.store-order-badge.is-cancelado{
  background:#fff1f2;
  color:#b91c1c;
  border-color:#fecdd3;
}

.store-order-badge.is-neutro{
  background:#f8fafc;
  color:#475569;
  border-color:#e2e8f0;
}

.store-order-summary{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;
  margin-top:16px;
}

.store-order-summary-card{
  border:1px solid #e8edf5;
  border-radius:18px;
  padding:14px 16px;
  background:linear-gradient(180deg,#ffffff 0%, #f9fbff 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72);
}

.store-order-summary-card strong{
  display:block;
  margin-top:3px;
  font-size:28px;
  line-height:1;
  letter-spacing:-0.03em;
  color:#0f172a;
}

.store-order-summary-label{
  display:block;
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:#64748b;
  margin-bottom:6px;
}

.store-order-items{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:14px;
}

.store-order-item{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  padding:13px 15px;
  border-radius:16px;
  background:linear-gradient(180deg,#fbfdff 0%, #f7faff 100%);
  border:1px solid #e7edf6;
}

.store-order-item-name{
  font-size:14px;
  color:#0f172a;
  font-weight:700;
  letter-spacing:-0.01em;
}

.store-order-item-qty{
  font-size:12px;
  font-weight:800;
  color:#1d4ed8;
  background:linear-gradient(180deg,#eef4ff 0%, #e5efff 100%);
  border:1px solid #d6e4ff;
  border-radius:999px;
  padding:5px 10px;
  min-width:48px;
  text-align:center;
  white-space:nowrap;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65);
}

.store-order-delivery{
  margin-top:14px;
  padding:15px 16px;
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%, #fbfcfe 100%);
  border:1px solid #e7edf5;
  color:#526274;
  font-size:13px;
  line-height:1.72;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72);
}

.store-order-delivery strong{
  color:#334155;
  font-weight:800;
}

.store-order-note{
  margin-top:14px;
  padding:12px 14px;
  border-radius:16px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  color:#475569;
  font-size:13px;
  line-height:1.55;
}

.store-order-note--pending{
  background:linear-gradient(180deg,rgba(255,247,237,.58) 0%, rgba(255,250,245,.82) 100%);
  border:1px solid rgba(251,191,36,.30);
  color:#b45309;
  font-weight:600;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55);
}

.store-order-note{
  margin-top:14px;
  padding:11px 14px;
  border-radius:15px;
  background:#f8fafc;
  border:1px solid #e8eef5;
  color:#526274;
  font-size:13px;
  line-height:1.55;
}

.store-order .row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.store-order .muted{
  color:#64748b;
  font-size:12px;
}


/* =========================
   MODAL DETALHE DO PRODUTO - PREMIUM
   (coloque no FINAL do style.css)
========================= */

.loja-det-overlay{
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(2, 6, 23, .55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 9999;
}

.loja-det-modal{
  width: min(1280px, 96vw);
  max-height: 94vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;

  background: linear-gradient(180deg, #ffffff, #fbfcff);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 18px;
  box-shadow: 0 40px 120px rgba(2, 6, 23, .35);
}

/* header fixo e corpo com 1 scroll */
.loja-det-modal .loja-det-header{
  position: sticky;
  top: 0;
  z-index: 2;

  padding: 18px 22px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-bottom: 1px solid rgba(15, 23, 42, .06);
}

.loja-det-modal .loja-det-body{
  flex: 1;
  overflow: auto;
  overflow-x: hidden;
  padding: 18px 22px 22px;
}

.loja-det-modal .loja-det-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, .95fr);
  gap: 22px;
  align-items: start;
}

/* evita scrollbar horizontal “misteriosa” */
.loja-det-modal .loja-det-grid > *{
  min-width: 0;
}

/* card da imagem mais “chique” */
.loja-det-modal .loja-det-imgcard{
  padding: 16px;
  background: #f8fafc;
  border: 1px solid rgba(15, 23, 42, .06);
  border-radius: 16px;
}

.loja-det-modal .loja-det-imgwrap{
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;

  background: #fff;
  border: 1px solid rgba(15, 23, 42, .06);
  border-radius: 14px;
  overflow: hidden;
}

.loja-det-modal .loja-det-imgwrap img{
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* buycard premium e sticky */
.loja-det-modal .loja-det-buycard{
  position: sticky;
  top: 18px;

  padding: 18px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 16px;
  box-shadow: 0 18px 50px rgba(2, 6, 23, .08);
}

/* TAMANHOS em pílulas (não lista vertical) */
.loja-det-modal .loja-size-list{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.loja-det-modal .loja-size-btn{
  width: auto;              /* importante: remove “full width” */
  min-width: 56px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, .14);
  background: #fff;
  font-weight: 700;
}

.loja-det-modal .loja-size-btn:hover{
  background: rgba(15,23,42,.03);
}

.loja-det-modal .loja-size-btn.is-active{
  background: rgba(37, 99, 235, .10);
  border-color: rgba(37, 99, 235, .45);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, .12);
}

/* ACCORDION com cara de SaaS */
.loja-det-modal .loja-acc-item{
  border: 1px solid rgba(15, 23, 42, .06);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
  margin-top: 10px;
}

.loja-det-modal .loja-acc-head{
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
}

.loja-det-modal .loja-acc-head:hover{
  background: rgba(15, 23, 42, .03);
}

.loja-det-modal .loja-acc-caret{
  transition: transform .2s ease;
  opacity: .65;
}

.loja-det-modal .loja-acc-item.is-open .loja-acc-caret{
  transform: rotate(180deg);
}

.loja-det-modal .loja-acc-body{
  padding: 0 16px 16px;
  color: #334155;
  line-height: 1.65;
}

/* Responsivo */
@media (max-width: 980px){
  .loja-det-overlay{ padding: 12px; }
  .loja-det-modal{ width: 96vw; max-height: 96vh; border-radius: 16px; }
  .loja-det-modal .loja-det-grid{ grid-template-columns: 1fr; }
  .loja-det-modal .loja-det-buycard{ position: relative; top: 0; }
}

/* ===== Modal Detalhe do Produto: maior e premium ===== */

/* (Opcional, mas recomendado) trava o fundo quando abrir o modal */
body.modal-open { overflow: hidden; }

/* Modal maior: usa quase toda a largura/altura da tela */
#lojaDetModal{
  width: min(1280px, calc(100vw - 48px));   /* antes era menor */
  max-height: calc(100vh - 48px);           /* mais alto */
  border-radius: 18px;
  overflow: hidden;                          /* evita scroll lateral no modal */
}

/* Corpo do modal é quem rola */
#lojaDetModal .loja-det-body{
  max-height: calc(100vh - 120px);          /* ajusta conforme seu header */
  overflow-y: auto;
  overflow-x: hidden;
  padding: 24px;                             /* mais espaço interno */
}

/* Grid interno com mais espaço */
#lojaDetModal .loja-det-grid{
  gap: 28px;
}

/* Imagem maior e card mais confortável */
#lojaDetModal .loja-det-media{
  min-height: 520px;                         /* aumenta área visual */
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Card de compra ligeiramente maior */
#lojaDetModal .loja-det-buy{
  padding: 22px;
}

/* ===== Isso já deixa o modal bem maior e com mais “espaço de visualização”. ===== */

/* ===== Variação: modo MAX (quase fullscreen) ===== */
/* Use apenas se quiser ocupar ainda mais tela */
#lojaDetModal.max-full,
#lojaDetModal[data-mode="max"]{
  width: calc(100vw - 24px);
  max-height: calc(100vh - 24px);
  border-radius: 16px;
}
#lojaDetModal.max-full .loja-det-body,
#lojaDetModal[data-mode="max"] .loja-det-body{
  max-height: calc(100vh - 96px);
}

/* ===== Ajuste fino (pra não quebrar em telas menores) ===== */
@media (max-width: 900px){
  #lojaDetModal{
    width: calc(100vw - 16px);
    max-height: calc(100vh - 16px);
    border-radius: 14px;
  }
  #lojaDetModal .loja-det-grid{
    grid-template-columns: 1fr;
  }
}

/* ===== Dica premium extra (recomendado) ===== */
@media (min-width: 901px){
  #lojaDetModal .loja-det-buy{
    position: sticky;
    top: 92px; /* ajuste de acordo com seu header */
  }
}

/* Fim do bloco de customizações do modal */

/* ===================== PRÉ-PEDIDO (MODAL) ===================== */

/* trava rolagem do fundo quando abrir modal */
body.modal-open { overflow: hidden; }

#preOverlay{
  display:none;
  position:fixed;
  inset:0;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(4px);
  z-index: 99990;
}

#preModal{
  display:none;
  position:fixed;
  left:50%;
  top:50%;
  transform: translate(-50%, -50%);
  width: min(1100px, 96vw);
  max-height: 92vh;

  background: rgba(255,255,255,0.96);
  border-radius: 16px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.25);

  overflow: hidden;              /* importante: quem rola é o conteúdo, não o modal inteiro */
  z-index: 99991;

  display:flex;
  flex-direction: column;
}

/* header */
#preModal .pre-head{
  padding: 14px 16px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid #e5e7eb;
}

/* Evita o botão Fechar "esticar" dentro do header do modal */
#preModal #preFechar{
  width: auto !important;
  flex: 0 0 auto;
  white-space: nowrap;
}

#preModal .pre-title{
  margin:0;
  font-size: 16px;
  font-weight: 700;
  color: #0f172a;
}

#preModal .pre-sub{
  padding: 10px 16px 0 16px;
  margin: 0;
  color:#6b7280;
  font-size: 13px;
}

/* área rolável */
#preContent{
  padding: 12px 16px;
  overflow: auto;
  flex: 1;
}

/* Deixa o input de Qtd sugerida com cara de campo editável (minimalista) */
#tablePrePedido input[data-pre-qtd]{
  border: 1px solid #e6e9ef;
  background: #fff;
  padding:6px 8px;
  border-radius:8px;
}
#tablePrePedido input[data-pre-qtd]:focus{
  outline: none;
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59,130,246,.15);
}

/* footer fixo */
#preModal .pre-foot{
  padding: 12px 16px;
  border-top: 1px solid #e5e7eb;
  background: linear-gradient(180deg, rgba(248,250,252,0.85), #ffffff);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

#preModal .pre-actions{ display:flex; gap:10px; }

/* Evita quebra de linha nos botões do pré-pedido e garante largura mínima */
#preModal .pre-actions .btn{ white-space: nowrap; }
#preModal .pre-actions .btn{ min-width: 140px; }


/* tabela dentro do modal */
#preContent .table-wrap{
  border: 1px solid #e6e9ef;
  border-radius: 12px;
  overflow: auto;
  background: #fff;
}

/* Ajustes específicos recomendados para o Pré-pedido (visuais SaaS) */
/* Padroniza botões apenas dentro do modal para evitar herança indesejada */
#preModal .btn{
  border-radius: 12px;
  padding: 8px 12px;
  font-weight: 600;
  box-shadow: none;
  border: 1px solid transparent;
  background: #fff;
  color: #0f172a;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Ghost dentro do modal */
#preModal .btn--ghost{
  background: #fff;
  border-color: #e6e9ef;
}

/* Primary CTA */
#preModal .btn--primary{
  background: linear-gradient(135deg,#1e4a6c,#3b82f6);
  color: #fff;
  border-color: transparent;
}

/* Ajustes tipográficos do header */
#preModal .pre-title{ font-size: 17px; }
#preModal .pre-sub{ margin-top: 2px; line-height: 1.25; }

/* Header e footer "fixos" dentro do modal para sensação premium */
#preModal .pre-head{
  position: sticky;
  top: 0;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(6px);
  z-index: 3;
}

#preModal .pre-head-left{ padding-left: 14px; }

#preModal .pre-foot{
  position: sticky;
  bottom: 0;
  z-index: 3;
}

/* Especificidade para o botão Fechar (visualmente mais leve) */
#preModal #preFechar.btn--ghost{ background: #fff; }

/* Tabela: alinhar colunas numéricas à direita (ERP-like) */
/* Ajuste os índices conforme sua ordem de colunas */
#tablePrePedido td:nth-child(2),
#tablePrePedido td:nth-child(3),
#tablePrePedido td:nth-child(4),
#tablePrePedido td:nth-child(5),
#tablePrePedido td:nth-child(6),
#tablePrePedido td:nth-child(7){
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* coluna Item: alinhada à esquerda, mas com truncamento para nomes longos */
#tablePrePedido td:nth-child(1){
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Destaque para saldos negativos/positivos/neutros quando a célula receber classe via JS */
#tablePrePedido .neg{ color:#b91c1c; background:#fef2f2; border-radius:8px; padding:2px 8px; display:inline-block; min-width:42px; text-align:center; }
#tablePrePedido .pos{ color:#065f46; background:#ecfdf5; border-radius:8px; padding:2px 8px; display:inline-block; min-width:42px; text-align:center; }
#tablePrePedido .neu{ color:#334155; background:#f1f5f9; border-radius:8px; padding:2px 8px; display:inline-block; min-width:42px; text-align:center; }

/* Peso visual da tabela: bordas mais definidas e hierarquia */
#tablePrePedido th, #tablePrePedido td{
  border-bottom: 1px solid #eef2f7;
}
#tablePrePedido thead th{
  border-bottom: 1px solid #e6e9ef;
}

/* alinhamento do rótulo do total no footer da tabela */
#tablePrePedido .pre-total-label{ text-align: right; }

/* remove underline for links inside the pre modal table (if any) */
#preModal #tablePrePedido a{ color:inherit; text-decoration:none; }

/* destaque visual para a linha de total sugerido */
#tablePrePedido .pre-total-row{
  background: linear-gradient(180deg, rgba(248,250,252,0.6), #ffffff);
  font-weight: 600;
}

/* ===== PRÉ-PEDIDO: alinhamento consistente (th + td) ===== */
#tablePrePedido th:nth-child(n+2),
#tablePrePedido td:nth-child(n+2){
  text-align: right;
  font-variant-numeric: tabular-nums;
}

#tablePrePedido th:first-child,
#tablePrePedido td:first-child{
  text-align: left;
}

/* última coluna: input alinhado com o total (lado direito) */
#tablePrePedido td:last-child{
  text-align: right;
}
#tablePrePedido td:last-child input[data-pre-qtd]{
  display: block;
  margin-left: auto;
  text-align: right;
}

/* evita o nome do item quebrar linha (fica elegante) */
#tablePrePedido td:first-child{
  white-space: nowrap !important;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* total “grudado” no grid da última coluna */
#tablePrePedido tfoot .pre-total-label{
  text-align: right;
  padding-right: 14px;
}


/* em vez de width fixa, usa min-width */
#tablePrePedido{
  width: 100%;
  min-width: 924px;              /* mantém seu layout, mas não força sempre */
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}

/* header mais moderno + sticky */
#tablePrePedido thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  background: #f8fafc;
  color: #0f172a;
  font-weight: 700;
}

/* zebra + hover (fica muito mais “SaaS”) */
#tablePrePedido tbody tr:nth-child(even){ background:#fcfdff; }
#tablePrePedido tbody tr:hover{ background:#f1f5ff; }

/* inputs mais bonitos */
#tablePrePedido input[data-pre-qtd]{
  width: 92px !important;
  padding: 6px 8px;
  border-radius: 10px;
}

/* pequenos ajustes visuais */
.btn--ghost{ background:transparent; border:1px solid #e6e9ef; }

/* ===================== PRÉ-PEDIDO — ALINHAMENTO PERFEITO ===================== */
/* (Cabeçalho e corpo alinhados por coluna, igual às outras tabelas do sistema) */

#preModal #tablePrePedido th,
#preModal #tablePrePedido td{
  padding: 12px 14px;
  vertical-align: middle;
}

/* 1) Item: texto à esquerda */
#preModal #tablePrePedido th:nth-child(1),
#preModal #tablePrePedido td:nth-child(1){
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 2) CA: centralizado */
#preModal #tablePrePedido th:nth-child(2),
#preModal #tablePrePedido td:nth-child(2){
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* 3/4/5) Estoque / Mín / Venc 30d: números centralizados */
#preModal #tablePrePedido th:nth-child(3),
#preModal #tablePrePedido td:nth-child(3),
#preModal #tablePrePedido th:nth-child(4),
#preModal #tablePrePedido td:nth-child(4),
#preModal #tablePrePedido th:nth-child(5),
#preModal #tablePrePedido td:nth-child(5){
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* 6) Saldo (badge): centralizado fica mais “limpo” */
#preModal #tablePrePedido th:nth-child(6),
#preModal #tablePrePedido td:nth-child(6){
  text-align: center;
}

/* 7) Qtd sugerida (input): centralizado */
#preModal #tablePrePedido th:nth-child(7),
#preModal #tablePrePedido td:nth-child(7){
  text-align: center;
}
#preModal #tablePrePedido td:nth-child(7) input[data-pre-qtd]{
  text-align: center;
}

/* ===================== PRÉ-PEDIDO (MODAL) — ALINHAMENTO FINAL ===================== */
#preModal #tablePrePedido{
  width: 100%;
  min-width: 924px;            /* mantém sua referência */
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}

/* Mesmo espaçamento de tabela “boa” (mais legível) */
#preModal #tablePrePedido th,
#preModal #tablePrePedido td{
  padding: 12px 14px;
  vertical-align: middle;
}

/* Cabeçalho mais consistente */
#preModal #tablePrePedido thead th{
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .02em;
  text-align: left;            /* base: texto à esquerda */
}

/* Larguras (você já tem — aqui só reforço com o escopo do modal) */
#preModal #tablePrePedido th:nth-child(1),
#preModal #tablePrePedido td:nth-child(1){ width:217px; text-align:left; white-space: normal; }

#preModal #tablePrePedido th:nth-child(2),
#preModal #tablePrePedido td:nth-child(2){ width:121px; text-align:left; white-space: nowrap; }

/* NÚMEROS: alinhar “título com número” = mesmo alinhamento */
#preModal #tablePrePedido th:nth-child(3),
#preModal #tablePrePedido td:nth-child(3){ width:97px;  text-align:center; }

#preModal #tablePrePedido th:nth-child(4),
#preModal #tablePrePedido td:nth-child(4){ width:71px;  text-align:center; }

#preModal #tablePrePedido th:nth-child(5),
#preModal #tablePrePedido td:nth-child(5){ width:140px; text-align:center; }

/* Saldo é badge/pílula → fica melhor centralizado */
#preModal #tablePrePedido th:nth-child(6),
#preModal #tablePrePedido td:nth-child(6){ width:165px; text-align:center; }

/* Input (Qtd sugerida) → centralizado e com largura consistente */
#preModal #tablePrePedido th:nth-child(7),
#preModal #tablePrePedido td:nth-child(7){ width:113px; text-align:center; }

#preModal #tablePrePedido td:nth-child(7) input[data-pre-qtd]{
  width: 86px !important;      /* vence inline width:100px do JS */
  text-align: center;
  margin: 0 auto;
  height: 34px;
  border-radius: 10px;
}

/* Se “Saldo (sem compra)” estiver quebrando feio, deixa quebrar bonito */
#preModal #tablePrePedido th:nth-child(6){
  white-space: normal;
  line-height: 1.15;
}




/* ===================== PRÉ-PEDIDO — ALINHAMENTO FINAL ===================== */

/* Espaçamento consistente */
#preModal #tablePrePedido th,
#preModal #tablePrePedido td{
  padding: 10px 8px;
  vertical-align: middle;
  font-size: 13px;
}

/* Pré-pedido: base estrutural da tabela */
#preModal #tablePrePedido{
  table-layout: fixed !important;
  width: 781px !important;           /* exatamente o total das colunas */
  border-collapse: separate;
  border-spacing: 0;
}

/* Coluna 1 — Item */
#preModal #tablePrePedido th:nth-child(1),
#preModal #tablePrePedido td:nth-child(1){
  text-align: left;
  white-space: normal;
}

/* Coluna 2 — CA */
#preModal #tablePrePedido th:nth-child(2),
#preModal #tablePrePedido td:nth-child(2){
  text-align: center;
}

/* Colunas numéricas — alinhamento perfeito título ↔ número */
#preModal #tablePrePedido th:nth-child(3),
#preModal #tablePrePedido td:nth-child(3),
#preModal #tablePrePedido th:nth-child(4),
#preModal #tablePrePedido td:nth-child(4),
#preModal #tablePrePedido th:nth-child(5),
#preModal #tablePrePedido td:nth-child(5){
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* Saldo — badge central */
#preModal #tablePrePedido th:nth-child(6),
#preModal #tablePrePedido td:nth-child(6){
  text-align: center;
}

/* Qtd sugerida — input central */
#preModal #tablePrePedido th:nth-child(7),
#preModal #tablePrePedido td:nth-child(7){
  text-align: center;
}

#preModal #tablePrePedido td:nth-child(7) input{
  width: 80px;
  margin: 0 auto;
  text-align: center;
}

/* IMPORTANTE: remover/regra conflitante ex.: */
/* #tablePrePedido tbody td{ text-align: left !important; } */

/* Opcional: centralizar tabela dentro do modal */
#preModal .table-wrap{
  display: flex;
  justify-content: center;
}








/* =========================
   LOJA - TOP NAV (VITRINE)
========================= */
.store-topnav{
  margin: 10px 0 14px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(2, 8, 23, .05);
  position: sticky;
  top: 10px;
  z-index: 20;
}

.store-topnav-list{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  overflow: visible;     /* IMPORTANTÍSSIMO pro mega menu aparecer */
  flex-wrap: wrap;       /* se faltar espaço, quebra linha ao invés de rolar */
}

/* Evita qualquer scroll horizontal provocado por menus na LOJA */
#loja { overflow-x: hidden; }

.store-topnav-item{ position: relative; }

.store-topnav-btn{
  border: 1px solid transparent;
  background: transparent;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 600;
  color: #0f172a;
  cursor: pointer;
  white-space: nowrap;
  transition: background .18s ease, color .14s ease, transform .12s ease;
}

.store-topnav-btn:hover{
  background: rgba(37, 99, 235, .08);
  border-color: rgba(37, 99, 235, .18);
  transform: translateY(-1px);
}

.store-topnav-btn .chev{
  margin-left: 6px;
  opacity: .7;
}


/* Topnav / dropdowns */
.store-topnav { position: relative; overflow: visible; }
.store-topnav-list { display: flex; gap: 18px; align-items: center; list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.store-topnav-item { position: relative; }

.store-topnav-btn { cursor: pointer; border: 0; background: transparent; padding: 10px 12px; border-radius: 999px; font-weight: 800; }
.store-topnav-btn:hover { background: rgba(37, 99, 235, 0.08); }
.store-topnav-btn .chev { margin-left: 6px; font-size: 12px; opacity: .7; }

/* Mega menu — usa fixed pra não empurrar o conteúdo da página */
.store-topnav-item.has-mega { position: static; }

.store-mega{
  position: fixed;
  top: var(--mega-top, 64px);
  left: var(--mega-left, 16px);
  right: auto;

  width: min(980px, calc(100vw - 32px));
  max-width: 980px;
  max-height: min(80vh, 520px);
  overflow-y: auto;

  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,255,255,0.96));
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 14px;
  padding: 16px 18px;

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;

  box-shadow: 0 10px 30px rgba(15,23,42,.08), 0 24px 60px rgba(15,23,42,.06);
  z-index: 9999;
  will-change: transform, opacity, box-shadow;

  opacity: 0;
  transform: translateY(-6px) scale(.995);
  transition: opacity .16s ease, transform .18s cubic-bezier(.2,.9,.3,1), box-shadow .18s ease;
  pointer-events: none;
}

.store-mega.is-open{
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
  box-shadow: 0 20px 50px rgba(15,23,42,.12), 0 8px 18px rgba(15,23,42,.06);
}

/* “Ponte” invisível pra não sumir quando desce o mouse */
.store-mega::before{
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: -12px;
  height: 12px;
}

/* Colunas do mega */
.store-mega-col { display: flex; flex-direction: column; gap: 10px; }
.store-mega .store-dd-item{
  text-align: left;
  width: 100%;
  border: 0;
  background: transparent;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  color: #0f172a;
  transition: background .14s ease, transform .12s ease, padding-left .12s ease;
}
.store-mega .store-dd-item:hover{
  background: rgba(37, 99, 235, 0.08);
  transform: translateX(6px);
  padding-left: 14px;
  box-shadow: inset 0 0 0 1px rgba(37,99,235,0.03);
}

.store-mega .store-dd-item:active{
  transform: translateX(2px);
}


/* Mobile: mega vira 1 coluna */
@media (max-width: 860px){
  .store-topnav{ top: 6px; }
  .store-mega{
    grid-template-columns: 1fr;
    min-width: 320px;
    width: min(420px, calc(100vw - 20px));
  }
}







.loja-specs-title{font-weight:700;color:#0f172a;margin:8px 0 4px;}
#especContainer{display:flex;flex-direction:column;gap:8px;}
.espec-group{display:grid;grid-template-columns:1fr 2fr auto;gap:8px;align-items:flex-start;}
.espec-group input,.espec-group textarea{width:100%;}
.espec-group textarea{min-height:60px;resize:vertical;}
.espec-del{align-self:start;background:#f44336;color:#fff;border:none;padding:8px 10px;border-radius:6px;cursor:pointer;}
.espec-del:hover{filter:brightness(1.05);}
.loja-det-spec{border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;margin-bottom:10px;}
.loja-det-spec h4{margin:0 0 6px;font-size:14px;color:#0f172a;}
.loja-det-spec p{margin:0;white-space:pre-wrap;}

/* Upload de imagem no modal da Loja - preview */
.loja-img-box{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.loja-imgs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;}
.loja-img-slot{position:relative;border:1px dashed #cbd5e1;border-radius:10px;aspect-ratio:4/5;overflow:hidden;background:#fff;display:grid;place-items:center;}
.loja-img-slot img{width:100%;height:100%;object-fit:cover;}
.loja-img-del{position:absolute;top:6px;right:6px;background:#fff;border:1px solid #fecdd3;color:#b91c1c;border-radius:8px;padding:4px 8px;cursor:pointer;font-size:12px;}
.loja-img-del:hover{box-shadow:0 6px 14px rgba(185,28,28,.18);}

.loja-img-preview{
  position: relative;
  width:100%;
  aspect-ratio: var(--loja-card-ratio);
  border:1px dashed #d6e2f5;
  border-radius:14px;
  background: #fff;
  overflow:hidden;
  --img-x: 50%;
  --img-y: 50%;
  --img-zoom: 1;
}

.loja-img-preview::before{
  content:"Sem imagem";
  font-size:12px;
  color:#7a8fb6;
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
}

.loja-img-preview.is-on::before{
  content:"";
}

.loja-img-preview img{
  position:absolute;
  top:50%;
  left:50%;
  width:100%;
  height:100%;
  max-width:none;
  max-height:none;
  object-fit:contain;
  transform: translate(calc(-50% + var(--img-x, 50%)), calc(-50% + var(--img-y, 50%))) scale(var(--img-zoom, 1));
  transform-origin:center;
  display:none;
}

.loja-img-preview.is-on img{
  display:block;
}

/* PREVIEW do cadastro igual ao card */
#lojaProdImgPreviewWrap{
  display: none;
}

#lojaProdImgPreviewWrap.is-on{
  display: block;
}

#lojaProdImgPreview{
  pointer-events: none;
}

.loja-det-thumbs{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.loja-det-thumbs{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px;scroll-snap-type:x mandatory;overflow-x:auto;padding-bottom:4px;}
.loja-det-thumbs .loja-thumb{border:1px solid #e5e7eb;border-radius:12px;padding:4px;background:#fff;cursor:pointer;width:74px;height:74px;display:grid;place-items:center;transition:box-shadow .14s ease, border-color .14s ease, transform .12s ease; scroll-snap-align:start;}
.loja-det-thumbs .loja-thumb:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(15,23,42,.12);}
.loja-det-thumbs .loja-thumb.is-on{border-color:#3b82f6;box-shadow:0 10px 26px rgba(59,130,246,.16);}
.loja-det-thumbs img{width:100%;height:100%;object-fit:cover;border-radius:10px;}

/* Deixa a prévia da imagem menor dentro do modal de produto */
#lojaProdModal .loja-img-box{
  align-items: flex-start;
}

#lojaProdModal .loja-img-preview{
  width: 180px;
  max-width: 100%;
}

@media (max-width: 640px){
  #lojaProdModal .loja-img-preview{ width: 140px; }
}

/* CROP: garantir 1 tela e viewport limpa */
#lojaCropModal{
  max-height: 88vh;
  overflow-x: hidden;
  overflow-y: auto;
}

#lojaCropModal .loja-crop-viewport{
  width: 100%;
  aspect-ratio: var(--loja-card-ratio);
  max-height: 280px;
  min-height: 200px;
  overflow: hidden;
  border-radius: 12px;
  background: #fff;
  position: relative;
}

#lojaCropModal .cropper-container{
  width: 100% !important;
  height: 100% !important;
}

/* escurece mais a área fora do recorte */
#lojaCropModal .cropper-modal{
  background-color: rgba(0,0,0,0.70) !important;
}

/* deixa o quadro do recorte mais “visível” */
#lojaCropModal .cropper-view-box{
  outline: 2px solid rgba(255,255,255,0.95);
  outline-offset: -2px;
}

#lojaCropModal .cropper-face{
  background-color: rgba(255,255,255,0.10);
}

#lojaCropModal .cropper-line,
#lojaCropModal .cropper-point{
  background-color: rgba(255,255,255,0.95);
}



/* ===== LOJA: CROP (sombra mais escura + área útil bem marcada) ===== */
body.loja-crop-open #lojaCropOverlay{
  background: rgba(0,0,0,.72) !important;
}

body.loja-crop-open .cropper-modal{
  background-color: #000 !important;
  opacity: .65 !important;
}

body.loja-crop-open .cropper-view-box{
  outline: 2px solid rgba(255,255,255,.95) !important;
  outline-offset: -2px;
  border-radius: 14px;
  box-shadow: 0 0 0 9999px rgba(0,0,0,.55) !important;
}

body.loja-crop-open .cropper-face{
  background-color: rgba(255,255,255,.05) !important;
}

/* garante que o recorte fique limpo dentro do modal */
.loja-crop-modal{
  max-width: 760px;
}

.loja-crop-viewport{
  width: 100%;
  aspect-ratio: var(--loja-card-ratio);
  max-height: 280px;
  min-height: 200px;
  overflow: hidden;
  border-radius: 16px;
  background: #fff;
  position: relative;
}
#lojaCropImg{
  position:absolute;
  top:50%;
  left:50%;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: contain;
  transform: translate(calc(-50% + var(--img-x, 50%)), calc(-50% + var(--img-y, 50%))) scale(var(--img-zoom, 1));
  transform-origin: center;
  user-select: none;
  pointer-events: auto;
}







/* Ajuste de altura do card da loja */
.store-card .img { height:auto; min-height:190px; aspect-ratio: var(--loja-card-ratio); }

/* Estilos do modal de detalhe do produto (Loja) */
.loja-det-modal{
  width: min(980px, 96vw);
  max-height: 92vh;
  overflow: auto;
}

.loja-det-grid{
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 14px;
}

.loja-det-left{
  background: #f5f7ff;
  border: 1px solid #e7ebff;
  border-radius: 12px;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 360px;
}

#lojaDetImg{
  width: 100%;
  height: 340px;
  object-fit: contain;
  border-radius: 10px;
  background: #fff;
}

.loja-det-nome{ font-weight: 800; font-size: 16px; margin-top: 4px; }
.loja-det-meta{ font-size: 12px; opacity: .8; margin: 6px 0 10px; }
.loja-det-preco{ font-size: 18px; font-weight: 900; margin: 8px 0 12px; }

.loja-det-label{ font-size: 12px; font-weight: 700; opacity: .85; margin-bottom: 6px; }

.loja-det-cores{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.loja-cor-dot{
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid rgba(0,0,0,.15);
  cursor: pointer;
  position: relative;
}

.loja-cor-dot.is-active{
  border-color: #1f4bff;
  box-shadow: 0 0 0 3px rgba(31,75,255,.15);
}

.loja-cor-dot.is-disabled{
  opacity: .35;
  pointer-events: none;
}

.loja-cor-dot.is-active::after{
  content: "✓";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: #0a1a55;
  font-weight: 900;
}

.loja-det-qty{
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 12px 0;
}

#lojaDetQtd{
  width: 80px;
  padding: 10px;
  border-radius: 10px;
  border: 1px solid #dfe6ff;
  text-align: center;
  outline: none;
}

.loja-det-desc{
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid #e7ebff;
}

.loja-det-desc-text{
  font-size: 13px;
  line-height: 1.5;
  opacity: .9;
  white-space: pre-wrap;
}


/* garantir detalhe acima de tudo (apenas Loja) */
#lojaDetOverlay { z-index: 5000; }
#lojaDetModal   { z-index: 5001; }



/* ---------------------- Ajustes Loja: refinamento solicitado ---------------------- */
/* Cabeçalho: título + fechar */
#lojaDetNome{
  font-size: 22px;     /* fonte um pouco maior */
  font-weight: 800;    /* peso maior */
  margin: 0 0 4px 0;   /* espaçamento menor entre título e meta */
  line-height: 1.08;
}

#lojaDetMeta{
  font-size: 13px;     /* reduzido levemente */
  opacity: .85;        /* aumentar opacidade clara */
  margin-top: 2px;
}

/* Imagem do produto: destaque maior */
.loja-det-media{
  padding: 8px; /* reduzir padding interno */
  background: linear-gradient(180deg, rgba(245,247,255,0.6) 0%, rgba(255,255,255,0.85) 70%); /* degradê suave */
  border-radius: 14px;
  display: flex;
  align-items: center; /* centralizar verticalmente */
  justify-content: center;
  min-height: 420px;
}

#lojaDetImg{
  height: 400px; /* aumentar levemente */
  width: 100%;
  max-width: 100%;
  object-fit: contain; /* manter */
  display: block;
  margin: 0 auto;
}

/* Seletor de cores (premium) */
.loja-color-dot,
.loja-cor-dot{
  width: 28px; height: 28px;             /* aumentar levemente */
  border-radius: 50%;
  cursor: pointer;
  position: relative;
  box-shadow: 0 6px 18px rgba(2,6,23,0.08); /* sombra suave */
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease, border-color .12s ease;
  /* borda branca interna: criado com box-shadow inset */
  box-shadow: 0 6px 18px rgba(2,6,23,0.08), inset 0 0 0 2px rgba(255,255,255,0.85);
}

.loja-color-dot.is-on,
.loja-cor-dot.is-active{
  border-color: transparent; /* a cor principal fica visível por baixo */
  box-shadow: 0 6px 22px rgba(2,6,23,0.10), 0 0 0 6px rgba(31,75,255,0.12); /* anel externo azul suave */
}

.loja-color-dot.is-on::after,
.loja-cor-dot.is-active::after{
  content: "✓"; /* check centralizado */
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: #07207a;
  font-weight: 800;
}

.loja-color-dot.is-off,
.loja-cor-dot.is-disabled{
  opacity: .35;           /* reduzir opacidade */
  pointer-events: none;   /* sem pointer */
  cursor: default;
}

/* Card de compra: organização e destaque */
.loja-det-buy{
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: #fff;
  border-radius: 14px;
  padding: 16px;
  border: 1px solid rgba(15,23,42,0.06);
  box-shadow: 0 12px 28px rgba(2,6,23,0.08); /* sombra suave no card inteiro */
}

.loja-det-buy .loja-det-preco{ display:flex; flex-direction:column; gap:6px; }
.loja-det-buy .loja-det-preco .muted{ font-size:12px; font-weight:700; }
.loja-det-buy .loja-det-preco b{ font-size:26px; } /* aumentar valor */

.loja-det-buy .loja-color-list{ margin-top:6px; }

.loja-det-buy .loja-qty-ctrl{ margin-top:6px; }

/* Botão Adicionar ao carrinho */
#btnLojaDetAdd{
  background: linear-gradient(135deg, #1d4ed8, #2563eb); /* leve gradiente */
  color: #fff;
  border: none;
  padding: 12px 16px;
  border-radius: 12px;
  box-shadow: 0 8px 22px rgba(37,99,235,0.18);
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}

#btnLojaDetAdd:hover{
  transform: translateY(-4px); /* subir levemente */
  box-shadow: 0 16px 36px rgba(37,99,235,0.26);
}

#btnLojaDetAdd:active{
  transform: translateY(0); /* afundar levemente no clique */
  box-shadow: 0 6px 18px rgba(37,99,235,0.18);
}

/* Descrição: caixa visível sem rolar */
.loja-det-desc{
  margin: 12px 18px 18px;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(248,250,252,0.9);
  border: 1px solid rgba(15,23,42,0.04);
}

/* Animação de abertura suave (fade + scale) */
@keyframes lojaDetIn{
  from{
    opacity: 0;
    transform: translate(-50%, -50%) translateY(10px) scale(.98);
  }
  to{
    opacity: 1;
    transform: translate(-50%, -50%) translateY(0) scale(1);
  }
}

#lojaDetModal{
  animation: lojaDetIn .16s ease;
  will-change: transform, opacity;
}

/* Overlay mais leve e com blur */
#lojaDetOverlay{
  position: fixed;   /* garante overlay cobrindo toda a tela */
  inset: 0;
  display: none;     /* mostrado via JS quando necessário */
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(2,6,23,0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 5000;
}

/* centralização e posicionamento do modal de detalhe agora estão
   consolidados no bloco principal "LOJA — MODAL DETALHE". */

/* Responsividade: mobile refinado */
@media (max-width: 900px){
  .loja-det-grid{ grid-template-columns: 1fr; }
  .loja-det-media{ order: -1; min-height: 300px; }
  #lojaDetImg{ height: 260px; }
  .loja-det-buy{ width: 100%; }
  #btnLojaDetAdd{ width: 100%; }
}

/* Garantir que o início da descrição seja visível em desktop (pequeno ajuste estrutural) */
@media (min-width: 901px){
  .loja-det-modal{ max-height: 86vh; overflow: auto; }
  .loja-det-grid{ padding-bottom: 6px; }
}

/* fim do bloco de refinamento Loja */

/* Estilos de polimento visual do modal estão mantidos nos seletores
   específicos (.loja-det-inner, .loja-det-media, etc.). A base de
   posicionamento foi consolidada em um bloco único no topo do arquivo. */

/* ==========================
   LOJA — TOPO / NAV / TOOLBAR
   ========================== */

/* Header da Loja: duas linhas claras */
.store-header{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-bottom:12px;
}
.store-header .store-header-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.store-header .store-header-bottom{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:flex-start;
}

/* Padroniza o badge do carrinho */
.store-badge, #lojaCartCount{
  display:inline-grid;
  min-width:28px; height:20px; padding:0 8px;
  place-items:center;
  background: linear-gradient(180deg,#eef2ff,#e0e7ff);
  color:#1e3a8a;
  border-radius:999px;
  font-weight:700;
  font-size:12px;
  box-shadow: 0 6px 14px rgba(16,24,40,0.06);
}

/* Topnav: nav pills e estado ativo */
.loja-topnav{
  display:flex; gap:8px; flex-wrap:wrap; align-items:center;
}
.loja-topnav .store-topnav-item{ display:inline-flex; }
.loja-topnav .store-topnav-btn{
  padding:8px 12px; border-radius:999px; border:1px solid transparent; cursor:pointer;
}
.loja-topnav .store-topnav-btn.active,
.loja-topnav .loja-topitem.active{
  background: rgba(59,130,246,0.08);
  color: #1e40af;
  border-color: rgba(59,130,246,0.18);
}

/* mobile: scroll horizontal sem quebra */
@media (max-width: 980px){
  .loja-topnav{ overflow-x:auto; -webkit-overflow-scrolling:touch; white-space:nowrap; }
  .loja-topnav .store-topnav-item{ display:inline-flex; }
  .loja-topnav::-webkit-scrollbar{ display:none; }
}

/* Toolbar: inputs e botões com mesma altura e raio */
.store-toolbar{ display:flex; gap:12px; align-items:center; justify-content:space-between; margin-bottom:14px; }
.store-search-block, .store-filter-block{ display:flex; flex-direction:column; gap:6px; }
.store-search-block .ctrl, .store-filter-block .ctrl, .store-toolbar .btn{ height:40px; border-radius:10px; }
.store-search-block .ctrl{ padding:8px 12px; box-shadow: 0 6px 18px rgba(2,6,23,0.04); }
.store-filter-block .ctrl{ padding:8px 12px; }
.store-toolbar-right .btn{ height:40px; padding:8px 12px; }

/* Grid Head: reduz poluição visual */
.store-grid-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:10px; }
.store-grid-title{ margin:0; font-size:20px; font-weight:700; color:#0f172a; }
.store-grid-sub{ margin:2px 0 0; font-size:12px; color:#94a3b8; }

/* ==========================
   LOJA — CARDS (refinamento)
   ========================== */
.store-grid{ display:grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap:18px; }
.store-card{ background:#fff; border-radius:14px; overflow:hidden; border:1px solid rgba(15,23,42,0.02); box-shadow: 0 18px 42px rgba(15,23,42,0.08); transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease; display:flex; flex-direction:column; }
.store-card .img{
  position: relative;
  width: 100%;
  aspect-ratio: var(--loja-card-ratio);
  min-height: 190px;
  background:#fff;
  overflow:hidden;
  --img-x: 50%;
  --img-y: 50%;
  --img-zoom: 1;
}
.store-card .img img{
  position: absolute;
  top:50%;
  left:50%;
  width:100%;
  height:100%;
  max-width:none;
  max-height:none;
  object-fit: contain;
  transform: translate(calc(-50% + var(--img-x, 50%)), calc(-50% + var(--img-y, 50%))) scale(var(--img-zoom, 1));
  transform-origin: center;
}
.store-card .body{ padding:14px 16px 16px; display:flex; flex-direction:column; gap:10px; }
.store-card .title{ font-weight:600; font-size:15px; color:#0f172a; line-height:1.25; }
.store-card .meta{ display:flex; gap:10px; flex-wrap:wrap; color:#94a3b8; font-size:12px; }
.store-card .meta .pill{ margin:0; background:transparent; color:inherit; padding:0; border-radius:0; }
.store-card .price{ display:flex; align-items:baseline; gap:6px; }
.store-card .price b{ font-size:20px; color:#0f172a; font-weight:700; }
.store-card .price small{ color:#94a3b8; font-size:12px; }
.store-card .actions{ display:flex; gap:8px; margin-top:auto; }
.store-card:hover{ transform: translateY(-6px); box-shadow: 0 24px 58px rgba(15,23,42,0.12); border-color: rgba(15,23,42,0.06); }

/* Ajuste do botão principal no card */
.store-card .actions .btn-primary{ flex:1; }

/* ==========================
   LOJA — DRAWER/CART
   ========================== */
.store-drawer{ width: 420px; max-width: 96vw; right:0; top:0; bottom:0; position:fixed; background:#fff; box-shadow: -18px 0 40px rgba(2,6,23,0.08); display:flex; flex-direction:column; z-index:6000; }
.store-cart-items{ flex:1; overflow:auto; padding:12px; }
.store-cart-footer{ border-top:1px solid rgba(15,23,42,0.04); padding:12px; display:flex; flex-direction:column; gap:10px; background:#fff; }
.store-cart-footer .store-cart-total{ display:flex; justify-content:space-between; align-items:center; font-weight:800; font-size:16px; }
.store-cart-empty{ text-align:center; padding:28px; color:#64748b; }
.store-cart-item{ display:flex; gap:10px; align-items:center; padding:8px 0; border-bottom:1px dashed rgba(15,23,42,0.04); }
.store-cart-item .thumb{ width:56px; height:56px; border-radius:8px; overflow:hidden; background:#f6f9ff; display:flex; align-items:center; justify-content:center; }
.store-cart-item .thumb img{ width:100%; height:100%; object-fit:cover; }
.store-cart-item .qty-ctrl{ display:flex; gap:8px; align-items:center; }
.store-cart-item .qty-ctrl button{ width:32px; height:32px; border-radius:8px; }

/* ==========================
   LOJA — MODAIS: Produto & Crop
   ========================== */
.modal .section{ padding:12px 0; border-bottom:1px solid rgba(15,23,42,0.04); }
.modal .section h4{ margin:0 0 8px 0; font-size:14px; }
.loja-var-list .var-row{ display:flex; gap:8px; align-items:center; padding:8px 0; }

/* crop preview final (pequeno quadrado) */
.loja-crop-preview{ width:76px; height:76px; border-radius:8px; overflow:hidden; border:1px solid rgba(15,23,42,0.06); background:#fff; }


/* ==========================
   LOJA — TOAST (flutuante)
   ========================== */
#lojaToast{
  position:fixed;
  top:22px;
  right:22px;
  z-index:7000;
  display:none;
}

.loja-toast{
  min-width:340px;
  max-width:430px;
  padding:16px 18px;
  border-radius:20px;
  display:flex;
  gap:12px;
  align-items:flex-start;
  justify-content:space-between;
  box-shadow:
    0 24px 60px rgba(15,23,42,.18),
    0 10px 24px rgba(15,23,42,.08);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.35);
}

.loja-toast .toast-msg{
  flex:1;
  font-size:13px;
  line-height:1.55;
}

.loja-toast .toast-close{
  width:28px;
  height:28px;
  border:none;
  border-radius:999px;
  background:rgba(255,255,255,.45);
  color:inherit;
  cursor:pointer;
  font-size:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:transform .16s ease, background .16s ease;
}

.loja-toast .toast-close:hover{
  transform:scale(1.04);
  background:rgba(255,255,255,.7);
}

.loja-toast--ok{
  background:linear-gradient(135deg, rgba(239,246,255,.96), rgba(219,234,254,.96));
  color:#0f3c8a;
  border-color:rgba(147,197,253,.55);
}

.loja-toast--error{
  background:linear-gradient(135deg, rgba(255,241,242,.96), rgba(254,205,211,.96));
  color:#881337;
  border-color:rgba(253,164,175,.55);
}

#lojaPedModal{
  background:linear-gradient(180deg, rgba(255,255,255,.99), rgba(248,251,255,.98));
  border:1px solid #e6edf7;
  border-radius:26px;
  box-shadow:0 34px 80px rgba(15,23,42,.18);
}

.loja-modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding-bottom:14px;
  margin-bottom:14px;
  border-bottom:1px solid #edf2f7;
}

.loja-modal-title{
  margin:0;
  font-size:24px;
  font-weight:800;
  color:#0f172a;
  letter-spacing:-0.02em;
}

.loja-modal-subtitle{
  margin:6px 0 0;
  font-size:13px;
  color:#64748b;
  line-height:1.55;
}

#btnLojaPedFechar{
  min-width:132px;
  height:40px;
  padding:0 18px;
  border-radius:12px;
  border:1px solid #dbe4ef;
  background:linear-gradient(180deg,#ffffff 0%, #f8fafc 100%);
  color:#334155;
  font-weight:700;
  box-shadow:0 8px 18px rgba(15,23,42,.04);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}

#btnLojaPedFechar:hover{
  transform:translateY(-1px);
  border-color:#cfd9e6;
  background:#ffffff;
  box-shadow:0 12px 22px rgba(15,23,42,.06);
}

#lojaPedModal{
  scrollbar-width:thin;
  scrollbar-color:#cbd5e1 transparent;
}

#lojaPedModal::-webkit-scrollbar{
  width:10px;
}

#lojaPedModal::-webkit-scrollbar-track{
  background:transparent;
}

#lojaPedModal::-webkit-scrollbar-thumb{
  background:#d4dce7;
  border-radius:999px;
  border:2px solid transparent;
  background-clip:padding-box;
}


/* O corpo do modal (rolável) */
.loja-det-body{
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0;                /* espaço interno controlado pelos elementos internos */
}

/* Garante que o header fique sempre visível */
#lojaDetModal .loja-det-head{ position: sticky; top: 0; z-index: 3; }

/* Ajustes do grid: evita que a coluna direita fique apertada */
#lojaDetModal .loja-det-grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 420px); /* coluna direita com min width */
  gap: 18px;
  align-items: start; /* evita empurrões estranhos */

  padding: 18px;
}

/* Reduz a moldura da área da imagem e aumenta ligeiramente a imagem para preencher */
#lojaDetModal .loja-det-media{
  padding: 6px; /* menor moldura */
  min-height: 220px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(180deg, rgba(245,247,255,0.6), rgba(255,255,255,0.9));
  border-radius: 12px;
  border: 1px solid rgba(230,235,255,0.6);
}

#lojaDetModal #lojaDetImg{
  height: 180px;       /* imagem maior para preencher, mas controlada */
  width: auto;
  max-width: 100%;
  object-fit: contain;
}

/* Right column (card) garante espaçamento e largura mínima maior */
#lojaDetModal .loja-det-buy{
  min-width: 360px;
  padding: 16px;
}

/* Header: botão X como icon button circular */
#lojaDetModal #btnLojaDetFechar{
  width: 40px; height: 40px; padding: 0; border-radius: 999px;
  display:inline-grid; place-items:center; border:1px solid transparent; background: rgba(0,0,0,0.04);
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}

#lojaDetModal #btnLojaDetFechar:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(2,6,23,0.08);
  background: rgba(0,0,0,0.06);
}

/* Meta mais discreta */
#lojaDetModal #lojaDetMeta{ font-size:12px; opacity:.6; text-transform:uppercase; letter-spacing:.04em; }

/* Linha divisória elegante abaixo do header */
#lojaDetModal .loja-det-head{ border-bottom: 1px solid rgba(15,23,42,0.06); padding: 14px 18px; }

/* Cores: bolinhas premium com anel duplo e tooltip */
#lojaDetModal .loja-color-list{ display:flex; gap:10px; align-items:center; }

#lojaDetModal .loja-color-dot,
#lojaDetModal .loja-cor-dot{
  width: 30px; height: 30px; border-radius:50%; position:relative; cursor:pointer;
  border: 2px solid rgba(255,255,255,0.8); box-shadow: 0 6px 18px rgba(2,6,23,0.08);
}

#lojaDetModal .loja-color-dot.is-on,
#lojaDetModal .loja-cor-dot.is-active{
  outline: 3px solid rgba(31,75,255,0.12); /* anel externo */
  box-shadow: 0 8px 26px rgba(31,75,255,0.12), 0 0 0 4px rgba(255,255,255,0.6) inset;
}

#lojaDetModal .loja-color-dot.is-on::after,
#lojaDetModal .loja-cor-dot.is-active::after{
  content: '✓'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#07207a; font-weight:800; font-size:14px;
}

/* tooltip com nome da cor (se o JS adicionar title="Nome") */
#lojaDetModal .loja-color-dot[title]:hover::before,
#lojaDetModal .loja-cor-dot[title]:hover::before{
  content: attr(title);
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  background: rgba(15,23,42,0.9); color:#fff; padding:6px 8px; border-radius:6px; font-size:12px; white-space:nowrap; z-index:4;
}

/* Botão CTA: leve reforço visual */
#lojaDetModal #btnLojaDetAdd{
  background: linear-gradient(135deg, #1e4ff3, #1d6ef0);
  box-shadow: 0 10px 28px rgba(29,78,216,0.18);
  border-radius: 12px; padding: 12px 16px; color:#fff; border:none; font-weight:700;
}

#lojaDetModal #btnLojaDetAdd:hover{ transform: translateY(-1px); box-shadow: 0 18px 40px rgba(29,78,216,0.22); }
#lojaDetModal #btnLojaDetAdd:active{ transform: translateY(0); box-shadow: 0 6px 18px rgba(29,78,216,0.16); }

/* Descrição: leitura melhorada */
#lojaDetModal .loja-det-desc{ background: #f6f9fc; padding: 16px; margin: 12px 18px 18px; border-radius: 12px; border: 1px solid rgba(15,23,42,0.04); }
#lojaDetModal .loja-det-desc-text{ line-height:1.7; color: #0f172a; }

/* Responsivo: ajustar colunas e tamanhos */
@media (max-width: 900px){
  #lojaDetModal.loja-det-modal{ width: calc(100vw - 24px); left:50%; transform: translate(-50%, -50%); }
  #lojaDetModal .loja-det-grid{ grid-template-columns: 1fr; padding: 12px; }
  #lojaDetModal #lojaDetImg{ height: 120px; }
  #lojaDetModal .loja-det-media{ min-height: 140px; }
  #lojaDetModal .loja-det-buy{ min-width: auto; }
}


/* Grid com proporção mais premium */
#lojaDetModal .loja-det-grid{
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 0.75fr);
  gap: 18px;
}

/* Área da imagem mais “galeria” */
#lojaDetModal .loja-det-media{
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,0.06);
  box-shadow: 0 18px 42px rgba(15,23,42,0.08);
  background: #f8fafc;
}

/* Imagem maior e bem centralizada (sobrescreve outras declarações) */
#lojaDetModal #lojaDetImg{
  height: 420px;
  object-fit: contain;
}

/* Chips de tamanho: mais consistentes e com estado forte */
#lojaDetModal .loja-size-list{
  gap: 10px;
}

#lojaDetModal .loja-size-pill{
  border-radius: 12px;
  padding: 9px 14px;
  min-width: 54px;
  letter-spacing: .02em;
}

#lojaDetModal .loja-size-pill:hover{
  transform: translateY(-1px);
}

#lojaDetModal .loja-size-pill.is-on{
  box-shadow: 0 10px 24px rgba(29,78,216,0.18);
}

/* Accordion mais sofisticado: hover + ativo + ícone girando */
#lojaDetModal .loja-acc-item{
  transition: background .14s ease, transform .14s ease;
}

#lojaDetModal .loja-acc-item:hover{
  background: rgba(29,78,216,0.04);
}

#lojaDetModal .loja-acc-item.is-open{
  background: rgba(29,78,216,0.06);
}

#lojaDetModal .loja-acc-item .acc-ico{
  transition: transform .16s ease;
}

#lojaDetModal .loja-acc-item.is-open .acc-ico{
  transform: rotate(180deg);
}

/* Focus ring no botão Adicionar ao carrinho (acessibilidade premium) */
#btnLojaDetAdd:focus{
  outline: none;
  box-shadow: 0 0 0 4px rgba(29,78,216,0.22), 0 16px 36px rgba(37,99,235,0.18);
}

/* Overlay do detalhe (somente Loja) */
#lojaDetOverlay.modal-overlay{
  background: rgba(2,6,23,0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

/* Base de posicionamento e scroll do modal consolidada em
   "LOJA — MODAL DETALHE" no início do arquivo. Evita regras
   conflitantes espalhadas pelo CSS. */

/* Imagem responsiva por breakpoint (sobrescreve regras anteriores) */
#lojaDetModal #lojaDetImg,
.loja-det-modal #lojaDetImg{
  height: 420px;
  object-fit: contain;
}

@media (max-width: 1200px){
  #lojaDetModal #lojaDetImg,
  .loja-det-modal #lojaDetImg{
    height: 320px;
  }
}

@media (max-width: 900px){
  #lojaDetModal #lojaDetImg,
  .loja-det-modal #lojaDetImg{
    height: 180px;
  }
}

/* Modal */
#lojaDetModal.loja-det-modal{
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 30px 70px rgba(2,6,23,.22);
  overflow: hidden; /* mantém cantos arredondados no scroll */
}

/* Cabeçalho (título + fechar) */
#lojaDetModal .loja-det-head{
  position: sticky;
  top: 0;
  z-index: 3;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15,23,42,.08);
}

/* Corrige o “Fechar” esticado */
#lojaDetModal #btnLojaDetFechar.btn{
  width: auto;
  min-width: 44px;
  padding: 10px 12px;
  border-radius: 12px;
}

/* Título/meta */
#lojaDetModal #lojaDetNome{ font-size: 20px; line-height: 1.15; }
#lojaDetModal #lojaDetMeta{ font-size: 12px; opacity: .75; }

/* Grid (imagem + compra) */
#lojaDetModal .loja-det-grid{
  padding: 16px 18px 6px;
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
  gap: 16px;
  align-items: start;
}

/* Coluna da imagem (HTML usa .loja-det-media) */
#lojaDetModal .loja-det-media{
  background: linear-gradient(180deg, #f5f7ff 0%, #ffffff 70%);
  border: 1px solid #e7ebff;
  border-radius: 14px;
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 420px;
}

#lojaDetModal #lojaDetImg{
  height: 380px; /* um pouco maior que o atual */
  width: 100%;
  max-width: 100%;
  object-fit: contain;
  border-radius: 12px;
  background: #fff;
}

/* Card de compra */
#lojaDetModal .loja-det-buy{
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 14px;
  padding: 14px;
  box-shadow: 0 10px 25px rgba(2,6,23,.10);
}

#lojaDetModal .loja-det-preco b{ font-size: 22px; }
#lojaDetModal .loja-det-preco .muted{ font-size: 12px; }

/* Lista de cores */
#lojaDetModal .loja-color-list{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 8px;
}

/* Suporta os 2 nomes que podem existir no seu JS (loja-color-dot e loja-cor-dot) */
#lojaDetModal .loja-color-dot,
#lojaDetModal .loja-cor-dot{
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid rgba(0,0,0,.15);
  cursor: pointer;
  position: relative;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease, opacity .12s ease;
}

#lojaDetModal .loja-color-dot:hover,
#lojaDetModal .loja-cor-dot:hover{ transform: scale(1.05); }

#lojaDetModal .loja-color-dot.is-on,
#lojaDetModal .loja-cor-dot.is-active{
  border-color: #1f4bff;
  box-shadow: 0 0 0 4px rgba(31,75,255,.15);
}

#lojaDetModal .loja-color-dot.is-off,
#lojaDetModal .loja-cor-dot.is-disabled{
  opacity: .35;
  pointer-events: none;
}

/* Quantidade */
#lojaDetModal .loja-qty-ctrl{
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 8px;
}

#lojaDetModal #lojaDetQtd.ctrl{
  width: 72px;
  text-align: center;
}

/* Descrição */
#lojaDetModal .loja-det-desc{
  margin: 10px 18px 18px;
  padding: 14px 16px;
  border-radius: 14px;
  background: #f8fafc;
  border: 1px solid rgba(15,23,42,.06);
}

#lojaDetModal .loja-det-desc-text{
  font-size: 14px;
  line-height: 1.6;
  color: #0f172a;
}

/* Responsivo */
@media (max-width: 900px){
  #lojaDetModal .loja-det-grid{ grid-template-columns: 1fr; }
  #lojaDetModal .loja-det-media{ min-height: 340px; }
  #lojaDetModal #lojaDetImg{ height: 300px; }
}


/* =========================================================
   LOJA UI v2 — Design System + Grid/Cards padrão e-commerce
   (Somente Loja: tudo deve estar dentro de #loja ...)
   ========================================================= */
#loja{
  --loja-primary: #1d4ed8;
  --loja-bg: linear-gradient(180deg, #f4f7fb 0%, #eef3fb 100%);
  --loja-surface: #ffffff;
  --loja-surface-2: #f2f6ff;
  --loja-border: #e2e8f0;
  --loja-border-strong: #cbd5e1;
  --loja-text: #0f172a;
  --loja-muted: #475569;
  --loja-radius: 14px;
  --loja-radius-sm: 10px;
  --loja-shadow: 0 10px 28px rgba(15,23,42,0.06);
  --loja-shadow-hover: 0 18px 42px rgba(15,23,42,0.12);
  background: var(--loja-bg);
  color: var(--loja-text);
}

/* Toolbar alinhada e com ring azul no foco */
#loja .store-toolbar{
  display:grid;
  grid-template-columns: 0.6fr 0.3fr 0.1fr;
  gap:12px;
  align-items:end;
  margin:10px 0 16px;
}
@media (max-width:1080px){ #loja .store-toolbar{ grid-template-columns: 1fr 1fr; } }
@media (max-width:820px){ #loja .store-toolbar{ grid-template-columns: 1fr; } }
#loja .store-search-block,
#loja .store-filter-block{ display:flex; flex-direction:column; gap:6px; }
#loja .store-toolbar .ctrl,
#loja .store-toolbar input,
#loja .store-toolbar select,
#loja .store-toolbar .btn{
  height:44px;
  border-radius:12px;
  border:1px solid var(--loja-border);
  background: var(--loja-surface);
  transition: box-shadow .16s ease, border-color .16s ease, transform .12s ease;
}
#loja .store-toolbar .ctrl:focus,
#loja .store-toolbar input:focus,
#loja .store-toolbar select:focus,
#loja .store-toolbar .btn:focus-visible{
  outline:none;
  border-color: color-mix(in srgb, var(--loja-primary) 38%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--loja-primary) 18%, transparent);
}
#loja .store-toolbar .btn{ padding:0 14px; display:inline-flex; align-items:center; justify-content:center; gap:6px; font-weight:700; }
#loja .store-toolbar-actions{ display:flex; flex-direction:column; gap:6px; align-items:flex-end; }
#loja .store-toolbar-actions-main{ display:flex; flex-wrap:wrap; gap:8px; justify-content:flex-end; align-items:center; }
#loja .store-toolbar-actions-main .btn{ height:38px; padding:0 12px; }
#loja .store-toolbar-toggles{ display:flex; flex-wrap:wrap; gap:6px; justify-content:flex-end; }
#loja .store-toolbar-toggles .pill{ background:#f8fafc; border:1px solid var(--loja-border); padding:4px 10px; font-weight:600; }

/* Loja: grid com cards padronizados (não estica quando tem 1 item) */
#loja .store-grid{
  display: grid;
  gap: 16px;

  /* min = 260px | max = 340px (não vira 100% da tela) */
  grid-template-columns: repeat(auto-fill, minmax(260px, 340px));

  /* escolha 1: start (fica alinhado à esquerda) */
  justify-content: start;

  /* escolha 2: center (fica centralizado quando tem 1 item) */
  /* justify-content: center; */
}

/* segurança extra (opcional) */
#loja .store-card{
  width: 100%;
  max-width: 340px;
}

/* Cards padrão e-commerce */
#loja .store-card{
  background: var(--loja-surface);
  border:1px solid var(--loja-border);
  border-radius: var(--loja-radius);
  box-shadow: var(--loja-shadow);
  display:flex;
  flex-direction:column;
  min-height:100%;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
#loja .store-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--loja-shadow-hover);
  border-color: color-mix(in srgb, var(--loja-primary) 24%, var(--loja-border));
}
#loja .store-card .img{
  height:180px;
  aspect-ratio: 4 / 3;
  background: var(--loja-surface-2);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px;
}
#loja .store-card .img img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
#loja .store-card .body{
  padding:12px 14px 14px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}
#loja .store-card .title{
  font-weight:800;
  color: var(--loja-text);
  line-height:1.25;
  display:-webkit-box;
  line-clamp:2;
  -webkit-line-clamp:2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
#loja .store-card .meta{ display:flex; flex-wrap:wrap; gap:6px; color: var(--loja-muted); font-size:12px; }
#loja .store-card .price{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; }
#loja .store-card .price b{ font-size:18px; color: var(--loja-text); letter-spacing:-0.02em; }
#loja .store-card .price .muted{ color: var(--loja-muted); font-size:12px; }
#loja .store-card .actions{ display:flex; gap:8px; margin-top:auto; }
#loja .store-card .actions .btn{ flex:1; height:44px; }

/* Modal de cadastro/edição (grid 2 col) */
#lojaProdModal .loja-prod-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap:12px;
}
#lojaProdModal .loja-prod-desc{ display:flex; flex-direction:column; gap:10px; margin-top:12px; }
#lojaProdModal .loja-prod-footer{ display:flex; gap:10px; justify-content:flex-end; margin-top:14px; border-top:1px solid var(--loja-border); padding-top:12px; }
#lojaProdModal .loja-var-wrap{ margin-top:12px; display:flex; flex-direction:column; gap:10px; }
#lojaProdModal .loja-var-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; }
#lojaProdModal .loja-var-list{ display:flex; flex-direction:column; gap:10px; }
#lojaProdModal .loja-var-row{
  display:grid;
  grid-template-columns:
    minmax(160px, 1.2fr)
    90px
    minmax(120px, .9fr)
    minmax(110px, .8fr)
    100px
    minmax(220px, 1fr)
    auto;
  gap:10px;
  align-items:center;
  border:1px solid var(--loja-border);
  border-radius:12px;
  padding:10px;
  background: #f8fafc;
}
#lojaProdModal .loja-var-img{ display:flex; flex-direction:column; gap:6px; }
#lojaProdModal .loja-var-preview{ width:64px; height:64px; border:1px dashed var(--loja-border); border-radius:12px; display:flex; align-items:center; justify-content:center; overflow:hidden; background:#fff; }
#lojaProdModal .loja-var-preview.is-on{ border-style:solid; }
#lojaProdModal .loja-var-preview img{ width:100%; height:100%; object-fit:contain; display:block; }
@media (max-width:840px){
  #lojaProdModal .loja-var-row{ grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }
}

/* LOJA — Modal de edição maior (sem scroll lateral) */
#lojaProdModal.loja-prod-modal-xl{
  width: min(1180px, 96vw);
  max-height: 92vh;
  overflow-y: auto;
  overflow-x: hidden;
}

/* Mobile/pequenas telas: vira praticamente tela cheia */
@media (max-width: 820px){
  #lojaProdModal.loja-prod-modal-xl{
    width: 96vw;
    max-height: calc(100vh - 24px);
    top: 12px;
    transform: translate(-50%, 0);
  }
}
@media (max-width: 560px){
  #lojaProdModal.loja-prod-modal-xl{
    inset: 0;
    left: 0;
    top: 0;
    transform: none;
    width: 100vw;
    max-height: 100vh;
    border-radius: 0;
  }
}

/* Importantíssimo para Grid não “estourar” e criar scroll horizontal */
#lojaProdModal .loja-prod-grid > div,
#lojaProdModal .loja-var-row > *{
  min-width: 0;
}

/* File input costuma estourar largura */
#lojaProdModal input[type="file"]{
  max-width: 100%;
  width: 100%;
}

#lojaProdModal .loja-img-box{ grid-column: 1 / -1; }

#lojaProdModal .loja-var-color{ display:flex; align-items:center; gap:10px; }
#lojaProdModal .loja-var-dot{
  width:18px;
  height:18px;
  border-radius:999px;
  border:2px solid #fff;
  box-shadow:0 6px 18px rgba(2,6,23,0.10);
  outline:1px solid rgba(15,23,42,0.10);
}
#lojaProdModal .loja-var-color input[type="color"]{
  width:42px;
  height:38px;
  padding:0;
  border:none;
  background:transparent;
  cursor:pointer;
}
#lojaProdModal .loja-var-color input[type="color"]::-webkit-color-swatch-wrapper{ padding:0; }
#lojaProdModal .loja-var-color input[type="color"]::-webkit-color-swatch{
  border:none;
  border-radius:12px;
}

#lojaProdModal .loja-var-actions{ display:flex; gap:6px; justify-content:flex-end; }
#lojaProdModal .loja-var-actions .btn{ height:34px; padding:0 10px; }

/* Pills discretas e focadas no azul */
#loja .pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 10px;
  border-radius:999px;
  background: color-mix(in srgb, var(--loja-primary) 10%, #fff);
  color: color-mix(in srgb, var(--loja-primary) 75%, #0f172a);
  border:1px solid color-mix(in srgb, var(--loja-primary) 18%, var(--loja-border));
  font-weight:700;
  font-size:12px;
}
#loja .pill--ghost{
  background: #f8fafc;
  color: var(--loja-text);
  border:1px solid var(--loja-border);
}

/* Botões com hierarquia: primário e outline para Editar */
#loja .btn{
  border-radius: var(--loja-radius-sm);
  border:1px solid transparent;
  font-weight:700;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease, color .16s ease;
}
#loja .btn.btn-primary{
  background:#0f2c82;
  border-color:#0f2c82;
  color:#fff;
  box-shadow: 0 12px 28px rgba(15,23,42,0.18);
}
#loja .btn.btn-primary:hover{ filter:brightness(1.03); transform: translateY(-1px); }
#loja .btn.btn-secondary{
  background: transparent;
  border:1px solid #e5e7eb;
  color: #475569;
  box-shadow: none;
}
#loja .btn.btn-secondary:hover{
  border-color: #d6dae3;
  box-shadow: 0 0 0 3px rgba(15,23,42,0.06);
  transform: translateY(-1px);
}
#loja .loja-cart-ico{ font-size:16px; line-height:1; }
#loja .loja-add-ico{ font-size:16px; line-height:1; margin-right:6px; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
#loja .btn:focus-visible{
  outline:none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--loja-primary) 18%, transparent);
}


#loja .btn.btn--sm{ height:32px; min-width:32px; padding:0 8px; border-radius:10px; }
#loja .btn.btn--sm i{ width:16px; height:16px; stroke-width:2.2; }
#loja .loja-header{
  position:relative;
  background:#fff;
  border:1px solid #e6edf7;
  border-radius:16px;
  padding:10px 12px;
  box-shadow:0 10px 25px rgba(15,23,42,.06);
  display:flex;
  align-items:center;
  gap:12px;
}
#loja .loja-head-left h3{
  margin:0;
  font-size:22px;
  letter-spacing:-0.01em;
}
#loja .loja-head-left .store-subtitle{
  margin:2px 0 0;
  font-size:12px;
  color: color-mix(in srgb, var(--loja-muted) 72%, #94a3b8);
}
#loja .loja-head-left{ width:100%; padding-right:0; }

/* Toolbar premium: ícones compactos no canto superior direito */
#loja .loja-actions{
  position:static;
  display:flex;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
}
#loja .loja-actions .btn{
  width:36px;
  height:36px;
  min-width:36px;
  padding:0;
  border-radius:10px;
  border:1px solid #e6edf7;
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#4b5a78;
  box-shadow:none;
  transition: background .16s ease, border-color .16s ease, transform .12s ease;
}
#loja .loja-actions .btn:hover{
  background:#f3f7ff;
  border-color:#c7d8ff;
  color:#1d4ed8;
  transform: translateY(-1px);
}
#loja .loja-actions .btn:active{ transform: translateY(0); }
#loja .loja-actions .btn i svg{ width:18px; height:18px; stroke-width:2; stroke:currentColor; fill:none; }

#loja #btnLojaNovoProduto,
#loja #btnLojaEscolherEditar,
#loja #btnLojaVerPedidos,
#loja #btnLojaConferencia,
#loja #btnLojaAbrirCarrinho{
  background:#fff;
  color:#4b5a78;
  border-color:#e6edf7;
}
#loja #btnLojaAbrirCarrinho{
  position:relative;
  border:1px solid #d9def0;
}
#loja #lojaCartCount{
  position:absolute;
  top:-4px;
  right:-4px;
  min-width:18px;
  height:18px;
  padding:0;
  background:#1d4ed8;
  color:#fff;
  font-weight:700;
  font-size:11px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:none;
}
#loja .loja-topnav .store-topnav-btn:hover{
  background: #eff5ff;
  color:#1d4ed8;
}
#loja .loja-topnav .store-topnav-btn.active,
#loja .loja-topnav .loja-topitem.active{
  background: #e7f0ff;
  color: #0f2c82;
  border-color: #cfe0ff;
  box-shadow: 0 10px 20px rgba(37,99,235,0.12);
}

/* Barra de filtros compacta, busca protagonista */
#loja .store-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  margin: 4px 0 10px;
}
#loja .store-toolbar .store-search-block{ order:1; }
#loja .store-toolbar .loja-actions{ order:2; margin-left:auto; }
#loja .store-search-block{
  position:relative;
  width:50%;
  min-width:260px;
  max-width:520px;
}
#loja .store-search-bar{
  display:flex;
  align-items:center;
  background:#fff;
  border:1px solid #e6edf7;
  border-radius:12px;
  box-shadow: 0 8px 18px rgba(15,23,42,0.05);
  overflow:hidden;
}
#loja .store-search-btn i{ width:18px; height:18px; stroke-width:2; }
#loja .store-filter-block{ display:none; }
#loja .store-search-block .ctrl{
  flex:1;
  padding:12px 14px;
  font-size:14px;
  border:none;
  background:transparent;
  color: var(--loja-text);
  outline:none;
}
#loja .store-search-block .ctrl::placeholder{ color:#94a3b8; }
#loja .store-search-btn{
  width:48px;
  height:100%;
  border-left:1px solid #e6edf7;
  border:none;
  background:#f7f9ff;
  color:#4b5a78;
  display:grid;
  place-items:center;
  font-size:18px;
  cursor:pointer;
  transition: background .12s ease, transform .12s ease, color .12s ease;
}
#loja .store-search-btn:hover{ background:#eef3ff; color:#1d4ed8; transform:translateY(-0.5px); }
#loja .store-search-btn:active{ transform:translateY(0); }
#loja .store-search-block::before{ content:none; }
#loja .store-filter-block .ctrl{
  font-size:13px;
  padding-left:12px;
  background:#fff;
}
#loja .store-hint{ display:none; }
#loja .store-label{
  font-size:12px;
  color: color-mix(in srgb, var(--loja-text) 68%, #475569);
  font-weight:700;
}
#loja .store-label--sr{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip: rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* Atalhos laterais leves (Meus pedidos / Conferência / Editar) */
#loja .store-toolbar-actions-main{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
  width:100%;
}
#loja .store-toolbar-actions-main .btn{
  background:#fff;
  border:1px solid color-mix(in srgb, var(--loja-primary) 10%, var(--loja-border));
  border-radius:10px;
  height:34px;
  padding:0 12px;
  box-shadow: 0 8px 18px rgba(2,6,23,0.06);
  gap:6px;
}
#btnLojaVerPedidos::before,
#btnLojaConferencia::before,
#btnLojaEscolherEditar::before{
  content:none;
}
#loja .store-toolbar-actions-main .btn::before{
  content:none;
}
#loja .store-toolbar-toggles{ display:flex; gap:6px; flex-wrap:wrap; justify-content:flex-end; }
#loja .store-toolbar-toggles .pill{
  background: #eef2ff;
  border:1px solid #d7e3ff;
  color:#1d4ed8;
  font-weight:700;
  padding:4px 10px;
}

/* Grid e cards mais hierarquizados */
#loja .store-card{
  border-radius:16px;
  border:1px solid color-mix(in srgb, var(--loja-primary) 6%, var(--loja-border));
  box-shadow: 0 14px 28px rgba(2,6,23,0.08);
}
#loja .store-card .img{
  height:210px;
  background: linear-gradient(180deg, #f6f8ff 0%, #eef3ff 100%);
  padding:12px;
}
#loja .store-card .body{
  padding:12px 14px 14px;
  gap:12px;
}
#loja .store-card-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
#loja .store-card-title-wrap .title{
  font-size:15px;
  line-height:1.25;
  min-height: 2.6em;
  display:-webkit-box;
  line-clamp:2;
  -webkit-line-clamp:2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
#loja .store-card-desc{
  font-size:12px;
  color: color-mix(in srgb, var(--loja-muted) 70%, #6b7280);
  margin-top:2px;
  display:-webkit-box;
  line-clamp:2;
  -webkit-line-clamp:2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
#loja .store-card-cat{
  background:#f3f6ff;
  border:1px solid #dbe7ff;
  color:#123072;
  font-weight:700;
}
#loja .store-card .meta-line{
  font-size:12px;
  color: color-mix(in srgb, var(--loja-muted) 72%, #6b7280);
}
#loja .store-card-colors{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
#loja .store-card-colors::before{
  content:"Cores";
  font-size:11px;
  color: color-mix(in srgb, var(--loja-muted) 68%, #6b7280);
  margin-right:2px;
}
#loja .store-card-colors .color-dot{
  width:18px;
  height:18px;
  border-radius:999px;
  border:2px solid #fff;
  box-shadow: 0 6px 16px rgba(15,23,42,0.10), inset 0 0 0 1px rgba(15,23,42,0.06);
}
#loja .store-card-colors .color-dot--more{
  background: #e2e8f0;
  color:#0f172a;
  font-weight:800;
  font-size:11px;
  display:inline-grid;
  place-items:center;
}
#loja .store-card .price{
  align-items:center;
  gap:6px;
}
#loja .price-aux{
  font-size:12px;
  color: color-mix(in srgb, var(--loja-muted) 70%, #475569);
}
#loja .store-card-price{ font-size:20px; letter-spacing:-0.01em; }
#loja .store-card .actions .btn{
  height:40px;
  border-radius:11px;
  border:1px solid color-mix(in srgb, var(--loja-primary) 12%, transparent);
}


/* =====================================================
   Loja — detalhe do produto (refino visual)
   ===================================================== */
#lojaDetModal, .loja-det-modal{
  max-height: 90vh;
  width: min(1180px, calc(100vw - 24px));
  box-shadow: 0 26px 70px rgba(2,6,23,0.16);
}

#lojaDetModal .loja-det-inner{
  padding: 26px 28px 28px 28px !important;
  gap: 16px;
  background: radial-gradient(circle at 12% 14%, #f3f6ff 0, #ffffff 46%), #fff;
  overflow: hidden !important;
}

#lojaDetModal .loja-det-body{
  overflow: auto !important;
  overflow-x: hidden;
}

#lojaDetModal .loja-det-grid{
  display: flex;
  align-items: stretch; /* blocos com mesma altura */
  gap: 16px;
  max-height: 100%;
}

#lojaDetModal .loja-det-grid > *{ min-width:0; }

#lojaDetModal .loja-det-media,
#lojaDetModal .loja-det-buy{
  flex: 1;
  max-width: 50%;
  min-height: 320px;
  padding: 14px;
  max-height: none;
  overflow: visible;
}

@media (max-width: 1024px){
  #lojaDetModal .loja-det-grid{ flex-direction: column; }
  #lojaDetModal .loja-det-media,
  #lojaDetModal .loja-det-buy{
    max-width: 100%;
    min-height: auto;
    max-height: none;
  }
  #lojaDetModal .loja-det-buy{ position: relative; top: 0; }
}

/* Galeria: thumbs à esquerda + imagem grande à direita */
#lojaDetModal .loja-det-media{
  padding: 16px;
  border-radius: 16px;
  border: 1px solid #e6e9ef;
  background: radial-gradient(circle at 18% 20%, #f5f8ff 0, #ffffff 55%, #f8fafc 100%);
  box-shadow: 0 18px 40px rgba(2,6,23,0.10);
  display: block;
}

/* grid interno */
#lojaDetModal .loja-det-gallery{
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}

/* estado com apenas 1 imagem: some thumbs e usa 1 coluna */
#lojaDetModal .loja-det-gallery.is-single{
  grid-template-columns: 1fr !important;
}

#lojaDetModal .loja-det-gallery.is-single .loja-det-thumbs{
  display: none !important;
}

/* coluna das thumbs (vertical) */
#lojaDetModal .loja-det-thumbs{
  margin-top: 0;           /* remove o espaçamento de “abaixo da imagem” */
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow-y: visible;
  overflow-x: visible;      /* evita rolagem interna */
  padding-right: 4px;
}

/* miniaturas */
#lojaDetModal .loja-det-thumbs .loja-thumb{
  width: 76px;
  height: 76px;
  border-radius: 12px;
  border: 1px solid #e6e9ef;
  background: #fff;
  box-shadow: 0 10px 22px rgba(15,23,42,0.10);
  flex: 0 0 auto;
}

/* área da imagem principal */
#lojaDetModal .loja-det-mainimg{
  width: 100%;
  height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,0.06);
  overflow: hidden;
}

#lojaDetModal .loja-det-mainimg img{
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Responsivo: thumbs abaixo em linha no mobile */
@media (max-width: 900px){
  #lojaDetModal .loja-det-gallery{
    grid-template-columns: 1fr;
  }

  #lojaDetModal .loja-det-thumbs{
    flex-direction: row;
    max-height: none;
    overflow-x: auto;
    overflow-y: hidden;
    padding-right: 0;
    padding-bottom: 4px;
    order: 2;
  }

  #lojaDetModal .loja-det-mainimg{
    height: 200px;
    order: 1;
  }
}

/* Card de compra mais compacto e aderente */
#lojaDetModal .loja-det-buy{
  gap: 14px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid #e6e9ef;
  border-top: 3px solid #1d4ed8;
  background: #fff;
  box-shadow: 0 18px 42px rgba(15,23,42,0.12);
}

#lojaDetModal .loja-det-preco{ gap: 6px; }
#lojaDetModal .loja-det-price-line{ display: flex; align-items: baseline; gap: 8px; }
#lojaDetModal .loja-price-curr{ font-size: 13px; font-weight: 700; color: #64748b; }
#lojaDetModal .loja-price-amt{ font-size: 32px; font-weight: 900; color: #0f172a; letter-spacing: -0.02em; }

/* Tamanhos em pills com estado destacado */
#lojaDetModal .loja-det-sizes{ gap: 10px; }
#lojaDetModal .loja-size-list{ display: grid; grid-template-columns: repeat(auto-fit, minmax(88px, 1fr)); gap: 10px; }
#lojaDetModal .loja-size-list .loja-size-pill{
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,0.14);
  background: #fff;
  font-weight: 800;
}
#lojaDetModal .loja-size-list .loja-size-pill.is-on{
  background: #eaf1ff;
  border-color: #1d4ed8;
  color: #0b3a9b;
  box-shadow: 0 12px 26px rgba(37,99,235,0.16);
}

/* Controle de quantidade mais limpo */
#lojaDetModal .loja-det-qty .loja-qty-ctrl{ gap: 10px; }
#lojaDetModal .loja-qty-ctrl input{
  height: 42px;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  font-weight: 800;
}
#lojaDetModal .loja-qty-ctrl--pill button{
  width: 42px;
  height: 42px;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  font-weight: 800;
}

/* CTA mais proeminente */
#lojaDetModal .loja-det-cta{
  height: 52px;
  font-weight: 800;
  font-size: 15px;
  letter-spacing: 0.01em;
  border: none;
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  box-shadow: 0 14px 30px rgba(37,99,235,0.25);
}

/* Accordion mais legível */
#lojaDetModal .loja-det-accordion{ border-radius: 14px; overflow: hidden; border: 1px solid #e6e9ef; }
#lojaDetModal .det-acc-item{ background: #fff; }
#lojaDetModal .det-acc-header{ padding: 16px 18px; font-weight: 800; color: #0f172a; }
#lojaDetModal .det-acc-body{
  padding: 0 18px 18px 18px;
  background: #fbfdff;
  color: #334155;
  line-height: 1.6;
}

/* Barra mobile mais agradável */
#lojaDetModal .loja-det-mobilebar{
  padding: 12px 16px;
  gap: 10px;
  box-shadow: 0 -8px 24px rgba(15,23,42,0.14);
}
#lojaDetModal .loja-det-mobile-price{ font-weight: 900; font-size: 18px; color: #0f172a; }

/* ===== Detalhe do produto: remover faixa branca do topo e barra inferior ===== */
#lojaDetModal { position: fixed; }

/* tira o bloco do header e deixa o X flutuando */
#lojaDetModal .loja-det-head{
  background: transparent !important;
  border-bottom: 0 !important;
  padding: 0 !important;
}

#lojaDetModal .loja-det-close{
  position: absolute !important;
  top: 12px;
  right: 12px;
  z-index: 50;
}

/* Remove a barra inferior (preço + adicionar) do detalhe por padrão */
#lojaDetMobileBar {
  display: none !important;
  box-shadow: none !important;
}

/* Se for mostrada via JS em telas pequenas */
#lojaDetMobileBar.is-on {
  display: flex !important;
  box-shadow: 0 -2px 8px rgba(0,0,0,0.12) !important;
}


/* =========================
   PATCH PREMIUM — Vencimentos (KPIs)
   Cole no FINAL do style.css
   ========================= */
#vencimentos .venc-kpis{
  gap: 14px;
  margin: 14px 0 10px;
}

#vencimentos .kpi{
  padding: 16px 16px;
  border-radius: 16px;
  border: 1px solid rgba(226,232,240,0.95);
  box-shadow: 0 10px 22px rgba(15,23,42,0.06);
  gap: 12px;
}

#vencimentos .kpi:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(15,23,42,0.10);
}

#vencimentos .kpi-icon{
  width: 36px;
  height: 36px;
  border-radius: 12px;
}

#vencimentos .kpi-label{
  font-size: 12px;
  letter-spacing: .2px;
  color: #475569;
  margin-bottom: 2px;
}

#vencimentos .kpi-value{
  font-size: 28px;
  letter-spacing: -0.02em;
}

/* Estoque: ícones de traço (feather) alinhados */
#estoque .search-ico svg{ width:16px; height:16px; }
#estoque .icon-btn-blue svg{ width:18px; height:18px; display:block; }

/* ===== ESTOQUE: tabela premium ===== */
#estoqueConteudo .table-wrap{
  overflow:auto;
  border-radius: 14px;
  border: 1px solid #eef2f7;
}

#estoqueConteudo .table-epi{
  width:100%;
  border-collapse: separate;
  border-spacing: 0;
}

#estoqueConteudo .table-epi thead th{
  position: sticky;
  top: 0;
  z-index: 1;
  background: #f8fafc;
  font-size: 12px;
  letter-spacing: .02em;
  text-transform: none;
  color: #334155;
  padding: 12px 14px;
  border-bottom: 1px solid #eef2f7;
}

#estoqueConteudo .table-epi tbody td{
  padding: 12px 14px;
  border-bottom: 1px solid #f1f5f9;
  font-size: 13px;
  color:#0f172a;
}

#estoqueConteudo .table-epi tbody tr:nth-child(even){
  background: #fcfdff;
}

#estoqueConteudo .table-epi tbody tr:hover{
  background: #f3f8ff;
}

#estoqueConteudo .table-epi td.mono{
  font-variant-numeric: tabular-nums;
}

/* Stepper de quantidade (visual premium) */
#estoqueConteudo td .btn.btn--sm{
  width: 30px;
  height: 30px;
  padding: 0;
  border-radius: 10px;
  border: 1px solid #dbeafe;
  background: #ffffff;
  color: #2563eb;
  display: inline-flex;
  align-items:center;
  justify-content:center;
}

#estoqueConteudo td .btn.btn--sm:hover{
  background:#eff6ff;
}

#estoqueConteudo td input.ctrl{
  height: 30px;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  text-align: center;
  font-variant-numeric: tabular-nums;
}


/* =========================================================
   SIDEBAR PREMIUM AGRUPADA + MINI HOVER
========================================================= */
:root{
  --sb-collapsed: 72px;
  --sb-expanded: 234px;
  --sb-bg: #0b1224;
  --sb-border: rgba(255,255,255,0.05);
  --sb-text: #e2e8f0;
  --sb-muted: #94a3b8;
  --sb-active: #38bdf8;
}

.sidebar{
  width: var(--sb-expanded);
  background: linear-gradient(180deg, #0b1224 0%, #0c152d 45%, #0b1224 100%);
  color: var(--sb-text);
  padding: 8px 8px;
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-right: 1px solid var(--sb-border);
  box-shadow: 8px 0 32px rgba(7,12,24,0.35);
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.sidebar::-webkit-scrollbar{ width:0; height:0; }

.sidebar-groups{ display:flex; flex-direction:column; gap:6px; }
.sidebar-group{ padding: 2px 0; }
.sidebar-label{
  margin: 6px 12px 4px;
  font-size: 10px;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--sb-muted);
  opacity: 0.78;
}
.sidebar-list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:3px; }

.sidebar-item{
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px 8px 14px;
  border-radius: 9px;
  cursor: pointer;
  color: var(--sb-text);
  text-decoration: none;
  transition: background 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

.sidebar-item:hover{ background: rgba(255,255,255,0.04); }

.sidebar-item.active{
  background: rgba(255,255,255,0.06);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.nav-ico{
  width: 28px;
  height: 26px;
  border-radius: 8px;
  display:flex;
  align-items:center;
  justify-content:center;
  color: #fff;
  flex-shrink: 0;
}

.sidebar-item.active .nav-ico{
  background: rgba(56,189,248,0.12);
}

.nav-txt{ flex: 1; min-width: 0; }

/* Só aplica em desktop */
@media (min-width: 881px){
  .sidebar.sidebar--mini{
    position: fixed;
    left: 0;
    top: 0;
    height: 100vh;
    width: var(--sb-collapsed);
    padding: 8px 6px;
    overflow-x: hidden;
    overflow-y: auto;
    z-index: 999;
    transition: width .18s ease, box-shadow .18s ease;
  }

  .sidebar.sidebar--mini:hover{
    width: var(--sb-expanded);
    box-shadow: 0 18px 44px rgba(2,6,23,.35);
  }

  .sidebar.sidebar--mini + .main-content{
    margin-left: var(--sb-collapsed);
  }

  .sidebar.sidebar--mini .sidebar-brand{
    display:flex;
    align-items:center;
    gap:10px;
    padding: 4px 6px 8px;
    margin-bottom: 2px;
  }

  .sidebar.sidebar--mini .sidebar-brand > div{
    opacity: 0;
    transform: translateX(-6px);
    transition: opacity .16s ease, transform .16s ease;
    pointer-events: none;
    white-space: nowrap;
  }

  .sidebar.sidebar--mini:hover .sidebar-brand > div{
    opacity: 1;
    transform: none;
    pointer-events: auto;
  }

  .sidebar.sidebar--mini .sidebar-label{
    opacity: 0;
    height: 0;
    margin: 0;
    transition: opacity .16s ease, height .16s ease, margin .16s ease;
  }

  .sidebar.sidebar--mini:hover .sidebar-label{
    opacity: 0.75;
    height: auto;
    margin: 0 12px 6px;
  }

  .sidebar.sidebar--mini .sidebar-item{
    justify-content: center;
    padding: 9px;
  }

  .sidebar.sidebar--mini .nav-ico{
    margin-right: 0;
    background: transparent;
  }

  /* MINI: sumir imediato ao recolher, entrada suave ao abrir (hover) */
  .sidebar.sidebar--mini:not(:hover) .nav-txt,
  .sidebar.sidebar--mini:not(:hover) .sidebar-label,
  .sidebar.sidebar--mini:not(:hover) .sidebar-brand .brand-text {
    opacity: 0 !important;
    width: 0 !important;
    overflow: hidden !important;
    pointer-events: none !important;
    transform: translateX(-6px) !important;
    transition: none !important; /* sem transição ao recolher (suma instantâneo) */
    white-space: nowrap !important;
  }

  .sidebar.sidebar--mini:hover .nav-txt,
  .sidebar.sidebar--mini:hover .sidebar-label,
  .sidebar.sidebar--mini:hover .sidebar-brand .brand-text {
    opacity: 1 !important;
    width: auto !important;
    transform: none !important;
    pointer-events: auto !important;
    transition: opacity .18s ease, transform .18s ease !important; /* fade/slide in */
    transition-delay: .06s !important; /* pequeno delay antes de aparecer */
    margin-left: -2px !important; /* micro-ajuste opcional */
  }
/* ===== HARD OVERRIDE: empurra o texto para a direita com valor fixo ===== */
/* Use transform translateX para evitar conflitos com width:0 / overflow:hidden */
.sidebar.sidebar--mini:hover .sidebar-item .nav-txt {
  transform: translateX(56px) translateY(4px) !important; /* move o texto 56px para a direita e 4px para baixo */
  margin-left: 0 !important;
  display: inline-block !important;
  width: auto !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transition: transform .16s ease, opacity .12s ease !important;
}

/* Se o HTML tiver a ordem: .nav-ico (absoluto) e depois .nav-txt, garantir espaçamento menor */
.sidebar.sidebar--mini:hover .sidebar-item > .nav-ico + .nav-txt{
    transform: translateX(25px) translateY(1.5px) !important;
  }

/* classe alternativa: quando o menu NÃO usa .sidebar--mini, também aplica um deslocamento menor */
.sidebar:not(.sidebar--mini) .sidebar-item .nav-txt{
  margin-left: 12px !important;
}

}



/* =========================================================
   OVERRIDE FINAL — MENU COMPACTO (IGUAL PRINT ESO)
   Cole no FINAL do style.css
========================================================= */

/* 1) Itens do menu mais baixos, com menos espaço */
.sidebar .sidebar-item{
  height: 34px !important;     /* ↓ compacta como ESO */
  border-radius: 8px !important;
  gap: 8px !important;         /* ícone mais perto do texto */
  padding: 0 10px !important;  /* menos “ar” */
  margin: 3px 8px !important;  /* itens mais juntinhos */
}

/* 2) Ícones menores e mais discretos */
.sidebar .nav-ico{
  width: 26px !important;      /* ↓ menor */
  height: 26px !important;
  border-radius: 7px !important;
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
}

.sidebar .nav-ico svg{
  width: 14px !important;      /* ↓ tamanho real do símbolo */
  height: 14px !important;
  stroke-width: 2 !important;
}

/* 3) Texto menor e mais “colado” */
.sidebar .nav-txt{
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
}

/* 4) Labels (Operações / Gestão / Admin) menores e com menos espaço */
.sidebar .sidebar-label{
  font-size: 10px !important;
  letter-spacing: .12em !important;
  margin: 8px 12px 4px !important;
  opacity: .75 !important;
}

/* 5) Grupos com separação bem leve (igual print) */
.sidebar .sidebar-group + .sidebar-group{
  margin-top: 6px !important;
  padding-top: 6px !important;
  border-top: 1px solid rgba(255,255,255,.05) !important;
}

/* Remover o quadrado de fundo dos ícones do menu lateral */
.sidebar .nav-ico,
.sidebar .sidebar-item.is-active .nav-ico,
.sidebar .sidebar-item.active .nav-ico,
.sidebar.sidebar--mini:not(:hover) .nav-ico{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Desativar destaque do item selecionado (sem fundo ou barra) */
.sidebar .sidebar-item.is-active,
.sidebar .sidebar-item.active{
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

.sidebar .sidebar-item.is-active .nav-txt,
.sidebar .sidebar-item.active .nav-txt,
.sidebar .sidebar-item.is-active .nav-ico,
.sidebar .sidebar-item.active .nav-ico{
  color: var(--sb-text) !important;
}

/* Compactar espaçamento entre itens do menu */
.sidebar .sidebar-item{
  margin: 4px 0 !important;
  padding: 10px 12px !important;
}

.sidebar nav,
.sidebar .sidebar-group,
.sidebar .sidebar-list{
  gap: 6px !important;
}

/* Sidebar ultra-compacta (itens quase colados) */
.sidebar nav,
.sidebar .sidebar-group,
.sidebar .sidebar-list{
  gap: 2px !important;
}

.sidebar .sidebar-item{
  height: 30px !important;
  padding: 6px 10px !important;
  margin: 1px 6px !important;
  gap: 6px !important;
}

.sidebar .nav-ico{
  width: 22px !important;
  height: 22px !important;
  border-radius: 6px !important;
}

.sidebar .nav-ico svg{
  width: 12px !important;
  height: 12px !important;
}

.sidebar .nav-txt{
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 600 !important;
}

/* Labels/minititulos mais colados */
.sidebar .sidebar-label{
  margin: 6px 10px 2px !important;
  font-size: 9px !important;
  letter-spacing: 0.12em !important;
}

/* Remove separadores extras entre grupos */
.sidebar .sidebar-group + .sidebar-group{
  margin-top: 2px !important;
  padding-top: 2px !important;
  border-top: none !important;
}

/* Ocultar títulos de grupo (Operações / Gestão / Admin) */
.sidebar .sidebar-label{
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  height: 0 !important;
}

/* Sidebar estilo referencia (altura, fonte e espacamento) */
.sidebar nav,
.sidebar .sidebar-group,
.sidebar .sidebar-list{
  gap: 8px !important;
}

/* Micro-ajuste: aproxima o texto ligeiramente ao abrir o menu (uso opcional, -1px/-2px) */
/* removed: micro-ajuste duplicado; handled in the hover rule above */

.sidebar .sidebar-item{
  height: 35px !important;
  padding: 8px 6px !important;
  margin: 2px 4px !important;
  gap: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.sidebar .nav-ico{
  width: 40px !important;
  height: 40px !important;
  border: none !important;
  background: transparent !important;
  margin-right: 8px !important;
  border-radius: 10px !important;
}

.sidebar .nav-ico svg{
  width: 20px !important;
  height: 20px !important;
}

.sidebar .nav-txt{
  font-size: 14px !important;
  line-height: 1.2 !important;
  font-weight: 500 !important;
  color: #e6e6e6 !important;
}

/* Hover suave (opcional) */
.sidebar .sidebar-item:hover{
  background: rgba(255,255,255,0.06) !important;
}





/* =========================================================
   SIDEBAR MINI HOVER (FIXO): ícone NÃO muda e NÃO se move
   Cole no FINAL do style.css
========================================================= */

:root{
  --sb-mini: 52px;     /* largura colapsada */
  --sb-open: 248px;    /* largura expandida */
  --sb-ico: 20px;      /* tamanho do container do ícone */
  --sb-svg: 18px;      /* tamanho do svg/feather */
  --sb-pad-left: 14px; /* recuo fixo do item (mantém o ícone parado) */
}

/* Sidebar no mini + expandir no hover */
.sidebar.sidebar--mini{
  width: var(--sb-mini) !important;
  overflow-x: hidden !important;
}
.sidebar.sidebar--mini:hover{
  width: var(--sb-open) !important;
}

/* Item: NUNCA centraliza, NUNCA zera padding */
.sidebar.sidebar--mini:hover .sidebar-item{
  /* flex-start APENAS quando estiver aberto (hover) */
  justify-content: flex-start !important;
}


/* Ícone: tamanho FIXO sempre */
.sidebar.sidebar--mini .nav-ico{
  width: var(--sb-ico) !important;
  height: var(--sb-ico) !important;
  flex: 0 0 var(--sb-ico) !important;
  margin: 0 !important;
}

/* SVG/Feather: tamanho FIXO sempre */
.sidebar.sidebar--mini .nav-ico svg,
.sidebar.sidebar--mini .nav-ico i{
  width: var(--sb-svg) !important;
  height: var(--sb-svg) !important;
}

/* Texto: escondido no mini (sem empurrar ícone) */
.sidebar.sidebar--mini:not(:hover) .nav-txt,
.sidebar.sidebar--mini:not(:hover) .sidebar-label,
.sidebar.sidebar--mini:not(:hover) .sidebar-brand .brand-text {
  opacity: 0 !important;
  width: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  transform: translateX(-6px) !important;
  pointer-events: none !important;
  transition: none !important; /* sem transição ao recolher */
}

/* Texto aparece no hover (entrada suave) */
.sidebar.sidebar--mini:hover .nav-txt,
.sidebar.sidebar--mini:hover .sidebar-label,
.sidebar.sidebar--mini:hover .sidebar-brand .brand-text {
  opacity: 1 !important;
  width: auto !important;
  transform: none !important;
  pointer-events: auto !important;
  transition: opacity .18s ease, transform .18s ease !important;
  transition-delay: .06s !important;
  margin-left: -2px !important; /* micro-ajuste opcional */
}







/* =========================================================
   FIX DEFINITIVO — mini centralizado + ícone NÃO desloca ao abrir
   (cole no FINAL do style.css)
========================================================= */

:root{
  /* usa variável do seu layout se existir; senão cai no padrão */
  --sb-mini-fix: var(--sb-collapsed, 52px); /* largura do mini */
  --sb-ico-fix: 40px;        /* igual ao .sidebar .nav-ico do seu “OVERRIDE FINAL” */
  --sb-item-mx-fix: 8px;     /* igual ao margin horizontal da .sidebar-item (3px 8px) */

  /* posição do ícone no mini (central) convertida em padding-left no aberto */
  --sb-ico-left-fix: calc((var(--sb-mini-fix) - var(--sb-ico-fix)) / 2 - var(--sb-item-mx-fix));
}

/* MINI (não hover): centraliza o ícone */
.sidebar.sidebar--mini:not(:hover) .sidebar-item{
  justify-content: center !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* ABERTO (hover): mantém o ícone na MESMA coluna do mini */
.sidebar.sidebar--mini:hover .sidebar-item{
  justify-content: flex-start !important;
}

/* garante que o ícone não tenha margem que empurre */
.sidebar.sidebar--mini .nav-ico{
  margin: 0 !important;
}


/* =========================================================
   TRAVA TOTAL: ícone não mexe ao abrir (mini centralizado)
   Cole NO FINAL do style.css
========================================================= */
:root{
  --sb-mini: 52px;     /* deixe igual à sua largura real do mini */
  --sb-open: 248px;    /* deixe igual à sua largura real aberta */
  --sb-ico: 28px;      /* bate com seu padrão final do nav-ico */
}

/* largura mini / aberta */
.sidebar.sidebar--mini{ width: var(--sb-mini) !important; }
.sidebar.sidebar--mini:hover{ width: var(--sb-open) !important; }

/* IMPORTANTÍSSIMO: remover margem lateral do item no modo mini
   (senão a origem do "left" muda e parece que o ícone mexe) */
.sidebar.sidebar--mini .sidebar-item{
  position: relative !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* ÍCONE: fixo na "coluna" do mini (sempre no mesmo X) */
.sidebar.sidebar--mini .nav-ico{
  position: absolute !important;
  left: calc(var(--sb-mini) / 2) !important;
  top: 39% !important;
  transform: translate(-65%, -30%) !important;
  width: var(--sb-ico) !important;
  height: var(--sb-ico) !important;
  margin: 0px !important;
}

/* MINI: centraliza visualmente (texto escondido) */
.sidebar.sidebar--mini:not(:hover) .sidebar-item{
  padding: 8px 0 !important;
}

/* ABERTO: o texto começa depois da largura do mini */
.sidebar.sidebar--mini:hover .sidebar-item{
  padding-left: calc(var(--sb-mini) + 2px) !important;
  padding-right: 14px !important;
  justify-content: flex-start !important;
}

/* =========================================================
   AUMENTAR ÁREA CLICÁVEL + CONTORNO QUADRADO NO HOVER
   - Aplica apenas quando a sidebar está ABERTA (não afeta o modo mini)
   - Garante área maior para clique e remove borda arredondada no hover
========================================================= */
.sidebar:not(.sidebar--mini) .sidebar-item{
  display: block !important;
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 12px 16px !important; /* área clicável maior */
  margin: 4px 0 !important;
  border-radius: 0 !important;   /* sem cantos arredondados por padrão */
  transition: background .12s ease, box-shadow .12s ease !important;
}

.sidebar:not(.sidebar--mini) .sidebar-item .nav-ico{
  margin-right: 12px !important; /* mantém separação visual maior entre ícone e texto */
}

.sidebar:not(.sidebar--mini) .sidebar-item:hover{
  background: rgba(255,255,255,0.06) !important;
  border-radius: 0 !important; /* força contorno quadrado no hover */
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08) !important; /* contorno quadrado */
}

/* Pequeno cuidado: mantém comportamento do modo mini (não sobrescrever posicionamento absoluto) */
.sidebar.sidebar--mini .sidebar-item{ padding-left: 0 !important; padding-right: 0 !important; }







/* =========================
   ESTOQUE - UI IMPROVEMENTS
   ========================= */

/* Sticky header, compact cells, zebra and hover */
#estoqueConteudo .table-epi thead th{
  position: sticky;
  top: 0;
  z-index: 6;
  background: linear-gradient(180deg,#fbfdff,#ffffff);
  box-shadow: 0 6px 18px rgba(15,23,42,0.04);
  border-bottom: 1px solid #eef2f7;
  padding: 10px 14px;
}

#estoqueConteudo .table-epi tbody td{
  padding: 10px 12px;
  font-size: 13px;
  vertical-align: middle;
}

#estoqueConteudo .table-epi tbody tr:nth-child(even){ background: #fbfdff; }
#estoqueConteudo .table-epi tbody tr:hover td{ background: #f3f8ff; transition: background .12s ease; }

/* Qty stepper - uses existing markup (.qty, .qty-btn, .qty-input) */
#estoqueConteudo .td-qtd{
  text-align: center;
  white-space: nowrap;
}

#estoqueConteudo .td-qtd .qty{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: auto;
  margin: 0 auto;
}

#estoqueConteudo .td-qtd .qty-btn{
  width: 30px;
  min-width: 30px;
  height: 30px;
  padding: 0;
  margin: 0;
  display: inline-grid;
  place-items: center;
  flex: 0 0 30px;
  border-radius: 8px;
  border: 1px solid #dbeafe;
  background: #ffffff;
  color: #124679;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 6px 14px rgba(15,23,42,0.04);
  transition: transform .12s ease, background .12s ease;
}

#estoqueConteudo .td-qtd .qty-btn:hover{
  background: #eef6ff;
  transform: translateY(-1px);
}

#estoqueConteudo .td-qtd .qty-input{
  width: 52px;
  min-width: 52px;
  height: 30px;
  padding: 0 4px;
  margin: 0;
  flex: 0 0 52px;
  text-align: center;
  border-radius: 8px;
  border: 1px solid #e6eefc;
  background: #f9fbff;
  font-weight: 800;
}

/* remove setinhas nativas do input number */
#estoqueConteudo .td-qtd .qty-input::-webkit-outer-spin-button,
#estoqueConteudo .td-qtd .qty-input::-webkit-inner-spin-button{
  -webkit-appearance: none;
  margin: 0;
}

#estoqueConteudo .td-qtd .qty-input{
  -moz-appearance: textfield;
  appearance: textfield;
}

/* highlight modified rows */
.row-modified td{ box-shadow: inset 0 0 0 2px rgba(59,130,246,0.06); }

/* badge for low stock */
.badge-low{ display:inline-block; padding:4px 8px; border-radius:999px; font-size:12px; font-weight:700; background:#fff7ed; color:#9a3412; border:1px solid rgba(249,115,22,0.12); }

/* Small responsive adjustments */
@media (max-width:820px){
  .qty-input{ width:56px; }
  #estoqueConteudo .table-epi thead th{ font-size:12px; padding:8px 10px; }
  #estoqueConteudo .table-epi tbody td{ padding:8px 10px; font-size:13px; }
}

/* ensure table card looks tidy */
#estoqueConteudo{ border-radius:14px; padding:12px; }

/* === Ajuste: aproximar texto dos ícones (override final) === */
/* Mantém o ícone na mesma posição e aproxima apenas o texto. */
.sidebar .sidebar-item { gap: 12px !important; }
.sidebar .sidebar-item .nav-ico { margin-right: 12px !important; flex: 0 0 auto !important; }
.sidebar .nav-txt { margin-left: 4px !important; transition: opacity .18s ease, transform .18s ease; }
.sidebar.sidebar--mini:hover .sidebar-item { padding-left: 12px !important; }
.sidebar .nav-ico { position: relative; }

/* Ajuste alternativo (aumente/abaixe para 4px ou 2px conforme desejar) */
/* .sidebar .sidebar-item { gap: 4px !important; } */

/* === Override mais específico para garantir aplicação === */
/* Seletores mais longos e !important para vencer outras regras conflitantes */
.sidebar .sidebar-list .sidebar-group .sidebar-item,
.sidebar nav .sidebar-item,
.sidebar .sidebar-item {
  gap: 12px !important;
}

.sidebar .sidebar-list .sidebar-item > .nav-ico,
.sidebar nav .sidebar-item > .nav-ico,
.sidebar .sidebar-item > .nav-ico {
  margin-right: 12px !important;
  flex: 0 0 auto !important;
}

.sidebar .sidebar-list .sidebar-item > .nav-ico + .nav-txt,
.sidebar nav .sidebar-item > .nav-ico + .nav-txt,
.sidebar .sidebar-item > .nav-ico + .nav-txt {
  margin-left: 4px !important;
  display: inline-block !important;
  vertical-align: middle !important;
}

/* Quando a sidebar está no modo mini e em hover garantir que o texto fique alinhado */
.sidebar.sidebar--mini:hover .nav-txt {
  opacity: 1 !important;
  width: auto !important;
  margin-left: 4px !important;
  transform: none !important;
  pointer-events: auto !important;
}

/* Se algo usa padding-left para alinhar o texto, garantir que não empurre o ícone */
.sidebar .sidebar-item .nav-txt {
  padding-left: 0 !important;
}

/* Dica: se ainda não ver mudanças, faça um hard refresh (Ctrl+F5) no navegador */

/* ===== FIX FINAL: garantir que texto não sobreponha o ícone ===== */
/* Aplica somente quando a sidebar estiver no modo "mini" e em hover (expandida) */
.sidebar.sidebar--mini .nav-ico { z-index: 20 !important; }
.sidebar.sidebar--mini .nav-txt { z-index: 10 !important; }

/* Força o texto começar depois da largura do mini, evitando sobreposição. */
.sidebar.sidebar--mini:hover .sidebar-item > .nav-txt,
.sidebar.sidebar--mini:hover .sidebar-item .nav-txt{
  margin-left: calc(var(--sb-mini, 52px) + 8px) !important; /* ajuste fino */
  display: inline-block !important;
  width: auto !important;
  opacity: 1 !important;
}

/* Alternativa para quando a estrutura do HTML usar ícone e texto como irmãos em container */
.sidebar.sidebar--mini:hover .sidebar-item > .nav-ico + .nav-txt{
  margin-left: 8px !important; /* garante espaçamento caso o item já tenha padding-left maior */
}

/* proteção: quando há regras que escondem o texto via width:0, garantir que no hover fique visível */
.sidebar.sidebar--mini:hover .nav-txt[style],
.sidebar.sidebar--mini:hover .nav-txt[hidden]{
  width: auto !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}








:root{
  --sb-hit-gap: 1px;
  --sb-hit-inset-x: 0px;
  --sb-hit-h: 36px;
  --sb-hit-radius: 0px;
  --sb-hover-bg: rgba(255,255,255,0.032);
  --sb-active-bg: rgba(255,255,255,0.058);
  --sb-active-ring: inset 0 1px 0 rgba(255,255,255,0.04), inset 0 -1px 0 rgba(0,0,0,0.16);
}

/* faixa contínua entre os itens */
.sidebar .sidebar-list{
  gap: 0 !important;
}

/* item continua clicável inteiro */
.sidebar .sidebar-item{
  position: relative !important;
  margin: 0 !important;
  min-height: calc(var(--sb-hit-h) + (var(--sb-hit-gap) * 2)) !important;
  height: calc(var(--sb-hit-h) + (var(--sb-hit-gap) * 2)) !important;
  border-radius: 0 !important;
  background: transparent !important;
}

/* camada visual do item */
.sidebar .sidebar-item::before{
  content: "" !important;
  position: absolute !important;
  inset: var(--sb-hit-gap) var(--sb-hit-inset-x) !important;
  border-radius: var(--sb-hit-radius) !important;
  background: transparent !important;
  box-shadow: none !important;
  transition: background 160ms ease, box-shadow 160ms ease !important;
  pointer-events: none !important;
}

/* hover mais fluido e mais horizontal */
.sidebar .sidebar-item:hover{
  background: transparent !important;
}

.sidebar .sidebar-item:hover::before{
  background: var(--sb-hover-bg) !important;
}

/* item ativo */
.sidebar .sidebar-item.active,
.sidebar .sidebar-item.is-active{
  background: transparent !important;
  color: #ffffff !important;
}

.sidebar .sidebar-item.active::before,
.sidebar .sidebar-item.is-active::before{
  background: var(--sb-active-bg) !important;
  box-shadow: var(--sb-active-ring) !important;
}

/* conteúdo acima da faixa */
.sidebar .sidebar-item > *{
  position: relative !important;
  z-index: 1 !important;
}

/* ativo com leitura mais forte */

.sidebar .sidebar-item.active > .nav-txt,
.sidebar .sidebar-item.is-active > .nav-txt{
  color: rgba(255,255,255,0.96) !important;
  font-weight: 500 !important;
}

.sidebar .sidebar-item.active > .nav-ico,
.sidebar .sidebar-item.is-active > .nav-ico{
  color: rgba(255,255,255,0.96) !important;
}

/* ===== Estilos para Downloads (engrenagem premium) ===== */
#btnDownloadsGear {
  border: 1px solid rgba(0,0,0,0.08);
  background: #ffffff;
  transition: background .14s ease, transform .12s ease, box-shadow .14s ease;
  box-shadow: none;
  color: #0f172a;
}
#btnDownloadsGear:hover {
  background: #eef6ff; /* azul clarinho */
}
#btnDownloadsGear:active {
  transform: translateY(1px);
}

#downloadsGearWrap { display:inline-flex; align-items:center; }

#downloadsGearMenu {
  min-width: 260px;
  padding: 8px;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 14px;
  background: #ffffff;
  box-shadow: 0 6px 18px rgba(16,24,40,0.08), 0 2px 6px rgba(16,24,40,0.04);
}

#downloadsGearMenu a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 600;
  color: #0f172a;
  text-decoration: none;
  transition: background .12s ease;
}
#downloadsGearMenu a:hover {
  background: #eaf4ff; /* hover azul suave */
}
#downloadsGearMenu a:focus {
  outline: 3px solid rgba(59,130,246,0.18);
  outline-offset: 2px;
}

#downloadsGearMenu a i { width: 18px; height: 18px; color: rgba(17,24,39,0.9); }
#downloadsGearMenu a .dl-right { margin-left: auto; width: 16px; height: 16px; opacity: 0.9; }

@media (max-width: 720px) {
  #downloadsGearMenu { right: 0; left: auto; }
}

/* ===== Fim Downloads ===== */

/* FIX DEFINITIVO — Carrinho da LOJA
   Overlay abaixo do Drawer (senão o overlay “come” o clique) */
#lojaCartOverlay { z-index: 6000; }
#lojaCartDrawer  { z-index: 6001; }

/* ===== LOJA — Checkout / Dados de entrega (mínimo) ===== */
.loja-checkout{
  margin:10px 0;
  border:1px solid #e6e9ef;
  border-radius:12px;
  background:#fff;
  padding:10px;
}
.loja-checkout summary{
  cursor:pointer;
  font-weight:800;
  user-select:none;
}
.loja-checkout-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
  margin-top:10px;
}
.loja-checkout-grid .span2{ grid-column: 1 / -1; }
.loja-checkout label{ margin:0 0 4px; font-size:12px; font-weight:700; }


/* =========================================================
   PRÉ-PEDIDO PREMIUM — BLOCO FINAL
   Colar no final do style.css
========================================================= */

body #preOverlay{
  background: rgba(2, 8, 23, 0.58);
  backdrop-filter: blur(10px);
}

body #preModal{
  width: min(1180px, 94vw);
  max-height: 88vh;
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-top: 4px solid #2563eb;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,250,252,0.98) 100%);
  box-shadow:
    0 30px 90px rgba(2, 8, 23, 0.34),
    0 10px 24px rgba(15, 23, 42, 0.10);
  overflow: hidden;
}

body #preModal .pre-head{
  padding: 22px 24px 16px 24px;
  border-bottom: 1px solid rgba(226, 232, 240, 0.95);
  background:
    linear-gradient(180deg, rgba(248,250,252,0.98) 0%, rgba(255,255,255,0.96) 100%);
  backdrop-filter: blur(8px);
  align-items: flex-start;
}

body #preModal .pre-head-left{
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-left: 0;
}

body #preModal .pre-title{
  margin: 0;
  font-size: 24px;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
}

body #preModal .pre-sub{
  margin: 0;
  padding: 0;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  padding: 8px 12px;
  border-radius: 999px;
  background: #eff6ff;
  border: 1px solid #dbeafe;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
}

body #preContent{
  padding: 18px 24px 16px 24px;
  background: transparent;
}

body #preContent .table-wrap{
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.65),
    0 10px 30px rgba(15, 23, 42, 0.05);
  overflow: auto;
}

body #preModal .pre-foot{
  padding: 16px 24px;
  border-top: 1px solid rgba(226, 232, 240, 0.95);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(248,250,252,0.98) 100%);
  backdrop-filter: blur(8px);
}

body #preModal .pre-foot .muted{
  color: #64748b;
  font-size: 13px;
  font-weight: 600;
}

body #preModal .pre-actions{
  display: flex;
  gap: 12px;
  align-items: center;
}

body #preModal .btn{
  min-height: 44px;
  padding: 0 18px;
  border-radius: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}

body #preModal .btn:hover{
  transform: translateY(-1px);
}

body #preModal .btn--ghost{
  background: #ffffff;
  border: 1px solid #dbe3ee;
  color: #0f172a;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.04);
}

body #preModal .btn--ghost:hover{
  background: #f8fafc;
  border-color: #cbd5e1;
}

body #preModal .btn--primary{
  background: linear-gradient(135deg, #1d4ed8 0%, #2563eb 52%, #3b82f6 100%);
  color: #ffffff;
  border: 1px solid transparent;
  box-shadow: 0 14px 30px rgba(37, 99, 235, 0.30);
}

body #preModal .btn--primary:hover{
  box-shadow: 0 18px 34px rgba(37, 99, 235, 0.36);
}

body #preModal .btn--primary:disabled{
  opacity: .6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

body #preModal #preFechar{
  min-width: 108px;
}

body #preModal #tablePrePedido{
  width: 100%;
  min-width: 940px;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}

body #preModal #tablePrePedido thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  background: #f8fbff;
  color: #475569;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-bottom: 1px solid #e2e8f0;
  padding: 14px 14px;
}

body #preModal #tablePrePedido th,
body #preModal #tablePrePedido td{
  padding: 16px 14px;
  vertical-align: middle;
  border-bottom: 1px solid #eef2f7;
}

body #preModal #tablePrePedido tbody tr{
  background: transparent;
  transition: background .16s ease, box-shadow .16s ease;
}

body #preModal #tablePrePedido tbody tr:nth-child(even){
  background: rgba(248, 250, 252, 0.55);
}

body #preModal #tablePrePedido tbody tr:hover{
  background: #f8fbff;
  box-shadow: inset 3px 0 0 #3b82f6;
}

body #preModal #tablePrePedido td:nth-child(1){
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 700;
  color: #0f172a;
}

body #preModal #tablePrePedido td:nth-child(2){
  text-align: center;
  font-variant-numeric: tabular-nums;
  color: #64748b;
  font-weight: 700;
}

body #preModal #tablePrePedido td:nth-child(3),
body #preModal #tablePrePedido td:nth-child(4),
body #preModal #tablePrePedido td:nth-child(5),
body #preModal #tablePrePedido td:nth-child(6),
body #preModal #tablePrePedido td:nth-child(7){
  text-align: center;
  font-variant-numeric: tabular-nums;
}

body #preModal #tablePrePedido .neg,
body #preModal #tablePrePedido .pos,
body #preModal #tablePrePedido .neu{
  min-width: 48px;
  padding: 5px 10px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  border: 1px solid transparent;
}

body #preModal #tablePrePedido .neg{
  color: #b91c1c;
  background: #fef2f2;
  border-color: #fecaca;
}

body #preModal #tablePrePedido .pos{
  color: #065f46;
  background: #ecfdf5;
  border-color: #bbf7d0;
}

body #preModal #tablePrePedido .neu{
  color: #334155;
  background: #f1f5f9;
  border-color: #e2e8f0;
}

body #preModal #tablePrePedido input[data-pre-qtd]{
  width: 94px !important;
  height: 42px;
  padding: 0 12px;
  border-radius: 14px;
  border: 1px solid #dbe3ee;
  background: #ffffff;
  text-align: center;
  font-size: 15px;
  font-weight: 800;
  color: #0f172a;
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

body #preModal #tablePrePedido input[data-pre-qtd]:hover{
  border-color: #bfdbfe;
  background: #f8fbff;
}

body #preModal #tablePrePedido input[data-pre-qtd]:focus{
  outline: none;
  border-color: #3b82f6;
  background: #ffffff;
  box-shadow:
    0 0 0 4px rgba(59, 130, 246, 0.14),
    inset 0 1px 2px rgba(15, 23, 42, 0.04);
}

body #preModal #tablePrePedido tfoot .pre-total-row{
  background: linear-gradient(180deg, #f8fbff 0%, #f1f5f9 100%);
}

body #preModal #tablePrePedido tfoot td{
  border-bottom: 0;
  border-top: 1px solid #dbe3ee;
  padding-top: 16px;
  padding-bottom: 16px;
}

body #preModal #tablePrePedido .pre-total-label{
  text-align: right;
  padding-right: 16px;
  font-size: 13px;
  font-weight: 800;
  color: #334155;
  text-transform: uppercase;
  letter-spacing: .04em;
}

body #preModal #preTotal.pre-total-value{
  display: inline-flex;
  min-width: 52px;
  justify-content: center;
  align-items: center;
  padding: 8px 12px;
  border-radius: 14px;
  background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
  color: #1d4ed8;
  font-size: 18px;
  font-weight: 900;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.65);
}

/* responsivo */
@media (max-width: 780px){
  body #preModal{
    width: min(96vw, 96vw);
    max-height: 90vh;
    border-radius: 20px;
  }

  body #preModal .pre-head{
    padding: 18px 16px 14px 16px;
    align-items: flex-start;
  }

  body #preModal .pre-title{
    font-size: 20px;
  }

  body #preContent{
    padding: 14px 16px;
  }

  body #preModal .pre-foot{
    padding: 14px 16px;
  }

  body #preModal .pre-actions{
    width: 100%;
    justify-content: flex-end;
    flex-wrap: wrap;
  }

  body #preModal .pre-actions .btn{
    min-width: 148px;
  }
}

  /* ===== Loja: filtros, orçamento, timeline e totais ===== */
  .loja-ped-filtros{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin:14px 0 12px;
    padding:10px;
    border:1px solid #e7edf6;
    border-radius:18px;
    background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);
  }

  .loja-ped-filter{
    border:1px solid #dbe7f7;
    background:#fff;
    color:#334155;
    border-radius:999px;
    padding:8px 11px;
    font-size:12px;
    font-weight:800;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    gap:7px;
    transition:.16s ease;
  }

  .loja-ped-filter:hover{
    border-color:#93c5fd;
    color:#1d4ed8;
  }

  .loja-ped-filter.is-active{
    background:#17328c;
    border-color:#17328c;
    color:#fff;
    box-shadow:0 10px 22px rgba(23,50,140,.18);
  }

  .loja-ped-filter span{
    min-width:20px;
    height:20px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:#eef4ff;
    color:#1d4ed8;
    font-size:11px;
  }

  .loja-ped-filter.is-active span{
    background:rgba(255,255,255,.18);
    color:#fff;
  }

  .store-order-badge.is-orcamento{
    background:#f5f3ff;
    color:#6d28d9;
    border-color:#ddd6fe;
  }

  .store-order-summary--finance{
    grid-template-columns:repeat(4, minmax(0,1fr));
  }

  .store-order-summary-card--total{
    border-color:#bfdbfe;
    background:linear-gradient(180deg,#eff6ff 0%, #ffffff 100%);
  }

  .loja-order-timeline{
    margin-top:14px;
    padding:12px 14px;
    border:1px solid #e8eef5;
    border-radius:16px;
    background:#fbfdff;
    display:grid;
    gap:10px;
  }

  .loja-order-step{
    display:grid;
    grid-template-columns:14px 1fr;
    gap:10px;
    align-items:start;
    color:#334155;
  }

  .loja-order-dot{
    width:10px;
    height:10px;
    margin-top:4px;
    border-radius:999px;
    background:#1d4ed8;
    box-shadow:0 0 0 4px rgba(29,78,216,.10);
  }

  .loja-order-step strong{
    display:block;
    font-size:13px;
    color:#0f172a;
  }

  .loja-order-step small{
    display:block;
    margin-top:2px;
    font-size:11px;
    color:#64748b;
  }

  .loja-client-actions{
    margin-top:14px;
    display:flex;
    justify-content:flex-end;
    gap:10px;
    flex-wrap:wrap;
  }

  @media (max-width: 760px){
    .store-order-summary--finance{
      grid-template-columns:repeat(2, minmax(0,1fr));
    }
  }

/* =========================================================
   LOJA — PEDIDOS PROFISSIONAL + FRETE AUTOMÁTICO
   ========================================================= */

/* Corrige o bug visual dos filtros virarem barras gigantes */
#lojaPedModal .loja-ped-filtros,
.loja-ped-filtros.loja-ped-filtros--chips{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:8px !important;
  width:100% !important;
  margin:14px 0 16px !important;
  padding:10px !important;
  border:1px solid #e5edf8 !important;
  border-radius:18px !important;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%) !important;
  box-shadow:0 10px 24px rgba(15,23,42,.045) !important;
}

#lojaPedModal .loja-ped-filter,
.loja-ped-filtros--chips .loja-ped-filter{
  width:auto !important;
  min-width:0 !important;
  height:36px !important;
  padding:0 12px !important;
  border-radius:999px !important;
  border:1px solid #d9e5f6 !important;
  background:#ffffff !important;
  color:#334155 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:7px !important;
  font-size:12px !important;
  font-weight:850 !important;
  line-height:1 !important;
  box-shadow:none !important;
  cursor:pointer !important;
  transition:background .16s ease, color .16s ease, border-color .16s ease, transform .14s ease, box-shadow .16s ease !important;
}

#lojaPedModal .loja-ped-filter:hover,
.loja-ped-filtros--chips .loja-ped-filter:hover{
  background:#f4f8ff !important;
  border-color:#b8d2ff !important;
  color:#1d4ed8 !important;
  transform:translateY(-1px) !important;
}

#lojaPedModal .loja-ped-filter.is-active,
.loja-ped-filtros--chips .loja-ped-filter.is-active{
  background:#17328c !important;
  border-color:#17328c !important;
  color:#ffffff !important;
  box-shadow:0 10px 22px rgba(23,50,140,.18) !important;
}

#lojaPedModal .loja-ped-filter span,
.loja-ped-filtros--chips .loja-ped-filter span{
  min-width:20px !important;
  height:20px !important;
  padding:0 6px !important;
  border-radius:999px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:#eef4ff !important;
  color:#1d4ed8 !important;
  font-size:11px !important;
  font-weight:900 !important;
}

#lojaPedModal .loja-ped-filter.is-active span,
.loja-ped-filtros--chips .loja-ped-filter.is-active span{
  background:rgba(255,255,255,.18) !important;
  color:#ffffff !important;
}

/* Modal de frete */
.loja-frete-modal{
  border-radius:22px !important;
  overflow:hidden;
}

.loja-frete-box{
  margin-top:14px;
  border:1px solid #e5edf8;
  border-radius:18px;
  padding:16px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
}

.loja-switch-line{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid #e5edf8;
  border-radius:14px;
  background:#fff;
  margin:0 0 14px;
  font-weight:850;
  color:#0f172a;
}

.loja-switch-line input[type="checkbox"]{
  width:18px;
  height:18px;
  margin:0;
  padding:0;
}

.loja-frete-grid{
  gap:14px;
}

.loja-frete-grid label{
  font-size:12px;
  font-weight:850;
  color:#334155;
  margin-bottom:6px;
}

.loja-frete-grid small{
  display:block;
  margin-top:6px;
  color:#64748b;
  font-size:11px;
  line-height:1.35;
}

.loja-frete-preview{
  margin-top:14px;
  padding:12px 14px;
  border-radius:14px;
  background:#eef6ff;
  color:#1e3a8a;
  font-size:12px;
  line-height:1.45;
  border:1px solid #d9eafe;
}

.loja-frete-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:16px;
}

/* Resumo do carrinho com subtotal/frete/total */
.loja-cart-resumo{
  border:1px solid #e5edf8;
  border-radius:16px;
  padding:12px;
  background:#ffffff;
  display:grid;
  gap:8px;
}

.loja-cart-money-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:#475569;
  font-size:13px;
}

.loja-cart-money-row b{
  color:#0f172a;
  font-size:14px;
}

.loja-cart-money-row--total{
  padding-top:8px;
  margin-top:4px;
  border-top:1px solid #e5edf8;
}

.loja-cart-money-row--total span,
.loja-cart-money-row--total b{
  color:#0f2c82;
  font-size:16px;
  font-weight:900;
}

.loja-cart-frete-msg{
  margin-top:4px;
  border-radius:12px;
  background:#f0f7ff;
  color:#1d4ed8;
  font-size:12px;
  font-weight:750;
  padding:8px 10px;
}

/* Ações administrativas dos pedidos */
.loja-admin-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}

.loja-admin-actions .btn{
  width:auto !important;
  min-width:120px;
}

.loja-order-finalizado{
  margin-top:12px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #dbeafe;
  background:#eff6ff;
  color:#1e3a8a;
  display:grid;
  gap:3px;
}

.loja-order-finalizado strong{
  font-size:13px;
}

.loja-order-finalizado span{
  font-size:12px;
  color:#475569;
}

.loja-order-finalizado--wait{
  background:#fff7ed;
  border-color:#fed7aa;
  color:#9a3412;
}

.loja-admin-logistica summary{
  color:#0f172a;
}

.loja-admin-logistica-grid input:disabled{
  background:#f8fafc;
  color:#94a3b8;
  cursor:not-allowed;
}

@media (max-width:760px){
  #lojaPedModal .loja-ped-filtros,
  .loja-ped-filtros.loja-ped-filtros--chips{
    overflow-x:auto !important;
    flex-wrap:nowrap !important;
    justify-content:flex-start !important;
    -webkit-overflow-scrolling:touch;
  }

  #lojaPedModal .loja-ped-filter,
  .loja-ped-filtros--chips .loja-ped-filter{
    flex:0 0 auto !important;
  }

  .loja-frete-actions{
    flex-direction:column;
  }

  .loja-frete-actions .btn{
    width:100%;
  }
}

/* =========================================================
   LOJA — STATUS DO PEDIDO + PREVISÃO FORA DO BADGE
   ========================================================= */

.store-order-statusbox{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:flex-start;
  gap:5px;
  text-align:right;
}

.store-order-statusbox .store-order-badge{
  min-height:32px;
  padding:0 13px;
  white-space:nowrap;
}

.store-order-status-sub{
  display:block;
  font-size:11px;
  font-weight:800;
  line-height:1.2;
  color:#94a3b8;
  letter-spacing:.01em;
  white-space:nowrap;
}

.store-order-status-sub--previsao{
  color:#94a3b8;
  font-weight:750;
}

.store-order-badge.is-enviado{
  background:#ecfeff;
  color:#0f766e;
  border-color:#a5f3fc;
}

.store-order-badge.is-aprovado{
  background:#eff6ff;
  color:#1d4ed8;
  border-color:#bfdbfe;
}

/* neutraliza o estilo antigo caso ainda exista no final do CSS */
.store-order-badge--stack{
  flex-direction:row !important;
  gap:0 !important;
}

.store-order-badge--stack small{
  display:none !important;
}
