
.vp-wrap{display:grid;grid-template-columns:320px 1fr;gap:20px}
@media (max-width: 900px){ .vp-wrap{grid-template-columns:1fr} .vp-sidebar{order:1} .vp-content{order:2} }
/* Sidebar sem scrollbar interna no desktop.
   A página (window) faz a rolagem natural e as categorias podem crescer.
   No mobile, o drawer usa .vp-sidebar-panel com overflow próprio (ver mobile-sticky.css). */
.vp-sidebar{background:var(--vp-sidebar,#111827);color:#fff;padding:16px;border-radius:12px}
.vp-search{width:100%;padding:10px;border-radius:10px;border:1px solid #333;margin:12px 0;background:#0f172a;color:#fff}
.vp-all{width:100%;padding:10px;border:none;border-radius:10px;background:#374151;color:#fff;margin-top:8px;cursor:pointer}
.vp-cat-select{width:100%;padding:10px;border-radius:10px;border:1px solid #cbd5e1;background:#ffffff;color:#111827}

/* GRID */
.vp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}

/* CARD */
.vp-card{display:flex;flex-direction:column;border:1px solid #e5e7eb;border-radius:16px;overflow:hidden;background:#fff}
.vp-header{padding:12px 12px 0}
.vp-title{margin:0;color:#0EA5E9;text-align:center;font-size:clamp(1rem, 2vw, 1.25rem)}
.vp-sub{margin:6px 0 0 0;color:#374151;text-align:center;font-size:clamp(.9rem, 1.5vw, 1rem)}

/* MEDIA */
.vp-media{position:relative;background:#f8fafc}
.vp-media .vp-slide{display:none;aspect-ratio:4/3;align-items:center;justify-content:center}
.vp-media .vp-slide.active{display:flex}
.vp-media img{width:100%;height:100%;object-fit:contain}
.vp-nav{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;pointer-events:none}
.vp-nav button{pointer-events:auto;background:rgba(0,0,0,.3);border:none;border-radius:999px;color:#fff;padding:6px 10px;margin:6px}

/* DESCRIPTION (4 lines) */
.vp-body{padding:12px;position:relative}
.vp-body .sub{
  margin:0;color:#374151;
  font-size:clamp(.92rem, 1.6vw, 1rem);
  line-height:1.5;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:4;
  overflow:hidden;
}
@supports not (-webkit-line-clamp: 4) {
  .vp-body .sub{
    max-height: calc(1.5em * 4);
    position:relative;
  }
  .vp-body .sub::after{
    content:"";position:absolute;left:0;right:0;bottom:0;height:2.2em;
    background:linear-gradient(180deg, rgba(255,255,255,0), #fff);
  }
}

/* ACTIONS: stacked & sticky to bottom of card */
.vp-actions-bottom{
  display:flex;flex-direction:column;gap:10px;
  padding:12px;margin-top:auto;
}

/* BUTTONS */
.vp-btn{
  width:100%;
  text-align:center;text-decoration:none;border-radius:12px;
  padding:12px 14px; border:1px solid #e5e7eb;
  font-size:clamp(.95rem, 1.5vw, 1.05rem); font-weight:600;
  transition:transform .12s ease, box-shadow .2s ease, opacity .2s ease;
  will-change:transform;
}
.vp-btn.wa{background:#10B981;color:#fff;border-color:transparent}
.vp-btn.pdf{background:#0EA5E9;color:#fff;border-color:transparent}
.vp-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.08)}
.vp-btn:active{transform:translateY(0);box-shadow:0 3px 8px rgba(0,0,0,.06);opacity:.96}
.vp-btn:focus-visible{outline:3px solid rgba(14,165,233,.45);outline-offset:2px}
@media (prefers-reduced-motion: reduce){ .vp-btn{transition:none} }

/* PAGINATION */
.vp-pagination{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:16px}
.vp-pagination button{padding:8px 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:transform .1s ease}
.vp-pagination button:hover{transform:translateY(-1px)}


/* FILTERS UI */
.vp-tags{margin-top:12px}
.vp-chiplist{display:flex;flex-wrap:wrap;gap:8px}
.vp-chip{border:1px solid #e5e7eb;background:#fff;padding:6px 10px;border-radius:999px;cursor:pointer;font-size:.9rem;transition:all .15s ease}
.vp-chip.is-active{background:#0EA5E9;color:#fff;border-color:transparent;box-shadow:0 6px 14px rgba(14,165,233,.25)}
.vp-f-extra{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}
.vp-order-wrap select, .vp-perpage{width:100%;padding:8px;border-radius:10px;border:1px solid #cbd5e1;background:#ffffff;color:#111827}
.vp-f-meta{display:flex;align-items:center;gap:10px;margin-top:10px}
.vp-result-count{margin-left:auto;opacity:.85;font-size:.9rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Sidebar filters v3 */
.vp-filter-block{margin-top:12px}
.vp-filter-block:first-child{margin-top:0}
.vp-filter-title{font-weight:700;font-size:.95rem;margin:0 0 8px 0;color:#fff}

/* Sidebar accordions */
.vp-acc{margin-top:12px;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:rgba(255,255,255,.03);overflow:hidden}
.vp-acc:first-of-type{margin-top:12px}
.vp-acc-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:0;background:transparent;color:#fff;cursor:pointer;font-weight:800}
.vp-acc-head:hover{background:rgba(255,255,255,.04)}
.vp-acc-ico{opacity:.9}
.vp-acc-panel{padding:10px 12px 12px}
/* Alguns temas sobrescrevem [hidden] — força o accordion a realmente ocultar */
.vp-acc-panel[hidden]{display:none !important}

.vp-cat-all{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;cursor:pointer;font-weight:700;margin-bottom:10px}
.vp-cat-all:hover{filter:brightness(1.05)}

/*
  Categorias: sem scrollbar interna.
  A sidebar inteira já tem overflow:auto; então a árvore pode crescer livremente.
*/
.vp-cat-tree{max-height:none;overflow:visible;overflow-x:visible;padding-right:0}
.vp-tree{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.vp-node{margin:0;padding:0}
.vp-node-row{display:flex;align-items:center;gap:8px}
.vp-cat-btn{
  flex:1;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  text-align:left;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:#fff;
  cursor:pointer;
  line-height:1.25;
  min-width:0;
  white-space:normal;
  overflow-wrap:break-word;
  word-break:normal;
  hyphens:auto;
}
.vp-cat-label{flex:1;min-width:0;white-space:normal;overflow-wrap:break-word;word-break:normal;hyphens:auto}
.vp-cat-chevron{
  flex:none;
  width:34px;
  height:34px;
  margin-left:10px;
  display:inline-grid;
  place-items:center;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-size:12px;
  line-height:1;
  cursor:pointer;
  user-select:none;
}
.vp-cat-btn:hover{background:rgba(255,255,255,.08)}
/* Pais em destaque */
.vp-cat-btn.is-parent{font-weight:900;letter-spacing:.2px;background:rgba(255,255,255,.06)}
/* Ativo sempre prevalece (inclusive quando é categoria pai) */
.vp-cat-btn.is-active{background:rgba(16,185,129,.95);border-color:transparent;color:#fff;box-shadow:0 10px 22px rgba(16,185,129,.22)}
.vp-cat-btn.is-parent.is-active{background:rgba(16,185,129,.95);border-color:transparent;color:#fff}
.vp-cat-btn.is-child{opacity:.92}
.vp-children{list-style:none;margin:8px 0 0 0;padding:0 0 0 22px;display:flex;flex-direction:column;gap:8px}
/* Alguns temas sobrescrevem o comportamento padrão do atributo [hidden].
   Garante que o recolher/expandir da árvore de categorias funcione sempre. */
.vp-children[hidden]{display:none !important}

@media (max-width: 900px){
  .vp-cat-tree{max-height:none;overflow:visible;overflow-x:visible}
  .vp-cat-btn{padding:12px 12px;font-size:.98rem}
}

.vp-brand-select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff}
.vp-brand-select option{color:#111827}

.vp-range-group{margin-top:10px}
.vp-range-group label{display:block;margin:0 0 6px 0;font-weight:600;color:#fff;opacity:.95}
.vp-range{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.vp-range-input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff}
.vp-range-input::placeholder{color:rgba(255,255,255,.65)}

/* Faixas (select) */
.vp-range-select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;appearance:none}
.vp-range-select option{color:#111}

/* Selects: make sure chosen value never "disappears" (mobile/Chrome quirks) */
.vp-brand-select,.vp-range-select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-color:rgba(255,255,255,.08) !important;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(255,255,255,.92) 50%),
    linear-gradient(135deg, rgba(255,255,255,.92) 50%, transparent 50%),
    linear-gradient(to right, rgba(255,255,255,.0), rgba(255,255,255,.0));
  background-position:
    calc(100% - 18px) 50%,
    calc(100% - 12px) 50%,
    100% 0;
  background-size:6px 6px, 6px 6px, 2.5em 2.5em;
  background-repeat:no-repeat;
  padding-right:44px;
}
.vp-brand-select:focus,.vp-range-select:focus{outline:3px solid rgba(14,165,233,.45);outline-offset:2px}

/* Highlight when a filter is actually selected */
.vp-brand-select.vp-is-selected,
.vp-range-select.vp-is-selected{
  background-color:#0EA5E9 !important;
  border-color:transparent !important;
  color:#fff !important;
  box-shadow:0 10px 22px rgba(14,165,233,.18);
}

/* Mobile filter bar (hidden on desktop) */
.vp-mobilebar{display:none}

/* Content topbar / breadcrumb */
.vp-content{position:relative}
.vp-topbar{margin:0 0 12px 0}
.vp-breadcrumb{display:none;align-items:center;flex-wrap:wrap;gap:6px;padding:8px 10px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;color:#334155;font-size:.95rem;line-height:1.25}
.vp-breadcrumb.is-visible{display:inline-flex}
.vp-breadcrumb .vp-sep{opacity:.45}

/* Loading indicator (non-blocking) */
.vp-loading-overlay{position:absolute;top:10px;right:10px;z-index:5;display:none;background:rgba(15,23,42,.92);color:#fff;padding:6px 10px;border-radius:999px;font-size:12px;box-shadow:0 10px 22px rgba(0,0,0,.12)}
.vp-wrap.vp-loading .vp-loading-overlay{display:block}
.vp-wrap.vp-loading .vp-grid{opacity:.7}

/* Empty state */
.vp-empty{padding:22px;border-radius:16px;border:1px dashed #cbd5e1;background:#f8fafc;color:#334155;text-align:center}
.vp-empty strong{display:block;margin-bottom:6px;color:#0f172a}

/* Mobile-only close button (shown by mobile CSS) */
.vp-mobile-close{display:none}

/* WhatsApp popup (optional) */
.vpsafe-wa-modal{position:fixed;inset:0;z-index:99999;display:none}
.vpsafe-wa-modal.is-open{display:block}
.vpsafe-wa-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.vpsafe-wa-dialog{position:relative;max-width:420px;width:calc(100% - 24px);margin:8vh auto 0;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 18px 60px rgba(0,0,0,.25)}
.vpsafe-wa-head{background:#075E54;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 14px}
.vpsafe-wa-head-left{display:flex;align-items:center;gap:10px}
.vpsafe-wa-avatar{
  width:34px;
  height:34px;
  border-radius:50%;
  background-color:rgba(255,255,255,.25);
  background-image:var(--vpsafe-wa-logo, none);
  background-size:contain;
  background-position:center;
  background-repeat:no-repeat;
}
.vpsafe-wa-brand-name{font-weight:800;line-height:1.05}
.vpsafe-wa-brand-status{font-size:.85rem;opacity:.85;margin-top:2px}
.vpsafe-wa-x{border:none;background:transparent;color:#fff;font-size:22px;line-height:1;cursor:pointer}
.vpsafe-wa-body{padding:14px 14px 16px;background:#f4f7f9}
.vpsafe-wa-bubble{background:#fff;border-radius:12px;padding:10px 12px;margin:0 0 12px 0;box-shadow:0 8px 24px rgba(0,0,0,.08);color:#111827;font-size:.98rem}
.vpsafe-wa-field{margin:10px 0}
.vpsafe-wa-field input{width:100%;padding:12px 12px;border-radius:12px;border:1px solid #d1d5db;font-size:1rem;background:#e8f5e9}
.vpsafe-wa-field input:focus{outline:none;border-color:#10B981;box-shadow:0 0 0 3px rgba(16,185,129,.18)}
.vpsafe-wa-start{width:100%;padding:12px 14px;border-radius:14px;border:none;background:#0f766e;color:#fff;font-weight:900;letter-spacing:.06em;cursor:pointer;text-transform:uppercase;margin-top:8px}
.vpsafe-wa-start:hover{filter:brightness(1.03)}
.vpsafe-wa-start:active{filter:brightness(.97)}
.vpsafe-wa-hint{margin:10px 0 0 0;font-size:.95rem;color:#b91c1c;min-height:1.2em}
