/*
 Theme Name:   Glitch Uru
 Theme URI:    https://glitchuru.local
 Description:  Child theme de Storefront para Glitch Uru - estética dark glitch
 Author:       Glitch Uru
 Template:     storefront
 Version:      1.0.0
 Text Domain:  glitchuru-child
*/

/* =============================================
   IMPORTS & VARIABLES
   ============================================= */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Rajdhani:wght@400;500;600;700&display=swap');

:root {
  --color-bg:        #08080f;
  --color-bg-card:   #0f0f1c;
  --color-bg-card2:  #13131f;
  --color-border:    #2a1f4e;
  --color-purple:    #8B5CF6;
  --color-purple-bright: #a78bfa;
  --color-orange:    #FF9500;
  --color-pink:      #E91E8C;
  --color-text:      #e0e0f0;
  --color-muted:     #6b6b8a;
  --font-heading:    'Orbitron', monospace;
  --font-body:       'Rajdhani', sans-serif;
}

/* =============================================
   BASE
   ============================================= */
*, *::before, *::after { box-sizing: border-box; }

html,
body,
.site,
.site-content,
#page,
#content,
.content-area,
#primary,
.site-main,
.storefront-full-width-content .entry-content,
.woocommerce-page,
.hentry,
.page {
  background-color: var(--color-bg) !important;
  background: var(--color-bg) !important;
}

body {
  color: var(--color-text) !important;
  font-family: var(--font-body) !important;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.02em;
}

/* Quitar cualquier fondo blanco que inyecte Storefront */
.storefront-full-width-content .site-main > article,
.storefront-full-width-content .site-main > .page,
.entry-content,
.entry-header {
  background: transparent !important;
  box-shadow: none !important;
}

h1, h2, h3, h4, h5, h6,
.woocommerce-loop-product__title,
.entry-title {
  font-family: var(--font-heading) !important;
  color: #ffffff !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

a { color: var(--color-purple-bright); transition: color 0.2s; }
a:hover { color: var(--color-orange); }

p, li, label, td, th, span, div { color: var(--color-text); }

/* =============================================
   HEADER
   ============================================= */
.site-header {
  background-color: #05050e !important;
  border-bottom: 1px solid var(--color-border) !important;
  padding: 0 !important;
}

.site-header .col-full {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 40px;
}

/* Branding: logo + texto lado a lado */
.site-branding {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

/* Logo (gato) */
.custom-logo-link img.custom-logo {
  height: 48px !important;
  width: auto !important;
  max-width: none !important;
  display: block !important;
}

/* Forzar visibilidad del titulo aunque haya logo */
.site-branding .site-title {
  display: block !important;
  margin: 0 !important;
}

.site-branding .site-title a {
  font-family: var(--font-heading) !important;
  color: #ffffff !important;
  font-size: 1.3rem !important;
  text-decoration: none !important;
  letter-spacing: 0.1em !important;
  position: relative;
  display: inline-block;
}

/* Glitch effect en el titulo del header */
.site-branding .site-title a::before,
.site-branding .site-title a::after {
  content: "Glitch.Uru";
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  overflow: hidden;
  pointer-events: none;
}
.site-branding .site-title a::before {
  color: var(--color-pink);
  animation: glitch-top 4s infinite;
  clip-path: polygon(0 0, 100% 0, 100% 40%, 0 40%);
  transform: translateX(-2px);
}
.site-branding .site-title a::after {
  color: var(--color-orange);
  animation: glitch-bot 4s infinite;
  clip-path: polygon(0 60%, 100% 60%, 100% 100%, 0 100%);
  transform: translateX(2px);
}

.site-description { display: none !important; }

.site-description { color: var(--color-muted) !important; font-size: 0.75rem; }

/* Nav */
.main-navigation ul li a {
  font-family: var(--font-heading) !important;
  color: var(--color-text) !important;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 8px 16px !important;
  transition: color 0.2s;
}
.main-navigation ul li a:hover,
.main-navigation ul li.current-menu-item > a {
  color: var(--color-purple-bright) !important;
  background: transparent !important;
}

.main-navigation ul li ul {
  background: #0f0f1c !important;
  border: 1px solid var(--color-border) !important;
}

/* Header icons (cart, search, account) */
.site-header-cart .cart-contents,
.site-search .search-toggle,
.storefront-handheld-footer-bar a {
  color: var(--color-text) !important;
}

.site-header-cart .cart-contents .count {
  background: var(--color-purple) !important;
  color: #fff !important;
  border-radius: 50%;
  font-size: 0.65rem;
}

/* =============================================
   HERO / BANNER (pagina principal)
   ============================================= */
.storefront-hero,
.wc-block-featured-product,
.wc-block-featured-category {
  background: var(--color-bg) !important;
}

/* =============================================
   CONTENIDO PRINCIPAL
   ============================================= */
.site-main,
.content-area,
#primary,
.storefront-full-width-content .entry-content {
  background: var(--color-bg) !important;
}

.hentry, .page {
  background: transparent !important;
}

/* =============================================
   TARJETAS DE PRODUCTO
   ============================================= */
ul.products li.product,
.wc-block-grid__product {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 8px !important;
  padding: 16px !important;
  transition: border-color 0.25s, transform 0.25s, box-shadow 0.25s;
  overflow: hidden;
}

ul.products li.product:hover,
.wc-block-grid__product:hover {
  border-color: var(--color-purple) !important;
  transform: translateY(-3px);
  box-shadow: 0 0 20px rgba(139, 92, 246, 0.2) !important;
}

ul.products li.product .woocommerce-loop-product__title,
.wc-block-grid__product-title {
  font-size: 0.8rem !important;
  letter-spacing: 0.08em;
  margin: 12px 0 4px !important;
  color: #ffffff !important;
}

ul.products li.product .price,
.wc-block-grid__product-price {
  color: var(--color-purple-bright) !important;
  font-family: var(--font-heading) !important;
  font-size: 0.95rem !important;
  font-weight: 700;
}

ul.products li.product img,
.wc-block-grid__product-image img {
  border-radius: 4px;
  background: var(--color-bg-card2);
}

/* Etiqueta "Destacado", "Oferta" */
ul.products li.product .onsale,
.wc-block-grid__product-onsale {
  background: var(--color-purple) !important;
  color: #fff !important;
  border-radius: 4px !important;
  font-family: var(--font-heading) !important;
  font-size: 0.65rem !important;
}

/* =============================================
   BOTONES
   ============================================= */
.button,
button,
input[type="submit"],
.wc-block-components-button,
a.button {
  font-family: var(--font-heading) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  background: transparent !important;
  color: var(--color-purple-bright) !important;
  border: 1px solid var(--color-purple) !important;
  border-radius: 4px !important;
  padding: 10px 20px !important;
  transition: background 0.2s, color 0.2s, box-shadow 0.2s !important;
  cursor: pointer;
}

.button:hover,
button:hover,
input[type="submit"]:hover,
a.button:hover {
  background: var(--color-purple) !important;
  color: #ffffff !important;
  box-shadow: 0 0 14px rgba(139, 92, 246, 0.5) !important;
}

/* Botón añadir al carrito en la lista */
ul.products li.product .button.add_to_cart_button,
ul.products li.product .button {
  background: var(--color-bg-card2) !important;
  border-color: var(--color-purple) !important;
  color: var(--color-purple-bright) !important;
  width: 100%;
  margin-top: 10px;
  text-align: center;
}

ul.products li.product .button:hover {
  background: var(--color-purple) !important;
  color: #fff !important;
}

/* Botón primario (checkout, etc) */
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background: var(--color-purple) !important;
  color: #fff !important;
  border-color: var(--color-purple) !important;
}

.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background: var(--color-purple-bright) !important;
}

/* =============================================
   SIDEBAR / WIDGETS
   ============================================= */
.widget-area,
.sidebar-widget-area {
  background: transparent !important;
}

.widget {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 24px;
}

.widget-title {
  font-family: var(--font-heading) !important;
  color: var(--color-purple-bright) !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.1em;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 10px;
  margin-bottom: 14px !important;
}

.widget ul li a { color: var(--color-text) !important; }
.widget ul li a:hover { color: var(--color-purple-bright) !important; }

/* Price filter slider */
.widget_price_filter .ui-slider-range { background: var(--color-purple) !important; }
.widget_price_filter .ui-slider-handle { background: var(--color-purple-bright) !important; border-color: var(--color-purple) !important; }
.widget_price_filter .price_slider_wrapper .ui-widget-content { background: var(--color-border) !important; }

/* =============================================
   PAGINA DE TIENDA (shop)
   ============================================= */
.woocommerce-products-header__title,
.woocommerce-page h1.page-title {
  font-family: var(--font-heading) !important;
  color: #fff !important;
  font-size: 1.8rem !important;
  letter-spacing: 0.1em;
}

.woocommerce-result-count,
.woocommerce-ordering select {
  color: var(--color-muted) !important;
  background: var(--color-bg-card) !important;
  border-color: var(--color-border) !important;
}

/* Paginacion */
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
  background: var(--color-bg-card) !important;
  border-color: var(--color-border) !important;
  color: var(--color-text) !important;
}

.woocommerce-pagination ul li .current,
.woocommerce-pagination ul li a:hover {
  background: var(--color-purple) !important;
  border-color: var(--color-purple) !important;
  color: #fff !important;
}

/* =============================================
   PAGINA DE PRODUCTO INDIVIDUAL
   ============================================= */
.single-product .product {
  background: transparent !important;
}

.single-product .product .summary .price {
  color: var(--color-purple-bright) !important;
  font-family: var(--font-heading) !important;
  font-size: 1.6rem !important;
}

.single-product .product .woocommerce-product-details__short-description {
  color: var(--color-muted) !important;
}

.woocommerce-tabs ul.tabs {
  background: transparent !important;
  border-color: var(--color-border) !important;
}

.woocommerce-tabs ul.tabs li {
  background: var(--color-bg-card) !important;
  border-color: var(--color-border) !important;
}

.woocommerce-tabs ul.tabs li a {
  color: var(--color-muted) !important;
  font-family: var(--font-heading) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.08em;
}

.woocommerce-tabs ul.tabs li.active {
  background: var(--color-bg-card2) !important;
  border-top: 2px solid var(--color-purple) !important;
}

.woocommerce-tabs ul.tabs li.active a { color: #fff !important; }

.woocommerce-tabs .panel {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 0 8px 8px 8px;
  padding: 20px;
}

/* =============================================
   CARRITO & CHECKOUT
   ============================================= */
.shop_table,
.woocommerce table.shop_table {
  background: var(--color-bg-card) !important;
  border-color: var(--color-border) !important;
  color: var(--color-text) !important;
}

.woocommerce table.shop_table th {
  background: var(--color-bg-card2) !important;
  color: var(--color-purple-bright) !important;
  font-family: var(--font-heading) !important;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
}

.woocommerce table.shop_table td { border-color: var(--color-border) !important; }

.woocommerce .cart-collaterals .cart_totals,
.woocommerce-cart .cart-collaterals .cart_totals {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 8px;
  padding: 20px;
}

/* Checkout form */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: var(--color-bg-card2) !important;
  border-color: var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: 4px !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--color-purple) !important;
  box-shadow: 0 0 8px rgba(139,92,246,0.3) !important;
  outline: none;
}

.woocommerce form .form-row label {
  color: var(--color-muted) !important;
  font-family: var(--font-heading) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.08em;
}

/* =============================================
   FOOTER
   ============================================= */
.site-footer {
  background: #05050e !important;
  border-top: 1px solid var(--color-border) !important;
  color: var(--color-muted) !important;
}

.site-footer .widget-title {
  color: var(--color-orange) !important;
}

.site-footer a { color: var(--color-muted) !important; }
.site-footer a:hover { color: var(--color-purple-bright) !important; }

.site-info {
  background: #030308 !important;
  color: var(--color-muted) !important;
  font-size: 0.78rem;
  padding: 14px 40px;
}

/* =============================================
   NOTIFICACIONES WOOCOMMERCE
   ============================================= */
.woocommerce-message,
.woocommerce-info {
  background: var(--color-bg-card) !important;
  border-top-color: var(--color-purple) !important;
  color: var(--color-text) !important;
}

.woocommerce-error {
  background: var(--color-bg-card) !important;
  border-top-color: var(--color-pink) !important;
  color: var(--color-text) !important;
}

/* =============================================
   GLITCH EFFECT en titulos principales
   ============================================= */
@keyframes glitch-shift {
  0%, 100% { text-shadow: 2px 0 var(--color-pink), -2px 0 var(--color-purple); }
  25%       { text-shadow: -2px 0 var(--color-pink),  2px 0 var(--color-purple); }
  50%       { text-shadow: 2px 2px var(--color-purple), -2px -2px var(--color-pink); }
  75%       { text-shadow: 0 0 0 transparent; }
}

.page-title,
.woocommerce-products-header__title {
  animation: glitch-shift 6s infinite;
}

/* =============================================
   SCROLLBAR
   ============================================= */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--color-bg); }
::-webkit-scrollbar-thumb { background: var(--color-purple); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--color-purple-bright); }

/* =============================================
   HOMEPAGE — HERO
   ============================================= */
.gu-homepage { background: var(--color-bg); }

/* Quitar padding/margin del wrapper de Storefront en la home */
.gu-homepage,
.page-template-template-fullwidth .site-main,
.storefront-full-width-content .site-main {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}

.gu-hero {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  width: 100%;
  background: radial-gradient(ellipse 70% 80% at 70% 50%, rgba(139,92,246,0.12) 0%, transparent 70%),
              var(--color-bg);
}

/* Grid de fondo */
.gu-hero__grid-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(139,92,246,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(139,92,246,0.07) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

.gu-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 40px;
  padding: 80px 40px;
  position: relative;
  z-index: 1;
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
}

.gu-hero__eyebrow {
  font-family: var(--font-heading);
  font-size: 0.65rem;
  color: var(--color-purple-bright);
  letter-spacing: 0.2em;
  margin-bottom: 16px;
  opacity: 0.8;
}

.gu-hero__title {
  font-family: var(--font-heading) !important;
  font-size: clamp(2.4rem, 5vw, 4rem) !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  color: #ffffff !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 0 0 20px !important;
  animation: none !important;
}

/* Efecto glitch en la palabra clave */
.gu-glitch {
  color: var(--color-purple-bright);
  position: relative;
  display: inline-block;
}
.gu-glitch::before,
.gu-glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  overflow: hidden;
}
.gu-glitch::before {
  color: var(--color-pink);
  animation: glitch-top 3s infinite;
  clip-path: polygon(0 0, 100% 0, 100% 35%, 0 35%);
  transform: translateX(-2px);
}
.gu-glitch::after {
  color: var(--color-orange);
  animation: glitch-bot 3s infinite;
  clip-path: polygon(0 65%, 100% 65%, 100% 100%, 0 100%);
  transform: translateX(2px);
}
@keyframes glitch-top {
  0%, 90%, 100% { transform: translateX(0); opacity: 0; }
  92%            { transform: translateX(-4px); opacity: 1; }
  94%            { transform: translateX(4px); opacity: 1; }
  96%            { transform: translateX(0); opacity: 0; }
}
@keyframes glitch-bot {
  0%, 90%, 100% { transform: translateX(0); opacity: 0; }
  93%            { transform: translateX(4px); opacity: 1; }
  95%            { transform: translateX(-4px); opacity: 1; }
  97%            { transform: translateX(0); opacity: 0; }
}

.gu-hero__sub {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-muted);
  letter-spacing: 0.1em;
  line-height: 1.7;
  margin-bottom: 36px !important;
}

.gu-btn-hero {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-heading) !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-purple-bright) !important;
  border: 1px solid var(--color-purple) !important;
  background: transparent !important;
  padding: 14px 28px !important;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.25s, color 0.25s, box-shadow 0.25s;
}
.gu-btn-hero:hover {
  background: var(--color-purple) !important;
  color: #fff !important;
  box-shadow: 0 0 24px rgba(139,92,246,0.5);
}
.gu-btn-hero span { transition: transform 0.2s; }
.gu-btn-hero:hover span { transform: translateX(4px); }

/* Mascota */
.gu-hero__mascot {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.gu-mascot-img {
  width: 100%;
  max-width: 460px;
  height: auto;
  filter: drop-shadow(0 0 40px rgba(139,92,246,0.5)) drop-shadow(0 0 80px rgba(139,92,246,0.2));
  animation: float 6s ease-in-out infinite;
}

@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-18px); }
}

.gu-hero__glow {
  position: absolute;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(139,92,246,0.25) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
  z-index: -1;
}

.gu-mascot-placeholder {
  width: 340px;
  height: 340px;
  border: 2px dashed var(--color-border);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--color-muted);
  font-size: 5rem;
}
.gu-mascot-placeholder p {
  font-family: var(--font-heading);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  margin-top: 10px;
  color: var(--color-muted);
}

/* =============================================
   HOMEPAGE — FILTROS
   ============================================= */
.gu-filters {
  background: rgba(255,255,255,0.02);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: 20px 0;
}

.gu-filters__inner {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 0 40px;
  max-width: 1280px;
  margin: 0 auto;
}

.gu-filter {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-heading) !important;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  color: var(--color-muted) !important;
  border: 1px solid var(--color-border);
  padding: 8px 18px;
  border-radius: 40px;
  text-decoration: none;
  transition: all 0.2s;
  text-transform: uppercase;
}
.gu-filter:hover,
.gu-filter--active {
  color: #fff !important;
  border-color: var(--color-purple);
  background: rgba(139,92,246,0.15);
}

/* =============================================
   HOMEPAGE — PRODUCTOS DESTACADOS
   ============================================= */
.gu-featured {
  padding: 60px 0;
}
.gu-featured .col-full {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 40px;
}

.gu-featured__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 32px;
}

.gu-section-title {
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
  color: #fff !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 !important;
  animation: none !important;
}
.gu-section-title span { color: var(--color-purple-bright); }

.gu-ver-todos {
  font-family: var(--font-heading);
  font-size: 0.68rem;
  color: var(--color-purple-bright) !important;
  letter-spacing: 0.1em;
  text-decoration: none;
  transition: color 0.2s;
}
.gu-ver-todos:hover { color: var(--color-orange) !important; }

/* =============================================
   HOMEPAGE — TRUST BADGES
   ============================================= */
.gu-trust {
  border-top: 1px solid var(--color-border);
  padding: 32px 0;
  background: rgba(255,255,255,0.01);
}

.gu-trust__inner {
  display: flex;
  justify-content: center;
  gap: 60px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 40px;
  flex-wrap: wrap;
}

.gu-trust__item {
  display: flex;
  align-items: center;
  gap: 14px;
}

.gu-trust__icon {
  font-size: 1.8rem;
  flex-shrink: 0;
  filter: drop-shadow(0 0 8px rgba(139,92,246,0.6));
}

.gu-trust__text strong {
  display: block;
  font-family: var(--font-heading);
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  color: var(--color-purple-bright);
  text-transform: uppercase;
}
.gu-trust__text p {
  font-size: 0.82rem;
  color: var(--color-muted) !important;
  margin: 2px 0 0 !important;
}

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 768px) {
  .gu-hero__inner {
    grid-template-columns: 1fr;
    padding: 60px 24px;
    text-align: center;
  }
  .gu-hero__mascot { order: -1; }
  .gu-mascot-img { max-width: 260px; }
  .gu-filters__inner { padding: 0 24px; }
  .gu-trust__inner { grid-template-columns: 1fr 1fr; padding: 0 24px; }
  .gu-featured .col-full { padding: 0 24px; }
}

@media (max-width: 480px) {
  .gu-trust__inner { grid-template-columns: 1fr; }
}

/* =============================================
   TIENDA — FILTRO DE CATEGORIAS PLEGABLE
   ============================================= */
.gu-cat-filter {
  margin-bottom: 28px;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
}

.gu-cat-toggle {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: 100% !important;
  background: var(--color-bg-card) !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 14px 20px !important;
  color: var(--color-text) !important;
  font-family: var(--font-heading) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.12em !important;
  cursor: pointer !important;
  text-align: left !important;
  box-shadow: none !important;
}
.gu-cat-toggle:hover {
  background: var(--color-bg-card2) !important;
  color: var(--color-purple-bright) !important;
  box-shadow: none !important;
}

.gu-cat-toggle__icon { color: var(--color-purple-bright); font-size: 0.9rem; }

.gu-cat-toggle__arrow {
  margin-left: auto;
  font-size: 1rem;
  color: var(--color-muted);
  transition: transform 0.25s;
  display: inline-block;
}
.gu-cat-toggle--open .gu-cat-toggle__arrow { transform: rotate(180deg); }

.gu-cat-panel {
  display: none;
  flex-wrap: wrap;
  gap: 10px;
  padding: 16px 20px;
  background: var(--color-bg-card2);
  border-top: 1px solid var(--color-border);
  animation: slideDown 0.2s ease;
}
.gu-cat-panel--open {
  display: flex;
}
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.gu-cat-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-heading) !important;
  font-size: 0.67rem;
  letter-spacing: 0.1em;
  color: var(--color-muted) !important;
  border: 1px solid var(--color-border);
  padding: 7px 16px;
  border-radius: 40px;
  text-decoration: none;
  transition: all 0.2s;
  white-space: nowrap;
}
.gu-cat-item:hover,
.gu-cat-item--active {
  color: #fff !important;
  border-color: var(--color-purple);
  background: rgba(139,92,246,0.15);
}

.gu-cat-count {
  background: var(--color-border);
  color: var(--color-muted);
  font-size: 0.6rem;
  padding: 1px 6px;
  border-radius: 20px;
  margin-left: 2px;
}
.gu-cat-item--active .gu-cat-count,
.gu-cat-item:hover .gu-cat-count {
  background: rgba(139,92,246,0.3);
  color: var(--color-purple-bright);
}

/* =============================================
   NAV — DROPDOWN DE CATEGORIAS EN TIENDA
   ============================================= */

/* Mostrar dropdown al hover */
.main-navigation .primary-navigation > ul > li:hover > ul,
.main-navigation .primary-navigation > ul > li:focus-within > ul {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) !important;
}

.main-navigation ul ul {
  background: #0c0c1e !important;
  border: 1px solid var(--color-border) !important;
  border-top: 2px solid var(--color-purple) !important;
  border-radius: 0 0 8px 8px !important;
  min-width: 220px !important;
  padding: 8px 0 !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6), 0 0 20px rgba(139,92,246,0.15) !important;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity 0.2s ease, transform 0.2s ease !important;
  display: block !important;
}

.main-navigation ul ul li a {
  font-family: var(--font-heading) !important;
  font-size: 0.67rem !important;
  letter-spacing: 0.1em !important;
  color: var(--color-muted) !important;
  padding: 10px 20px !important;
  display: block;
  transition: color 0.15s, background 0.15s !important;
  border-bottom: 1px solid rgba(42,31,78,0.5) !important;
}
.main-navigation ul ul li:last-child a {
  border-bottom: none !important;
}
.main-navigation ul ul li a:hover {
  color: #fff !important;
  background: rgba(139,92,246,0.12) !important;
  padding-left: 26px !important;
}

/* Flecha indicadora en item padre */
.main-navigation ul li.menu-item-has-children > a::after {
  content: " ▾";
  font-size: 0.7em;
  color: var(--color-purple-bright);
  transition: transform 0.2s;
  display: inline-block;
}
.main-navigation ul li.menu-item-has-children:hover > a::after {
  transform: rotate(180deg);
}

/* =============================================
   HEADER — FILA UNICA (fix header duplicado)
   ============================================= */

/* Contenedor principal del header: una sola fila con todo */
.site-header > .col-full {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  padding: 12px 40px !important;
  flex-wrap: nowrap !important;
  gap: 12px;
}

/* Branding a la izquierda, todo lo demas a la derecha */
.site-header > .col-full .site-branding {
  flex-shrink: 0;
  margin-right: auto !important;
}

.site-header > .col-full .secondary-navigation,
.site-header > .col-full .storefront-product-search {
  flex-shrink: 0;
  margin-left: 0 !important;
}

/* Ocultar barra de busqueda del header superior */
.site-header .col-full .storefront-product-search,
.site-header > .col-full form.woocommerce-product-search {
  display: none !important;
}

/* Nav wrapper: inline dentro del header */
.storefront-primary-navigation {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

.storefront-primary-navigation > .col-full {
  display: flex !important;
  align-items: center !important;
  padding: 0 40px !important;
  gap: 32px;
  background: transparent !important;
}

/* Busqueda: moverla al nav */
.storefront-primary-navigation .storefront-product-search {
  margin-left: auto;
}

.storefront-product-search input[type="search"] {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: 4px !important;
  font-family: var(--font-body) !important;
  padding: 8px 14px !important;
  font-size: 0.85rem !important;
}
.storefront-product-search input[type="search"]:focus {
  border-color: var(--color-purple) !important;
  outline: none !important;
  box-shadow: none !important;
}
.storefront-product-search input[type="search"]::placeholder {
  color: var(--color-muted) !important;
}

/* =============================================
   CARRITO — BOTONES Y ESTILOS
   ============================================= */

/* Boton Finalizar Compra — visible y con color */
.woocommerce .cart .button,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce a.checkout-button,
.wc-proceed-to-checkout .button {
  background: var(--color-purple) !important;
  color: #ffffff !important;
  border-color: var(--color-purple) !important;
  display: block !important;
  text-align: center !important;
  padding: 14px 24px !important;
  font-size: 0.78rem !important;
}
.woocommerce .cart .button:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
  background: var(--color-purple-bright) !important;
  border-color: var(--color-purple-bright) !important;
  box-shadow: 0 0 20px rgba(139,92,246,0.5) !important;
}

/* Tabla del carrito */
.woocommerce table.shop_table thead tr th {
  font-family: var(--font-heading) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.12em;
  color: var(--color-purple-bright) !important;
  background: var(--color-bg-card2) !important;
  border-color: var(--color-border) !important;
  padding: 14px 12px !important;
}

/* Cantidad en carrito */
.woocommerce .quantity input.qty {
  background: var(--color-bg-card2) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: 4px !important;
  text-align: center;
}

/* Cupon */
.woocommerce .cart .coupon .input-text {
  background: var(--color-bg-card2) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: 4px !important;
}

/* Totales */
.woocommerce .cart-collaterals h2,
.woocommerce-cart .cart-collaterals h2 {
  font-size: 0.85rem !important;
  letter-spacing: 0.12em;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 10px;
  margin-bottom: 16px !important;
}

.woocommerce-cart .cart-collaterals .cart_totals table {
  background: transparent !important;
}

.woocommerce-cart .cart-collaterals .cart_totals table th,
.woocommerce-cart .cart-collaterals .cart_totals table td {
  border-color: var(--color-border) !important;
  color: var(--color-text) !important;
  padding: 10px 0 !important;
}

.woocommerce-cart .cart-collaterals .cart_totals .order-total th,
.woocommerce-cart .cart-collaterals .cart_totals .order-total td {
  color: var(--color-purple-bright) !important;
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
}

/* =============================================
   HEADER — NAVEGACION SECUNDARIA (Mi cuenta)
   ============================================= */
.secondary-navigation {
  display: flex !important;
  align-items: center !important;
}

.secondary-navigation ul {
  display: flex !important;
  align-items: center !important;
  gap: 4px;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}


.secondary-navigation ul li a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 50% !important;
  text-decoration: none !important;
  background: transparent !important;
  transition: all 0.2s !important;
  font-size: 0 !important;
  padding: 0 !important;
  color: transparent !important;
  /* icono persona via SVG */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%236b6b8a'%3E%3Cpath d='M12 12c2.7 0 4.8-2.1 4.8-4.8S14.7 2.4 12 2.4 7.2 4.5 7.2 7.2 9.3 12 12 12zm0 2.4c-3.2 0-9.6 1.6-9.6 4.8v2.4h19.2v-2.4c0-3.2-6.4-4.8-9.6-4.8z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 20px 20px !important;
}
.secondary-navigation ul li a:hover {
  border-color: var(--color-purple) !important;
  background-color: rgba(139,92,246,0.15) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23a78bfa'%3E%3Cpath d='M12 12c2.7 0 4.8-2.1 4.8-4.8S14.7 2.4 12 2.4 7.2 4.5 7.2 7.2 9.3 12 12 12zm0 2.4c-3.2 0-9.6 1.6-9.6 4.8v2.4h19.2v-2.4c0-3.2-6.4-4.8-9.6-4.8z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 20px 20px !important;
}

/* =============================================
   CARRITO — BOTON FINALIZAR COMPRA (fix)
   ============================================= */
.wc-proceed-to-checkout,
.wc-proceed-to-checkout a,
.wc-proceed-to-checkout .button,
.wc-proceed-to-checkout .checkout-button,
a.checkout-button,
.checkout-button {
  background-color: var(--color-purple) !important;
  background: var(--color-purple) !important;
  color: #ffffff !important;
  border: 1px solid var(--color-purple) !important;
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  padding: 16px !important;
  font-family: var(--font-heading) !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  transition: background 0.2s, box-shadow 0.2s !important;
}

.wc-proceed-to-checkout a:hover,
.wc-proceed-to-checkout .button:hover,
a.checkout-button:hover {
  background-color: var(--color-purple-bright) !important;
  background: var(--color-purple-bright) !important;
  color: #ffffff !important;
  box-shadow: 0 0 20px rgba(139,92,246,0.5) !important;
}

/* =============================================
   WOOCOMMERCE BLOCKS — CARRITO (block-based)
   ============================================= */

/* Variables de color que usan los bloques */
.wp-block-woocommerce-cart,
.wc-block-cart {
  --wc-blocks-color-primary: #8B5CF6 !important;
  --wc-blocks-color-primary-text: #ffffff !important;
  --wc-blocks-color-secondary: #13131f !important;
  --wc-blocks-color-border: #2a1f4e !important;
  --wc-blocks-color-background: #08080f !important;
  --wc-blocks-color-text: #e0e0f0 !important;
}

/* Boton Finalizar Compra — block version */
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-components-button,
.wc-block-cart__submit-button,
.wc-proceed-to-checkout .wc-block-components-button,
.wc-block-components-checkout-place-order-button,
a.wc-block-cart__submit-button {
  background-color: #8B5CF6 !important;
  background: #8B5CF6 !important;
  color: #ffffff !important;
  border-color: #8B5CF6 !important;
  font-family: 'Orbitron', monospace !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.12em !important;
  width: 100% !important;
  padding: 16px !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
}

.wp-block-woocommerce-proceed-to-checkout-block .wc-block-components-button:hover,
.wc-block-cart__submit-button:hover {
  background-color: #a78bfa !important;
  background: #a78bfa !important;
  border-color: #a78bfa !important;
  box-shadow: 0 0 20px rgba(139,92,246,0.5) !important;
}

/* Fondo del bloque carrito */
.wp-block-woocommerce-cart,
.wc-block-cart,
.wp-block-woocommerce-filled-cart-block,
.wp-block-woocommerce-cart-totals-block,
.wp-block-woocommerce-cart-order-summary-block {
  background: transparent !important;
  color: #e0e0f0 !important;
}

/* Totales */
.wc-block-components-totals-wrapper,
.wc-block-components-order-summary {
  background: #0f0f1c !important;
  border: 1px solid #2a1f4e !important;
  border-radius: 8px !important;
}

.wc-block-components-totals-item,
.wc-block-components-totals-item__label,
.wc-block-components-totals-item__value {
  color: #e0e0f0 !important;
  border-color: #2a1f4e !important;
}

.wc-block-components-totals-item--total .wc-block-components-totals-item__label,
.wc-block-components-totals-item--total .wc-block-components-totals-item__value {
  color: #a78bfa !important;
  font-family: 'Orbitron', monospace !important;
  font-size: 1rem !important;
}

/* Input cupon */
.wc-block-components-coupon-form input,
.wc-block-components-text-input input {
  background: #13131f !important;
  border-color: #2a1f4e !important;
  color: #e0e0f0 !important;
  border-radius: 4px !important;
}
.wc-block-components-coupon-form input:focus,
.wc-block-components-text-input input:focus {
  border-color: #8B5CF6 !important;
  box-shadow: 0 0 8px rgba(139,92,246,0.3) !important;
  outline: none !important;
}

/* Encabezado de totales */
.wc-block-components-order-summary__button-text,
.wc-block-cart__order-summary-title {
  font-family: 'Orbitron', monospace !important;
  color: #ffffff !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.1em;
}

/* =============================================
   HEADER — ICONO CUENTA + BUSCADOR AGRUPADOS
   ============================================= */
.gu-header-right {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-left: auto;
}

.gu-account-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 50% !important;
  color: var(--color-muted) !important;
  text-decoration: none !important;
  background: transparent !important;
  transition: all 0.2s !important;
  flex-shrink: 0;
}
.gu-account-icon:hover {
  border-color: var(--color-purple) !important;
  background: rgba(139,92,246,0.15) !important;
  color: var(--color-purple-bright) !important;
}

.gu-header-right .widget_product_search,
.gu-header-right form {
  margin: 0 !important;
}

/* Buscador en header — ancho fijo */
.gu-header-right .widget_product_search form,
.gu-header-right form.woocommerce-product-search {
  display: flex !important;
  align-items: center !important;
}

.gu-header-right input[type="search"] {
  width: 240px !important;
  min-width: 240px !important;
}

/* Buscador header — form directo de WooCommerce */
.gu-header-right form.woocommerce-product-search {
  display: flex !important;
  align-items: center !important;
  margin: 0 !important;
  gap: 0 !important;
}

.gu-header-right form.woocommerce-product-search input[type="search"] {
  width: 220px !important;
  min-width: 220px !important;
  height: 38px !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-border) !important;
  border-right: none !important;
  color: var(--color-text) !important;
  border-radius: 4px 0 0 4px !important;
  font-family: var(--font-body) !important;
  padding: 0 14px !important;
  font-size: 0.85rem !important;
}
.gu-header-right form.woocommerce-product-search input[type="search"]:focus {
  border-color: var(--color-purple) !important;
  outline: none !important;
  box-shadow: none !important;
}
.gu-header-right form.woocommerce-product-search input[type="search"]::placeholder {
  color: var(--color-muted) !important;
}

.gu-header-right form.woocommerce-product-search button[type="submit"] {
  height: 38px !important;
  padding: 0 12px !important;
  background: var(--color-purple) !important;
  border: 1px solid var(--color-purple) !important;
  border-radius: 0 4px 4px 0 !important;
  color: #fff !important;
  cursor: pointer !important;
  font-size: 0.75rem !important;
  font-family: var(--font-heading) !important;
  letter-spacing: 0.05em !important;
  transition: background 0.2s !important;
}
.gu-header-right form.woocommerce-product-search button[type="submit"]:hover {
  background: var(--color-purple-bright) !important;
  border-color: var(--color-purple-bright) !important;
  box-shadow: none !important;
}
