/**
 * StampTee — Custom CSS (Warehouse Theme)
 * Rediseño v3.0 — Estilo laTostadora
 * Paleta: Azul #1E73BE / Amarillo #FFC107 / Blanco
 */

/* ══════════════════════════════════════════════
   FUENTES E ICONOS
   ══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Outfit:wght@400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/icon?family=Material+Icons');

.material-icons {
  font-family: 'Material Icons' !important;
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  display: inline-block;
  line-height: 1;
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'liga';
}

/* ══════════════════════════════════════════════
   VARIABLES DE DISEÑO — PALETA LATOSTADORA
   ══════════════════════════════════════════════ */
:root {
  --lt-blue: #1E73BE;
  --lt-blue-dk: #155A96;
  --lt-blue-lt: #E8F1FB;
  --lt-yellow: #FFC107;
  --lt-yellow-dk: #E5AC00;
  --lt-yellow-lt: #FFF8E1;
  --lt-orange: #FF6B35;
  --lt-orange-dk: #E55A2B;
  --lt-red: #E53935;
  --lt-green: #43A047;

  --lt-white: #FFFFFF;
  --lt-cream: #FAFAFA;
  --lt-gray-50: #F8F9FA;
  --lt-gray-100: #F1F3F5;
  --lt-gray-200: #E9ECEF;
  --lt-gray-300: #DEE2E6;
  --lt-gray-500: #ADB5BD;
  --lt-gray-600: #868E96;
  --lt-gray-700: #495057;
  --lt-gray-800: #343A40;
  --lt-gray-900: #212529;
  --lt-black: #1A1A1A;

  --lt-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --lt-font-ui: 'Outfit', 'Inter', sans-serif;

  --lt-radius-sm: 4px;
  --lt-radius-md: 8px;
  --lt-radius-lg: 12px;
  --lt-radius-xl: 16px;
  --lt-radius-pill: 9999px;

  --lt-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
  --lt-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.08);
  --lt-shadow-md: 0 4px 16px rgba(0, 0, 0, 0.1);
  --lt-shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.12);
  --lt-shadow-blue: 0 4px 20px rgba(30, 115, 190, 0.25);
  --lt-shadow-yellow: 0 4px 20px rgba(255, 193, 7, 0.3);

  --lt-dur: 0.25s;
  --lt-ease: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ══════════════════════════════════════════════
   RESET Y BASE
   ══════════════════════════════════════════════ */
body {
  font-family: var(--lt-font-body) !important;
  color: var(--lt-gray-900) !important;
  background-color: var(--lt-white) !important;
  -webkit-font-smoothing: antialiased;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4 {
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  color: var(--lt-black) !important;
}

a {
  transition: color var(--lt-dur) var(--lt-ease);
}

/* ══════════════════════════════════════════════
   BARRA SUPERIOR — AMARILLO VIBRANTE
   ══════════════════════════════════════════════ */
.header-nav {
  background: linear-gradient(135deg, var(--lt-yellow), #FFD54F) !important;
  color: var(--lt-black) !important;
  padding: 8px 0 !important;
  border: none !important;
}

.header-nav .block-iqitlinksmanager,
.header-nav .right-nav,
.header-nav .left-nav {
  display: none !important;
}

.header-nav .container {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.header-nav .container::before {
  content: "🚀 Envío rápido a partir de €39  ·  🔒 Pago 100% seguro  ·  🔄 Cambios gratuitos" !important;
  display: block !important;
  text-align: center !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.03em !important;
  color: var(--lt-black) !important;
}

/* ══════════════════════════════════════════════
   HEADER PRINCIPAL
   ══════════════════════════════════════════════ */
.header-top {
  background: white !important;
  padding: 12px 0 !important;
  border-bottom: 2px solid var(--lt-gray-200) !important;
}

#desktop-header-container {
  max-width: 1200px !important;
}

.col-header-left {
  flex: 0 0 auto !important;
}

.col-header-center {
  flex-grow: 1 !important;
}

.col-header-right {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 1.5rem !important;
}

/* Logo */
#desktop_logo img {
  max-height: 55px !important;
  width: auto !important;
  transition: transform var(--lt-dur) !important;
}

#desktop_logo img:hover {
  transform: scale(1.03) !important;
}

/* Search widget - estilo laTostadora */
#search_widget {
  max-width: 480px !important;
  margin: 0 auto !important;
}

#search_widget .input-group {
  border: 2px solid var(--lt-blue) !important;
  border-radius: var(--lt-radius-pill) !important;
  overflow: hidden !important;
  background: var(--lt-white) !important;
  transition: all var(--lt-dur) !important;
}

#search_widget .input-group:focus-within {
  border-color: var(--lt-blue) !important;
  box-shadow: 0 0 0 4px rgba(30, 115, 190, 0.15) !important;
}

#search_widget input.form-search-control {
  border: none !important;
  background: transparent !important;
  height: 42px !important;
  padding: 0 1.25rem !important;
  font-family: var(--lt-font-body) !important;
  font-size: 0.9rem !important;
  color: var(--lt-black) !important;
}

#search_widget input.form-search-control::placeholder {
  color: var(--lt-gray-500) !important;
  font-style: italic;
}

#search_widget .search-btn {
  background: var(--lt-blue) !important;
  border: none !important;
  padding: 0 1.25rem !important;
  color: white !important;
  cursor: pointer !important;
  transition: background var(--lt-dur) !important;
}

#search_widget .search-btn:hover {
  background: var(--lt-blue-dk) !important;
}

/* Cart & Account */
#cart-toogle {
  border: none !important;
  background: var(--lt-blue) !important;
  padding: 8px 16px !important;
  border-radius: var(--lt-radius-pill) !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  color: white !important;
  text-decoration: none !important;
  transition: all var(--lt-dur) !important;
}

#cart-toogle:hover {
  background: var(--lt-blue-dk) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--lt-shadow-blue) !important;
}

#cart-toogle .icon {
  font-size: 1.15rem !important;
  color: white !important;
}

#cart-toogle .title {
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  font-size: 0.78rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  color: white !important;
}

#cart-toogle .cart-toggle-details {
  font-size: 0.72rem !important;
  color: rgba(255, 255, 255, 0.85) !important;
}

#user_info {
  margin: 0 !important;
}

#user_info a {
  display: flex !important;
  align-items: center !important;
  gap: 0.4rem !important;
  color: var(--lt-gray-700) !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 600 !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition: color var(--lt-dur) !important;
}

#user_info a:hover {
  color: var(--lt-blue) !important;
}

#user_info a i {
  font-size: 1.15rem !important;
}

/* ══════════════════════════════════════════════
   MEGAMENU NAVIGATION
   ══════════════════════════════════════════════ */
#iqitmegamenu-wrapper,
#iqitmegamenu-horizontal,
.cbp-hrmenu,
.cbp-hrmenu>ul,
.cbp-hrmenu-tab,
#iqitmegamenu-horizontal nav {
  background: var(--lt-white) !important;
  border: none !important;
  box-shadow: 0 1px 0 var(--lt-gray-200) !important;
}

.cbp-hrmenu .cbp-tab-title {
  color: var(--lt-gray-800) !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  padding: 14px 20px !important;
  transition: all var(--lt-dur) !important;
  position: relative !important;
}

.cbp-hrmenu .cbp-hrmenu-tab:hover .cbp-tab-title,
.cbp-hrmenu .cbp-hrmenu-tab.active .cbp-tab-title {
  color: var(--lt-blue) !important;
  background: transparent !important;
}

.cbp-hrmenu .cbp-hrmenu-tab:hover .cbp-tab-title::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 20px !important;
  right: 20px !important;
  height: 3px !important;
  background: var(--lt-blue) !important;
  border-radius: 3px 3px 0 0 !important;
}

.cbp-hrmenu .cbp-mainlink-icon,
.cbp-hrmenu .cbp-mainlink-icon::before {
  color: var(--lt-gray-800) !important;
}

#cbp-hrmenu-tab-2 {
  display: none !important;
}

/* Ocultar banners HTML por defecto */
.block-iqithtmlandbanners-html,
#iqithtmlandbanners-block-1 {
  display: none !important;
}

/* ══════════════════════════════════════════════
   TÍTULO DE SECCIÓN
   ══════════════════════════════════════════════ */
.section-title,
.products-section-title,
h2.products-section-title {
  font-family: var(--lt-font-ui) !important;
  font-size: 2rem !important;
  font-weight: 800 !important;
  text-align: center !important;
  color: var(--lt-black) !important;
  margin-bottom: 2rem !important;
  position: relative !important;
}

.section-title::after,
.products-section-title::after {
  content: '' !important;
  display: block !important;
  width: 60px !important;
  height: 4px !important;
  background: linear-gradient(90deg, var(--lt-blue), var(--lt-yellow)) !important;
  border-radius: var(--lt-radius-pill) !important;
  margin: 0.6rem auto 0 !important;
}

/* ══════════════════════════════════════════════
   TARJETAS EN CATÁLOGO — ESTILO LATOSTADORA
   ══════════════════════════════════════════════ */
.product-miniature .product-add-to-cart,
.product-miniature .product-quantity,
.product-miniature .quantity-button,
.product-miniature .btn-add-to-cart,
.product-miniature button[data-button-action="add-to-cart"],
.product-miniature .product-miniature__actions,
.product-miniature .col-add-qty,
.product-miniature .col-add-btn,
.product-miniature .col-add-wishlist,
.product-miniature .col-add-compare,
.product-miniature .product-quantity-group {
  display: none !important;
}

article.product-miniature,
.product-miniature-layout {
  background: var(--lt-white) !important;
  border: 1px solid var(--lt-gray-200) !important;
  border-radius: var(--lt-radius-lg) !important;
  overflow: hidden !important;
  position: relative !important;
  transition: all var(--lt-dur) var(--lt-ease) !important;
  box-shadow: var(--lt-shadow-xs) !important;
}

article.product-miniature:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--lt-shadow-lg) !important;
  border-color: var(--lt-blue) !important;
}

article.product-miniature::after {
  content: '🎨 Personalizar' !important;
  position: absolute !important;
  top: 45% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) scale(0.9) !important;
  background: var(--lt-blue) !important;
  color: white !important;
  font-family: var(--lt-font-ui) !important;
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  padding: 0.65rem 1.5rem !important;
  border-radius: var(--lt-radius-pill) !important;
  opacity: 0 !important;
  transition: all var(--lt-dur) var(--lt-ease) !important;
  pointer-events: none !important;
  z-index: 10 !important;
  white-space: nowrap !important;
}

article.product-miniature:hover::after {
  opacity: 1 !important;
  transform: translate(-50%, -50%) scale(1) !important;
}

article.product-miniature:hover .thumbnail-container img,
article.product-miniature:hover img {
  filter: brightness(0.88) !important;
}

/* Nombre y precio */
.product-miniature .product-title a {
  font-weight: 600 !important;
  color: var(--lt-gray-800) !important;
  font-size: 0.92rem !important;
  transition: color var(--lt-dur) !important;
}

.product-miniature:hover .product-title a {
  color: var(--lt-blue) !important;
}

.product-miniature .price,
.product-miniature .product-price-and-shipping .price {
  font-weight: 700 !important;
  font-size: 1.1rem !important;
  color: var(--lt-blue) !important;
}

/* ══════════════════════════════════════════════
   FICHA DE PRODUCTO
   ══════════════════════════════════════════════ */
.col-product-info {
  flex: 0 0 66.666667% !important;
  max-width: 66.666667% !important;
}

.product-sidebar,
.sidebar.product-sidebar {
  display: none !important;
}

h1.page-title,
.product-name,
h1.product-name {
  font-size: 2.2rem !important;
  font-weight: 800 !important;
  color: var(--lt-black) !important;
}

.product-prices .current-price,
.product-price span.price,
span.price {
  font-family: var(--lt-font-ui) !important;
  font-size: 1.85rem !important;
  font-weight: 700 !important;
  color: var(--lt-blue) !important;
}

/* Botón PERSONALIZAR — naranja/amarillo prominente */
#kb_custom_btn_link.exclusive-customize,
#kb_custom_btn_link {
  background: linear-gradient(135deg, var(--lt-orange), var(--lt-orange-dk)) !important;
  border: none !important;
  border-radius: var(--lt-radius-pill) !important;
  color: white !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  font-size: 1.05rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  padding: 1rem 2rem !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.6rem !important;
  transition: all var(--lt-dur) var(--lt-ease) !important;
  box-shadow: 0 4px 20px rgba(255, 107, 53, 0.3) !important;
  text-decoration: none !important;
  margin-bottom: 1rem !important;
}

#kb_custom_btn_link:hover {
  background: linear-gradient(135deg, var(--lt-orange-dk), #CC4A1A) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(255, 107, 53, 0.4) !important;
  color: white !important;
}

/* Reemplazar texto del botón */
#kb_custom_btn_link span {
  font-size: 0 !important;
}

#kb_custom_btn_link span .material-icons {
  display: none !important;
}

#kb_custom_btn_link span::after {
  content: '🎨 CREAR PERSONALIZACIÓN' !important;
  font-size: 1.05rem !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
}

/* Botón AÑADIR AL CARRITO — azul */
.product-add-to-cart button.add-to-cart,
#add-to-cart-or-refresh button.add-to-cart,
.add-to-cart {
  background: var(--lt-blue) !important;
  border: 2px solid var(--lt-blue) !important;
  border-radius: var(--lt-radius-pill) !important;
  color: white !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  padding: 0.85rem 2rem !important;
  width: 100% !important;
  transition: all var(--lt-dur) var(--lt-ease) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  box-shadow: var(--lt-shadow-blue) !important;
}

.product-add-to-cart button.add-to-cart:hover,
#add-to-cart-or-refresh button.add-to-cart:hover,
.add-to-cart:hover {
  background: var(--lt-blue-dk) !important;
  border-color: var(--lt-blue-dk) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(30, 115, 190, 0.35) !important;
}

/* Ocultar extras */
.col-add-wishlist,
.col-add-compare {
  display: none !important;
}

.product-actions__quantity,
.col-add-qty {
  display: none !important;
}

.col-add-btn {
  width: 100% !important;
  flex: 0 0 100% !important;
  max-width: 100% !important;
}

/* ══════════════════════════════════════════════
   PILLS DE TALLA E IMPRESIÓN
   ══════════════════════════════════════════════ */
.st-pills-container {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 0.5rem !important;
  margin-bottom: 1rem !important;
}

.st-pill {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 48px !important;
  height: 40px !important;
  padding: 0 1.1rem !important;
  border: 2px solid var(--lt-gray-200) !important;
  border-radius: var(--lt-radius-md) !important;
  font-family: var(--lt-font-ui) !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  color: var(--lt-gray-700) !important;
  cursor: pointer !important;
  transition: all 0.2s var(--lt-ease) !important;
  background: var(--lt-white) !important;
  user-select: none !important;
}

.st-pill:hover {
  border-color: var(--lt-blue) !important;
  color: var(--lt-blue) !important;
}

.st-pill.active {
  background: var(--lt-blue) !important;
  border-color: var(--lt-blue) !important;
  color: white !important;
}

.product-variants select.form-control-select,
.product-variants-item select {
  display: none !important;
}

/* Color swatches */
.product-variants-item ul li .color,
.product-variants .color {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  border: 3px solid var(--lt-gray-200) !important;
  box-shadow: inset 0 0 0 2px white !important;
  transition: all 0.2s var(--lt-ease) !important;
  display: inline-block !important;
}

.product-variants-item ul li:hover .color {
  transform: scale(1.15) !important;
  border-color: var(--lt-blue) !important;
}

.product-variants-item ul li input:checked+.color,
.product-variants-item ul li.active .color {
  border-color: var(--lt-blue) !important;
  box-shadow: 0 0 0 4px rgba(30, 115, 190, 0.2), inset 0 0 0 2px white !important;
}

/* ══════════════════════════════════════════════
   REASSURANCE
   ══════════════════════════════════════════════ */
.blockreassurance,
#block-reassurance {
  background: var(--lt-blue-lt) !important;
  border: 1px solid rgba(30, 115, 190, 0.15) !important;
  border-radius: var(--lt-radius-lg) !important;
  padding: 1.5rem !important;
  margin-top: 1.5rem !important;
}

.blockreassurance ul {
  display: flex !important;
  flex-direction: column !important;
  gap: 1rem !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}

.blockreassurance li {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.85rem !important;
  padding: 0 !important;
  border: none !important;
}

.blockreassurance li::before {
  display: none !important;
}

.reassurance-item img {
  width: 32px !important;
  height: 32px !important;
}

.blockreassurance .reassurance-title {
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  font-size: 0.85rem !important;
  color: var(--lt-blue-dk) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
}

.blockreassurance .reassurance-desc {
  font-size: 0.78rem !important;
  color: var(--lt-gray-600) !important;
}

/* ══════════════════════════════════════════════
   SOCIAL SHARING
   ══════════════════════════════════════════════ */
.social-sharing {
  margin-top: 2rem !important;
  border-top: 1px solid var(--lt-gray-200) !important;
  padding-top: 1.25rem !important;
}

.social-sharing ul {
  display: flex !important;
  gap: 10px !important;
  list-style: none !important;
  padding: 0 !important;
}

.social-sharing a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  background: var(--lt-gray-100) !important;
  color: var(--lt-gray-600) !important;
  transition: all 0.2s !important;
}

.social-sharing a:hover {
  background: var(--lt-blue) !important;
  color: white !important;
}

/* ══════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════ */
#footer {
  background: var(--lt-gray-900) !important;
  color: rgba(255, 255, 255, 0.8) !important;
  padding: 3rem 0 1.5rem !important;
  margin-top: 3rem !important;
}

#footer .footer-container {
  padding-top: 1.5rem !important;
}

#footer .h3.footer-title,
#footer .block-title {
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  color: white !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  margin-bottom: 1rem !important;
}

#footer ul li a {
  color: rgba(255, 255, 255, 0.65) !important;
  font-size: 0.88rem !important;
  transition: color var(--lt-dur) !important;
  padding: 0.2rem 0 !important;
  display: block !important;
}

#footer ul li a:hover {
  color: var(--lt-yellow) !important;
}

#footer .block_newsletter_form .form-control {
  border-radius: var(--lt-radius-pill) 0 0 var(--lt-radius-pill) !important;
  border: none !important;
  padding: 0.6rem 1.2rem !important;
}

#footer .block_newsletter_form .btn {
  background: var(--lt-yellow) !important;
  border: none !important;
  border-radius: 0 var(--lt-radius-pill) var(--lt-radius-pill) 0 !important;
  padding: 0.6rem 1.2rem !important;
  font-weight: 700 !important;
  color: var(--lt-black) !important;
  transition: background var(--lt-dur) !important;
}

#footer .block_newsletter_form .btn:hover {
  background: var(--lt-yellow-dk) !important;
}

/* ══════════════════════════════════════════════
   MÓDULO PERSONALIZACIÓN — KB CUSTOMIZER OVERRIDES
   ══════════════════════════════════════════════ */
#kbpc-container-popover {
  z-index: 99999 !important;
}

#kbcm-container-block {
  background: var(--lt-white) !important;
  box-shadow: var(--lt-shadow-lg) !important;
}

.kbpc-close-btn {
  position: absolute !important;
  top: 12px !important;
  right: 16px !important;
  z-index: 100 !important;
  background: var(--lt-gray-100) !important;
  border-radius: 50% !important;
  width: 36px !important;
  height: 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: all var(--lt-dur) !important;
}

.kbpc-close-btn:hover {
  background: var(--lt-red) !important;
  color: white !important;
}

#product-feature {
  box-shadow: none !important;
  border: 1px solid var(--lt-gray-200) !important;
  border-radius: var(--lt-radius-lg) !important;
  padding: 20px !important;
  background: var(--lt-gray-50) !important;
}

#product-feature .nav {
  background: var(--lt-white) !important;
  border-radius: var(--lt-radius-md) !important;
  border: 1px solid var(--lt-gray-200) !important;
  overflow: hidden !important;
}

#product-feature .nav li {
  text-align: center !important;
}

#product-feature .nav li a {
  color: var(--lt-gray-700) !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 600 !important;
  font-size: 0.82rem !important;
  padding: 12px 10px !important;
  transition: all var(--lt-dur) !important;
  border-bottom: 3px solid transparent !important;
}

#product-feature .nav li a i {
  font-size: 24px !important;
  display: block !important;
  margin-bottom: 4px !important;
}

#product-feature .nav li.active a,
#product-feature .nav li a:hover {
  background: var(--lt-blue) !important;
  color: white !important;
  border-bottom-color: var(--lt-blue-dk) !important;
}

/* Colors panel */
#kbcolors {
  background: var(--lt-white) !important;
  padding: 15px !important;
  border-radius: var(--lt-radius-md) !important;
}

.kb-color-item-block {
  display: inline-block !important;
  margin: 3px !important;
  padding: 2px !important;
  border: 2px solid transparent !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
}

.kb-color-item-block:hover {
  border-color: var(--lt-blue) !important;
  transform: scale(1.1) !important;
}

.kb-color-item {
  width: 30px !important;
  height: 30px !important;
  border-radius: 50% !important;
  margin: 0 !important;
  cursor: pointer !important;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.1) !important;
}

/* Canvas area */
.canvas-image {
  padding: 20px 0 !important;
  background: var(--lt-gray-50) !important;
  border-radius: var(--lt-radius-lg) !important;
}

.canvas-container-outer {
  border: 2px dashed var(--lt-blue) !important;
  border-radius: var(--lt-radius-md) !important;
  background: white !important;
}

/* Tool buttons */
.kb-icon-vertical ul {
  border: 1px solid var(--lt-gray-200) !important;
  background: var(--lt-white) !important;
  border-radius: var(--lt-radius-md) !important;
  overflow: hidden !important;
}

.kb-icon-vertical ul li {
  border-bottom: 1px solid var(--lt-gray-200) !important;
}

.kb-icon-vertical ul li:last-child {
  border-bottom: none !important;
}

.kb-icon-vertical ul li a,
.kb-icon-vertical ul li>span {
  padding: 10px !important;
  color: var(--lt-gray-700) !important;
  transition: all var(--lt-dur) !important;
}

.kb-icon-vertical ul li:hover,
.kb-icon-vertical ul li a:hover {
  background: var(--lt-blue) !important;
  color: white !important;
}

/* Price table */
.kb-pc-add-cart-block .table {
  border: 1px solid var(--lt-gray-200) !important;
  border-radius: var(--lt-radius-md) !important;
  overflow: hidden !important;
}

.kb-pc-add-cart-block .table td {
  padding: 10px 14px !important;
  font-family: var(--lt-font-body) !important;
  font-size: 0.9rem !important;
}

.kb-pc-add-cart-block .total_calc td {
  font-weight: 700 !important;
  color: var(--lt-blue) !important;
  font-size: 1rem !important;
}

/* Save customization button */
.kb-save-pc-customize-btn {
  background: linear-gradient(135deg, var(--lt-orange), var(--lt-orange-dk)) !important;
  border: none !important;
  border-radius: var(--lt-radius-pill) !important;
  color: white !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  padding: 14px 32px !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  transition: all var(--lt-dur) !important;
  box-shadow: 0 4px 16px rgba(255, 107, 53, 0.3) !important;
}

.kb-save-pc-customize-btn:hover {
  background: linear-gradient(135deg, var(--lt-orange-dk), #CC4A1A) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(255, 107, 53, 0.4) !important;
}

/* Side layers */
.kb-canvas-sub-layers {
  background: var(--lt-gray-50) !important;
  border: 1px solid var(--lt-gray-200) !important;
  border-radius: var(--lt-radius-md) !important;
  padding: 15px !important;
  margin-top: 10px !important;
}

.kb-canvas-sub-layers>ul>li>img {
  border: 2px solid var(--lt-gray-200) !important;
  border-radius: var(--lt-radius-md) !important;
  transition: all 0.2s !important;
  padding: 4px !important;
  background: white !important;
}

.kb-canvas-sub-layers>ul>li>img:hover {
  border-color: var(--lt-blue) !important;
  box-shadow: var(--lt-shadow-sm) !important;
}

/* Text editing */
.upload-custom-text label,
.custom-text-editing .form-group>label,
.image-custom-editing .form-group>label {
  color: var(--lt-gray-700) !important;
  font-family: var(--lt-font-ui) !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
}

.upload-custom-text #uploaded-text,
.custom-text-editing textarea {
  border: 2px solid var(--lt-gray-200) !important;
  border-radius: var(--lt-radius-md) !important;
  padding: 10px !important;
  font-family: var(--lt-font-body) !important;
  transition: border-color var(--lt-dur) !important;
}

.upload-custom-text #uploaded-text:focus,
.custom-text-editing textarea:focus {
  border-color: var(--lt-blue) !important;
  box-shadow: 0 0 0 3px rgba(30, 115, 190, 0.1) !important;
  outline: none !important;
}

.text-upload-btn,
.kb-add-qrcode-product {
  background: var(--lt-blue) !important;
  border: none !important;
  border-radius: var(--lt-radius-pill) !important;
  color: white !important;
  font-weight: 600 !important;
  padding: 8px 20px !important;
  transition: all var(--lt-dur) !important;
}

.text-upload-btn:hover,
.kb-add-qrcode-product:hover {
  background: var(--lt-blue-dk) !important;
}

.form-group .font-btn {
  background: var(--lt-white) !important;
  border: 1px solid var(--lt-gray-200) !important;
  border-radius: var(--lt-radius-sm) !important;
  padding: 6px 12px !important;
  color: var(--lt-gray-700) !important;
  transition: all var(--lt-dur) !important;
  margin: 6px 2px !important;
}

.form-group .font-btn:hover {
  border-color: var(--lt-blue) !important;
  color: var(--lt-blue) !important;
}

.form-group .font-btn.btn-active {
  background: var(--lt-blue) !important;
  border-color: var(--lt-blue) !important;
  color: white !important;
}

/* Upload section */
.upload-custom-image h4 {
  font-family: var(--lt-font-ui) !important;
  font-size: 0.95rem !important;
  color: var(--lt-blue) !important;
  font-weight: 600 !important;
}

/* ══════════════════════════════════════════════
   PÁGINAS CMS LEGALES — Normalización
   ══════════════════════════════════════════════ */
#cms .page-cms .cms-box,
#content-wrapper .page-cms .cms-box,
.page-cms .cms-box {
  max-width: 900px;
  margin: 0 auto;
  padding: 20px 15px 40px;
  font-family: var(--lt-font-body);
  color: var(--lt-gray-700);
  line-height: 1.75;
  font-size: 15px;
}

.page-cms .cms-box h2 {
  font-family: var(--lt-font-ui) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--lt-blue) !important;
  margin: 30px 0 12px !important;
  padding-bottom: 8px !important;
  border-bottom: 2px solid var(--lt-blue) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
}

.page-cms .cms-box h3 {
  font-family: var(--lt-font-ui) !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  color: var(--lt-gray-800) !important;
  margin: 24px 0 8px !important;
  padding: 0 !important;
  border: none !important;
  text-transform: none !important;
}

.page-cms .cms-box h4 {
  font-family: var(--lt-font-ui) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--lt-gray-700) !important;
  margin: 16px 0 6px !important;
}

.page-cms .cms-box p {
  font-size: 14.5px !important;
  line-height: 1.75 !important;
  margin-bottom: 12px !important;
  color: var(--lt-gray-700) !important;
}

.page-cms .cms-box ul,
.page-cms .cms-box ol {
  padding-left: 24px !important;
  margin-bottom: 14px !important;
}

.page-cms .cms-box li {
  font-size: 14.5px !important;
  line-height: 1.7 !important;
  margin-bottom: 4px !important;
  color: var(--lt-gray-700) !important;
}

.page-cms .cms-box table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 15px 0 20px !important;
  font-size: 13.5px !important;
}

.page-cms .cms-box table th {
  background: var(--lt-blue) !important;
  color: white !important;
  padding: 10px 12px !important;
  font-weight: 600 !important;
  text-align: left !important;
  font-size: 13px !important;
}

.page-cms .cms-box table td {
  padding: 8px 12px !important;
  border-bottom: 1px solid var(--lt-gray-200) !important;
}

.page-cms .cms-box table tr:nth-child(even) td {
  background: var(--lt-gray-50) !important;
}

.page-cms .cms-box a {
  color: var(--lt-blue) !important;
  text-decoration: underline !important;
}

.page-cms .cms-box a:hover {
  color: var(--lt-blue-dk) !important;
}

/* ══════════════════════════════════════════════
   ANIMACIONES
   ══════════════════════════════════════════════ */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.product-miniature {
  animation: fadeInUp 0.4s ease both;
}

.product-miniature:nth-child(2) {
  animation-delay: 0.05s;
}

.product-miniature:nth-child(3) {
  animation-delay: 0.10s;
}

.product-miniature:nth-child(4) {
  animation-delay: 0.15s;
}

.product-miniature:nth-child(5) {
  animation-delay: 0.20s;
}

/* ══════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════ */
@media (max-width: 768px) {

  h1.page-title,
  .product-name {
    font-size: 1.5rem !important;
  }

  .product-prices .current-price {
    font-size: 1.5rem !important;
  }

  #add-to-cart-or-refresh button.add-to-cart,
  #kb_custom_btn_link {
    font-size: 0.9rem !important;
    padding: 0.75rem 1.5rem !important;
  }

  .product-variants-item ul li .color {
    width: 28px !important;
    height: 28px !important;
  }

  .col-product-info {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
}