/* SerSanto – Kits Automáticos por Estampa (frontend)
   Objetivo: layout “vitrine” (mosaico 2x2), cards limpos e botão destacado (estilo próximo ao exemplo do cliente).
   Compatível com Flatsome (sem frameworks). */

.ss-ka-wrap{
  --sska-radius: 18px;
  --sska-gap: 14px;
  --sska-border: rgba(0,0,0,.10);
  --sska-muted: rgba(0,0,0,.62);
  --sska-shadow: 0 10px 30px rgba(0,0,0,.08);
  --sska-shadow-hover: 0 16px 42px rgba(0,0,0,.12);
  --sska-accent: #2bb24c; /* botão verde como referência */

  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 10px;
}

.ss-ka-header{
  text-align: center;
  margin: 8px 0 18px 0;
}

.ss-ka-title{
  margin: 0 0 6px 0;
  font-size: clamp(22px, 2.6vw, 32px);
  line-height: 1.15;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.ss-ka-subtitle{
  margin: 0;
  color: var(--sska-muted);
}

.ss-ka-notice{
  padding: 14px 16px;
  border: 1px solid var(--sska-border);
  border-radius: var(--sska-radius);
  background: rgba(0,0,0,.02);
}

.ss-ka-error{
  border-color: rgba(220,38,38,.25);
  background: rgba(220,38,38,.06);
}

.ss-ka-grid{
  display: grid;
  gap: var(--sska-gap);
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 900px){
  .ss-ka-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Card */
.ss-ka-card{
  border-radius: var(--sska-radius);
  border: 1px solid var(--sska-border);
  background: #fff;
  overflow: hidden;
  box-shadow: 0 2px 0 rgba(0,0,0,.02);
  transition: transform .18s ease, box-shadow .18s ease;
}

.ss-ka-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--sska-shadow);
}

.ss-ka-card-link{
  display: block;
  color: inherit;
  text-decoration: none;
}

/* Mosaic (robusto: sem depender só de aspect-ratio) */
.ss-ka-mosaic{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  padding: 10px;
  background: rgba(0,0,0,.02);
}

.ss-ka-mosaic-cell{
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  background: rgba(0,0,0,.04);
}

/* fallback height */
.ss-ka-mosaic-cell::before{
  content: "";
  display: block;
  padding-top: 100%;
}

.ss-ka-mosaic-cell img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1.08);
  transition: transform .18s ease;
  display: block;
}

.ss-ka-card:hover .ss-ka-mosaic-cell img{
  transform: scale(1.12);
}

.ss-ka-card-body{
  padding: 12px 14px 14px 14px;
  text-align: center;
}

.ss-ka-card-title{
  font-weight: 700;
  font-size: 15px;
  margin: 4px 0 12px 0;
  text-transform: none;
}

.ss-ka-card-actions{
  display: flex;
  justify-content: center;
}

/* Botões */
.ss-ka-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 18px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.02);
  font-weight: 800;
  letter-spacing: .02em;
  font-size: 12px;
  text-transform: uppercase;
  line-height: 1;
}

.ss-ka-btn-primary{
  border-color: rgba(0,0,0,.06);
  background: var(--sska-accent);
  color: #fff;
}

.ss-ka-btn-ghost{
  background: transparent;
}

.ss-ka-btn:disabled{
  opacity: .55;
  cursor: not-allowed;
}

/* Builder layout */
.ss-ka-builder-top{
  margin-bottom: 18px;
}

.ss-ka-back{
  display: inline-block;
  margin-bottom: 10px;
  text-decoration: none;
  color: rgba(0,0,0,.76);
}

.ss-ka-builder-layout{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 18px;
  align-items: start;
}

@media (max-width: 980px){
  .ss-ka-builder-layout{ grid-template-columns: 1fr; }
  .ss-ka-summary{ position: static; }
}

.ss-ka-loading{
  padding: 14px 16px;
  border-radius: var(--sska-radius);
  border: 1px dashed var(--sska-border);
  color: var(--sska-muted);
}

.ss-ka-products-list{
  display: grid;
  gap: 12px;
}

.ss-ka-product{
  display: grid;
  grid-template-columns: 92px minmax(0,1fr);
  gap: 12px;
  padding: 12px;
  border-radius: var(--sska-radius);
  border: 1px solid var(--sska-border);
  background: #fff;
  transition: box-shadow .18s ease, transform .18s ease;
}

.ss-ka-product:hover{
  box-shadow: var(--sska-shadow-hover);
  transform: translateY(-1px);
}

.ss-ka-product-img{
  position: relative;
  width: 92px;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 16px;
  overflow: hidden;
  background: rgba(0,0,0,.03);
}

.ss-ka-view-product{
  display: inline-block;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.1;
  text-decoration: none;
  color: var(--sska-muted);
}

.ss-ka-view-product:hover{
  color: var(--sska-accent);
  text-decoration: underline;
}


.ss-ka-product-img::before{
  content:"";
  display:block;
  padding-top: 100%;
}

.ss-ka-product-img img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1.06);
}

.ss-ka-product-top{
  display:flex;
  gap:10px;
  justify-content:space-between;
  align-items:flex-start;
}

.ss-ka-product-name{
  font-weight:800;
  line-height:1.2;
  margin:0 0 4px 0;
}

.ss-ka-product-price{
  color: rgba(0,0,0,.78);
  font-size: 13px;
}

.ss-ka-product-actions{
  margin-top:10px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.ss-ka-attrs{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
  margin-top:8px;
}

@media (max-width: 520px){
  .ss-ka-attrs{ grid-template-columns: 1fr; }
}

.ss-ka-attr label{
  display:block;
  font-size:12px;
  color: var(--sska-muted);
  margin-bottom:6px;
}

.ss-ka-attr select{
  width:100%;
  border-radius:12px;
  border:1px solid var(--sska-border);
  padding:4px 10px;
  background:#fff;
}

.ss-ka-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--sska-border);
  background: rgba(0,0,0,.02);
  color: rgba(0,0,0,.78);
}

.ss-ka-badge.ss-ka-badge-oos{
  border-color: rgba(220,38,38,.25);
  background: rgba(220,38,38,.06);
  color: rgba(220,38,38,.9);
}

/* Summary */
.ss-ka-summary{
  position: sticky;
  top: 16px;
}

.ss-ka-summary-card{
  border: 1px solid var(--sska-border);
  border-radius: var(--sska-radius);
  background:#fff;
  box-shadow: 0 2px 0 rgba(0,0,0,.02);
  overflow:hidden;
}

.ss-ka-summary-head{
  padding: 14px 14px 10px 14px;
  border-bottom: 1px solid var(--sska-border);
  background: rgba(0,0,0,.02);
}

.ss-ka-summary-title{
  font-weight: 900;
  margin: 0;
}

.ss-ka-summary-sub{
  margin-top:4px;
  color: var(--sska-muted);
  font-size: 13px;
}

.ss-ka-summary-items{
  padding: 10px 12px;
  display:grid;
  gap:10px;
  max-height: 52vh;
  overflow:auto;
}

.ss-ka-sel{
  display:grid;
  grid-template-columns: 46px minmax(0,1fr);
  gap:10px;
  border:1px solid var(--sska-border);
  border-radius:14px;
  padding:10px;
  background:#fff;
}

/* Mini link abaixo da imagem ("ver produto") */
.ss-ka-sel-media{
  width:46px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.ss-ka-sel-view{
  display:inline-block;
  font-size: 12px;
  line-height: 1;
  color: var(--sska-muted);
  text-decoration: underline;
  border: 0;
  background: transparent;
  padding: 0;
}
.ss-ka-sel-view:hover{ color: var(--sska-text); }

.ss-ka-sel-body{ min-width: 0; }

.ss-ka-sel-actions{
  margin-top: 10px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap:10px;
  flex-wrap: wrap;
}

/* Quantidade (padrão Woo: parecido com o carrinho / Flatsome) */
.ss-ka-qty.quantity{
  display:inline-flex !important;
  align-items:center;
  margin: 0;
}
.ss-ka-qty.quantity .minus,
.ss-ka-qty.quantity .plus{
  width: 30px;
  height: 30px;
  padding: 0;
  border-radius: 8px;
  border: 1px solid var(--sska-border);
  background: rgba(0,0,0,.02);
  font-weight: 900;
  line-height: 1;
}
.ss-ka-qty.quantity .minus{ margin-right: 6px; }
.ss-ka-qty.quantity .plus{ margin-left: 6px; }
.ss-ka-qty-input.qty{
  width: 56px !important;
  height: 30px;
  padding: 0 8px;
  text-align: center;
  border-radius: 8px;
  border: 1px solid var(--sska-border);
  background: #fff;
  font-weight: 800;
  font-size: 13px;
}
.ss-ka-qty-input::-webkit-outer-spin-button,
.ss-ka-qty-input::-webkit-inner-spin-button{ -webkit-appearance: none; margin: 0; }
.ss-ka-qty-input{ -moz-appearance: textfield; }


/* Quantidade (dropdown 1 a 8) */
.ss-ka-qty-label{
  display:inline-flex;
  align-items:center;
  margin: 0;
}
.ss-ka-qty-select{
  height: 30px;
  min-width: 92px;
  padding: 0 28px 0 10px;
  border-radius: 8px;
  border: 1px solid var(--sska-border);
  background: rgba(0,0,0,.02);
  line-height: 30px;
}
.ss-ka-qty-select:focus{
  outline: none;
  box-shadow: 0 0 0 3px rgba(0,0,0,.05);
}
.ss-ka-sel-img{
  position:relative;
  width:46px;
  border-radius:12px;
  overflow:hidden;
  background: rgba(0,0,0,.03);
}

.ss-ka-sel-img::before{
  content:"";
  display:block;
  padding-top:100%;
}

.ss-ka-sel-img img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}

.ss-ka-sel-name{
  font-weight: 800;
  font-size: 13px;
  margin: 0;
}

.ss-ka-sel-meta{
  color: var(--sska-muted);
  font-size: 12px;
  margin-top: 4px;
}

.ss-ka-sel-remove{
  margin-top: 0;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--sska-border);
  background: transparent;
  font-size: 12px;
}

/* Overlay de carregamento (finalizar) */
.ss-ka-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.38);
  z-index: 999999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 16px;
  pointer-events: all;
}
.ss-ka-overlay.is-hidden{ display:none; }
.ss-ka-overlay-box{
  width: min(420px, 100%);
  border-radius: 18px;
  background: rgba(255,255,255,.95);
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
  padding: 16px 16px;
  display:flex;
  align-items:center;
  gap: 12px;
}

.ss-ka-loader{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 5px;
  width: 34px;
  height: 18px;
}
.ss-ka-loader span{
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  animation: sska-bounce 1.05s infinite ease-in-out;
  transform: translateY(0);
}
.ss-ka-loader span:nth-child(2){ animation-delay: .15s; opacity:.75; }
.ss-ka-loader span:nth-child(3){ animation-delay: .30s; opacity:.55; }

@keyframes sska-bounce{
  0%, 80%, 100%{ transform: translateY(0); }
  40%{ transform: translateY(-6px); }
}

.ss-ka-spinner{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 2px solid rgba(0,0,0,.18);
  border-top-color: rgba(0,0,0,.55);
  animation: sska-spin .7s linear infinite;
}
.ss-ka-overlay-text{
  font-weight: 900;
  letter-spacing: -.01em;
  color: rgba(0,0,0,.78);
}
@keyframes sska-spin{ to{ transform: rotate(360deg); } }

.ss-ka-summary-footer{
  padding: 12px;
  border-top: 1px solid var(--sska-border);
  display:grid;
  gap:10px;
}

.ss-ka-summary-msg{
  color: var(--sska-muted);
  font-size: 12px;
}

/* Make finalize stand out */
.ss-ka-finalize.ss-ka-btn-primary{
  background: var(--sska-accent);
}


/* ===== v1.0.3 ajustes solicitados ===== */

/* 1) Alinhar botões "VER MAIS" (mesma altura) */
.ss-ka-card{
  display:flex;
  flex-direction:column;
}
.ss-ka-mosaic{ flex: 0 0 auto; }
.ss-ka-card-body{
  flex: 1 1 auto;
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.ss-ka-card-actions{
  margin-top:auto;
}

/* 2) Imagens quadradas no construtor e no resumo (forçar contra estilos do tema) */
.ss-ka-product-img,
.ss-ka-sel-img{
  border-radius: 16px !important;
}
.ss-ka-product-img img,
.ss-ka-sel-img img{
  border-radius: 0 !important;
}

/* 3) Neutraliza estilos de price do tema dentro do plugin */
.ss-ka-wrap .price{
  font-size: 13px;
}
.ss-ka-wrap .price del{ opacity:.55; margin-right: 6px; }
.ss-ka-wrap .price ins{ text-decoration: none; }


/* ===== v1.0.4: modo guiado por etapas (categorias) ===== */
.ss-ka-steps{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin: 0 0 12px 0;
}

.ss-ka-step{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.02);
  font-weight: 800;
  font-size: 12px;
  text-transform: uppercase;
  cursor: pointer;
  user-select:none;
}

.ss-ka-step .ss-ka-step-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.18);
}

.ss-ka-step.is-active{
  border-color: rgba(0,0,0,.06);
  background: rgba(43,178,76,.10);
}

.ss-ka-step.is-active .ss-ka-step-dot{
  background: var(--sska-accent, #2bb24c);
}

.ss-ka-step small{
  font-weight: 700;
  opacity: .72;
  text-transform:none;
}

.ss-ka-product.is-hidden{
  display:none;
}

.ss-ka-product .ss-ka-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(43,178,76,.10);
  color: rgba(0,0,0,.78);
  font-size: 12px;
  font-weight: 800;
}

.ss-ka-product .ss-ka-chip .dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--sska-accent, #2bb24c);
}


/* ===== v1.0.5: força imagens QUADRADAS mesmo com Flatsome ===== */
.ss-ka-product-img{
  width: 92px !important;
  height: 92px !important;
  min-width: 92px !important;
  min-height: 92px !important;
  border-radius: 16px !important;
  position: relative !important;
  overflow: hidden !important;
}
.ss-ka-product-img::before{ display:none !important; }

.ss-ka-product-img img{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center !important;
  transform: scale(1.06) !important;
}

.ss-ka-sel-img{
  width: 46px !important;
  height: 46px !important;
  min-width: 46px !important;
  min-height: 46px !important;
  border-radius: 12px !important;
  position: relative !important;
  overflow: hidden !important;
}
.ss-ka-sel-img::before{ display:none !important; }

.ss-ka-sel-img img{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center !important;
}


/* ===== Patch 1.0.7.1: botão adicionar ao kit verde claro + remover ver produto ===== */
.ss-ka-wrap .ss-ka-btn-primary,
.ss-ka-wrap .ss-ka-add,
.ss-ka-wrap button.ss-ka-btn-primary{
  background: #c4f5d2 !important;
  border-color: rgba(0,0,0,.10) !important;
  color: rgba(0,0,0,.80) !important;
}
.ss-ka-wrap .ss-ka-btn-primary:hover,
.ss-ka-wrap .ss-ka-add:hover{
  filter: brightness(.98);
}

/* Esconde qualquer botão/link "Ver produto" que eventualmente apareça no bloco de ações */
.ss-ka-wrap .ss-ka-product-actions a,
.ss-ka-wrap .ss-ka-product-actions .ss-ka-btn-ghost{
  display:none !important;
}

/* Premium hover (card inteiro clicável, sem botão "ver produto") */
.ss-ka-card-link{
  display:block;
  text-decoration:none;
  color:inherit;
  border-radius: var(--sska-radius);
  overflow:hidden;
  position:relative;
}

.ss-ka-card{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  will-change: transform;
}

.ss-ka-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 14px 34px rgba(0,0,0,.12);
  border-color: rgba(0,0,0,.16);
}

.ss-ka-mosaic{
  position:relative;
}

.ss-ka-card-link .ss-ka-mosaic::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(to bottom, rgba(0,0,0,0) 35%, rgba(0,0,0,.18) 100%);
  opacity: .0;
  transition: opacity .18s ease;
  pointer-events:none;
}

.ss-ka-card:hover .ss-ka-mosaic::after{
  opacity: 1;
}

.ss-ka-mosaic-cell img{
  transition: transform .22s ease;
}

.ss-ka-card:hover .ss-ka-mosaic-cell img{
  transform: scale(1.03);
}

.ss-ka-card-body{
  position:relative;
}

.ss-ka-card-title{
  transition: transform .18s ease, color .18s ease;
}

.ss-ka-card:hover .ss-ka-card-title{
  transform: translateY(-1px);
}

/* Foco acessível (teclado) */
.ss-ka-card-link:focus-visible{
  outline: 3px solid rgba(0,0,0,.35);
  outline-offset: 3px;
  border-radius: var(--sska-radius);
}


/* Totais do kit (quantidade e valor) */

.ss-ka-summary-totals{
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(0,0,0,.08);
}
.ss-ka-total-line{
  display:flex;
  justify-content: space-between;
  align-items:center;
  font-size: 14px;
  margin-bottom: 8px;
}
.ss-ka-total-line strong{
  font-size: 15px;
  font-weight: 700;
}
.ss-ka-total-price{
  font-size: 17px;
  font-weight: 800;
  color: #0a7d32;
}