/* ============================================================
   TEMPLATE SHOWCASE PRO — FRONTEND STYLES v5.1
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

.ts-showcase {
  --ts-yellow:      #fdc647;
  --ts-yellow-dark: #e6ad25;
  --ts-dark:        #2f3a44;
  --ts-dark-light:  #3d4e5c;
  --ts-text:        #1a2530;
  --ts-muted:       #5f7080;
  --ts-border:      #dde3e9;
  --ts-surface:     #ffffff;
  --ts-bg-soft:     #f5f7f9;
  --ts-radius:      12px;
  --ts-card-shadow: 0 2px 8px rgba(47,58,68,.07), 0 8px 24px rgba(47,58,68,.09);
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: var(--ts-text);
}

/* ============================================================
   FILTER BAR — scrollable with arrow buttons + STICKY
   ============================================================ */
.ts-filter-wrap {
    position: sticky;
    top: 0;
    z-index: 100;
    background: #fff;
    padding: 10px 0;
    margin-bottom: 28px;
    /* Sin sombra por defecto */
    box-shadow: none;
    transition: box-shadow .25s, border-color .25s;
}
/* Solo cuando está pegado: sombra limpia sin border-radius */
.ts-filter-wrap.ts-is-sticky {
  box-shadow: 0 3px 12px rgba(47,58,68,.10);
}
.ts-filter-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1.5px solid var(--ts-border);
    background: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    line-height: 1;
    color: var(--ts-dark);
    transition: all .18s;
    box-shadow: 0 1px 6px rgba(0, 0, 0, .10);
    flex-shrink: 0;
    padding: 0;
    margin-bottom: 0 !important;
    margin-top: -8px;
}
.ts-filter-arrow:hover {
  background: var(--ts-dark);
  color: var(--ts-yellow);
  border-color: var(--ts-dark);
}
.ts-filter-arrow.ts-arr-left  { left: 0; }
.ts-filter-arrow.ts-arr-right { right: 0; }
.ts-filter-arrow.hidden { opacity:0; pointer-events:none; }
.ts-filter-wrap::before,
.ts-filter-wrap::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 48px;
  z-index: 5;
  pointer-events: none;
}
.ts-filter-wrap::before { left:0px;  background: linear-gradient(to right, #fff 60%, transparent); }
.ts-filter-wrap::after  { right:0px; background: linear-gradient(to left,  #fff 60%, transparent); }
.ts-filter-bar {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 4px 48px;
}
.ts-filter-bar::-webkit-scrollbar { display: none; }
.ts-filter-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: 50px;
  border: 1.5px solid var(--ts-border);
  background: #fff;
  color: var(--ts-muted);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all .18s;
  font-family: inherit;
  white-space: nowrap;
  flex-shrink: 0;
}
.ts-filter-btn em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #eef1f4;
  color: var(--ts-muted);
  border-radius: 20px;
  padding: 1px 7px;
  font-size: 11px;
  font-style: normal;
  transition: all .18s;
}
.ts-filter-btn:hover { border-color:var(--ts-dark); color:var(--ts-dark); background:#f5f7f9; }
.ts-filter-btn.active {
  background: var(--ts-dark);
  border-color: var(--ts-dark);
  color: #fff;
  box-shadow: 0 4px 14px rgba(47,58,68,.28);
}
.ts-filter-btn.active em { background:var(--ts-yellow); color:var(--ts-dark); }

/* ============================================================
   CARD
   ============================================================ */
.ts-card {
  background: var(--ts-surface);
  border-radius: var(--ts-radius);
  overflow: hidden;
  border: 1.5px solid var(--ts-border);
  box-shadow: var(--ts-card-shadow);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s;
  display: flex;
  flex-direction: column;
  height: 100%;
  cursor: pointer;
}
.ts-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 36px rgba(47,58,68,.18);
  border-color: var(--ts-yellow);
}
.ts-card-thumb {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--ts-bg-soft);
}
.ts-card-thumb img {
  width:100%; height:100%; object-fit:cover;
  transition: transform .4s ease;
  display: block;
}
.ts-card:hover .ts-card-thumb img { transform: scale(1.05); }
.ts-no-img {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  font-size:40px; background:#eef1f4;
}
.ts-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 30%, rgba(47,58,68,.85));
  display: flex; align-items:flex-end; justify-content:center;
  padding: 16px; opacity: 0; transition: opacity .22s;
}
.ts-card:hover .ts-card-overlay { opacity: 1; }
.ts-card-preview-btn {
    background: var(--ts-yellow);
    border: none;
    border-radius: 8px;
    padding: 9px 22px;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
    color: var(--ts-dark);
    font-family: inherit;
    transition: all .15s;
    letter-spacing: .2px;
    margin-bottom: 4em;
}
.ts-card-preview-btn:hover { background:#fff; transform:scale(1.03); }
.ts-card-info { padding: 14px 16px 8px; flex:1; }
.ts-card-name {
  margin: 0 0 6px; font-size:14.5px; font-weight:700;
  color: var(--ts-text); line-height:1.35;
}
.ts-card-cat {
  display:inline-flex; background:#fff8e0; color:#8b6200;
  border-radius:20px; padding:2px 10px;
  font-size:11.5px; font-weight:700; border:1px solid #fdc647;
}
.ts-card-actions { padding:10px 14px 14px; display:flex; gap:8px; }
.ts-btn-demo {
  flex:1; background:var(--ts-dark); color:#fff; border:none;
  border-radius:8px; padding:9px 14px; font-size:13px;
  font-weight:700; cursor:pointer; transition:background .15s; font-family:inherit;
}
.ts-btn-demo:hover { background: var(--ts-dark-light); }
.ts-btn-trial {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    background: var(--ts-yellow);
    color: var(--ts-dark);
    border: none;
    border-radius: 8px;
    padding: 9px 14px;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
    text-decoration: none;
    transition: all .15s;
    font-family: inherit;
    max-height: 50px;
    text-transform: uppercase;
}
.ts-btn-trial:hover { background:var(--ts-yellow-dark); color:var(--ts-dark); transform:scale(1.02); }

/* ============================================================
   CAROUSEL
   ============================================================ */
.ts-swiper { padding-bottom: 44px !important; overflow: visible !important; }
.ts-swiper .swiper-wrapper { align-items:stretch; }
.ts-swiper .swiper-slide   { height:auto; }
.ts-swiper .swiper-button-prev,
.ts-swiper .swiper-button-next {
  width:42px; height:42px; border-radius:50%;
  background: var(--ts-dark);
  box-shadow: 0 4px 14px rgba(47,58,68,.35);
  top: calc(50% - 30px);
}
.ts-swiper .swiper-button-prev::after,
.ts-swiper .swiper-button-next::after {
  font-size:15px; font-weight:800; color:var(--ts-yellow);
}
.ts-swiper .swiper-button-prev:hover,
.ts-swiper .swiper-button-next:hover { background: var(--ts-yellow); }
.ts-swiper .swiper-button-prev:hover::after,
.ts-swiper .swiper-button-next:hover::after { color: var(--ts-dark); }
.ts-swiper .swiper-pagination-bullet { background:var(--ts-border); opacity:1; }
.ts-swiper .swiper-pagination-bullet-active {
  background: var(--ts-dark); width:20px; border-radius:4px; transition:width .25s;
}

/* ============================================================
   GRID / ROW
   ============================================================ */
.ts-grid {
  display:grid;
  grid-template-columns: repeat(var(--ts-cols,4), 1fr);
  gap: var(--ts-gap, 24px);
}
.ts-grid-item { display:flex; }
.ts-grid-item .ts-card { width:100%; }
@media (max-width:1100px) { .ts-grid { grid-template-columns: repeat(3,1fr); } }
@media (max-width:768px)  { .ts-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width:480px)  { .ts-grid { grid-template-columns: 1fr; } }

/* ============================================================
   LIST
   ============================================================ */
.ts-list { display:flex; flex-direction:column; gap:12px; }
.ts-list-item {
  display:flex; align-items:center; gap:16px;
  background:var(--ts-surface); border:1.5px solid var(--ts-border);
  border-radius:var(--ts-radius); padding:14px 18px;
  box-shadow:var(--ts-card-shadow);
  transition:border-color .2s, box-shadow .2s; cursor:pointer;
}
.ts-list-item:hover { border-color:var(--ts-yellow); box-shadow:0 4px 20px rgba(47,58,68,.13); }
.ts-li-thumb {
  flex-shrink:0; width:110px; height:72px;
  border-radius:8px; overflow:hidden;
  background:var(--ts-bg-soft); border:1px solid var(--ts-border);
}
.ts-li-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.ts-li-info { flex:1; }
.ts-li-info h3 { margin:0 0 4px; font-size:15px; font-weight:700; }
.ts-li-cat {
  background:#fff8e0; color:#8b6200;
  border-radius:20px; padding:2px 10px;
  font-size:11.5px; font-weight:700;
  border:1px solid #fdc647; display:inline-flex;
}
.ts-li-actions { display:flex; gap:8px; flex-shrink:0; }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.ts-lightbox {
  position: fixed; inset: 0; z-index: 999999;
  display: none; align-items:center; justify-content:center;
  padding: 24px;
}
.ts-lightbox.active { display: flex; }
.ts-lb-overlay {
  position: fixed; inset: 0;
  background: rgba(15,22,28,.92);
  backdrop-filter: blur(8px);
  z-index: 1;
}
/* Constrained container */
.ts-lb-inner {
  position: relative; z-index: 2;
  width: 100%; max-width: 1180px;
  height: 100%; max-height: 840px;
  background: var(--ts-surface);
  border-radius: 18px;
  overflow: hidden;
  display: flex; flex-direction: column;
  animation: ts-lb-in .26s cubic-bezier(.34,1.15,.64,1);
  box-shadow: 0 40px 100px rgba(0,0,0,.55);
}
@keyframes ts-lb-in {
  from { opacity:0; transform:scale(.9) translateY(20px); }
  to   { opacity:1; transform:scale(1)  translateY(0); }
}
.ts-lb-topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding: 0 20px; height:58px; min-height:58px;
  background: #fdc647; flex-shrink:0; gap:12px;
}
.ts-lb-title {
  color:#fff; font-weight:800; font-size:15px;
  font-family:'Plus Jakarta Sans',sans-serif;
  flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.ts-lb-controls { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.ts-lb-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; border-radius:8px;
  font-size:13px; font-weight:700; text-decoration:none;
  cursor:pointer; border:none;
  font-family:'Plus Jakarta Sans',sans-serif;
  transition:all .15s; white-space:nowrap;
}
.ts-lb-trial { background:var(--ts-yellow); color:var(--ts-dark); }
.ts-lb-trial:hover { background:#ffe076; color:var(--ts-dark); transform:scale(1.03); }
.ts-lb-demo  { background:rgba(255,255,255,.1); color:#fff; border:1.5px solid rgba(255,255,255,.18); }
.ts-lb-demo:hover { background:rgba(255,255,255,.2); color:#fff; }
.ts-lb-close {
    background: rgba(255, 255, 255, .1);
    color: #fff;
    border: none;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-size: 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s;
    font-family: inherit;
    flex-shrink: 0;
    margin: 0;
}
.ts-lb-close:hover { background:#ef4444; }
.ts-lb-frame-wrap {
  flex:1; position:relative; overflow:hidden; min-height:0;
}
.ts-lb-iframe {
  position:absolute; inset:0;
  width:100%; height:100%; border:none; display:block;
}
.ts-lb-loading {
  position:absolute; inset:0;
  background:var(--ts-bg-soft);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:14px; z-index:10;
}
.ts-lb-loading-text { font-size:13px; color:var(--ts-muted); font-family:'Plus Jakarta Sans',sans-serif; }
.ts-spinner {
  width:44px; height:44px;
  border:4px solid var(--ts-border);
  border-top-color: var(--ts-dark);
  border-right-color: var(--ts-yellow);
  border-radius:50%;
  animation: ts-spin .75s linear infinite;
}
@keyframes ts-spin { to { transform: rotate(360deg); } }
body.ts-lb-open { overflow:hidden; }
.ts-empty { text-align:center; color:var(--ts-muted); padding:40px; font-size:15px; }

@media (max-width:700px) {
  .ts-lightbox { padding:0; }
  .ts-lb-inner { max-width:none; max-height:none; border-radius:0; }
  .ts-lb-btn { padding:7px 10px; font-size:12px; }
}

/* ============================================================
   CARD FILTER ANIMATIONS — efecto shuffle/reordenamiento
   ============================================================ */

/* Estado base para grid-items y list-items */
.ts-grid-item,
.ts-list-item {
  transition:
    opacity .32s ease,
    transform .38s cubic-bezier(.34,1.15,.64,1),
    scale .32s cubic-bezier(.34,1.15,.64,1);
  transform-origin: center center;
}

/* Cuando se oculta: se achica y desaparece */
.ts-grid-item.ts-hidden,
.ts-list-item.ts-hidden {
  opacity: 0;
  transform: scale(0.82) translateY(12px);
  pointer-events: none;
}

/* Cuando aparece: viene desde abajo con rebote */
.ts-grid-item.ts-entering,
.ts-list-item.ts-entering {
  animation: ts-card-enter .42s cubic-bezier(.34,1.15,.64,1) both;
}

@keyframes ts-card-enter {
  0%   { opacity: 0; transform: scale(0.80) translateY(18px); }
  60%  { opacity: 1; transform: scale(1.04) translateY(-4px); }
  100% { opacity: 1; transform: scale(1)    translateY(0); }
}

/* Stagger delay para que las cards entren en cascada */
.ts-grid-item:nth-child(1),  .ts-list-item:nth-child(1)  { animation-delay: 0ms; }
.ts-grid-item:nth-child(2),  .ts-list-item:nth-child(2)  { animation-delay: 40ms; }
.ts-grid-item:nth-child(3),  .ts-list-item:nth-child(3)  { animation-delay: 80ms; }
.ts-grid-item:nth-child(4),  .ts-list-item:nth-child(4)  { animation-delay: 120ms; }
.ts-grid-item:nth-child(5),  .ts-list-item:nth-child(5)  { animation-delay: 160ms; }
.ts-grid-item:nth-child(6),  .ts-list-item:nth-child(6)  { animation-delay: 200ms; }
.ts-grid-item:nth-child(7),  .ts-list-item:nth-child(7)  { animation-delay: 240ms; }
.ts-grid-item:nth-child(8),  .ts-list-item:nth-child(8)  { animation-delay: 280ms; }
.ts-grid-item:nth-child(9),  .ts-list-item:nth-child(9)  { animation-delay: 310ms; }
.ts-grid-item:nth-child(10), .ts-list-item:nth-child(10) { animation-delay: 330ms; }
.ts-grid-item:nth-child(n+11), .ts-list-item:nth-child(n+11) { animation-delay: 350ms; }

/* ============================================================
   IFRAME LOADING OVERLAY — "Cargando, espere por favor..."
   ============================================================ */
.ts-lb-loading {
    position: absolute;
    inset: 0;
    background: var(--ts-bg-soft);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 18px;
    z-index: 10;
    background: #fffffff5;
}

/* Mensaje de carga mejorado */
.ts-lb-loading-text {
  font-size: 15px;
  font-weight: 600;
  color: var(--ts-dark);
  font-family: 'Plus Jakarta Sans', sans-serif;
  letter-spacing: .2px;
  animation: ts-pulse-text 1.6s ease-in-out infinite;
}

@keyframes ts-pulse-text {
  0%, 100% { opacity: 1; }
  50%       { opacity: .55; }
}

/* Spinner más visible */
.ts-spinner {
  width: 52px; height: 52px;
  border: 5px solid var(--ts-border);
  border-top-color: var(--ts-dark);
  border-right-color: var(--ts-yellow);
  border-radius: 50%;
  animation: ts-spin .75s linear infinite;
  box-shadow: 0 0 0 4px rgba(253,198,71,.15);
}

/* Subtexto animado de puntos */
.ts-lb-loading-dots {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
  animation: ts-ellipsis 1.4s steps(4, end) infinite;
  width: 20px;
  text-align: left;
}
@keyframes ts-ellipsis {
  0%  { clip-path: inset(0 75% 0 0); }
  25% { clip-path: inset(0 50% 0 0); }
  50% { clip-path: inset(0 25% 0 0); }
  75% { clip-path: inset(0 0   0 0); }
}
