/* ============================================================
   GYMBO — WooCommerce skin (Grafiti Cathedral)
   Estiliza shop, archivo, ficha de producto, carrito y checkout
   ============================================================ */

.gymbo-shop { padding-top: calc(var(--gymbo-nav-h) + 2.5rem); padding-bottom: 5rem; }

/* Cabecera de tienda */
.gymbo-shop-hero { position: relative; padding: 4rem 0 3rem; overflow: hidden; }
.gymbo-shop-hero__glow { position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 60% 90% at 30% 30%, oklch(0.48 0.28 295 / 12%) 0%, transparent 70%); }
.gymbo-shop-hero h1,
.woocommerce-products-header__title {
  font-family: var(--font-display); font-size: clamp(3rem, 8vw, 6rem); line-height: 0.9; letter-spacing: 0.02em; color: #fff;
}
.woocommerce-breadcrumb {
  font-family: var(--font-data); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.18em;
  color: rgba(255,255,255,0.4); margin-bottom: 1rem;
}
.woocommerce-breadcrumb a { color: var(--gymbo-purple-light); }

/* Barra de resultados + orden */
.woocommerce-result-count { font-family: var(--font-data); font-size: 0.8rem; color: rgba(255,255,255,0.5); }
.woocommerce-ordering select,
.gymbo select {
  background: var(--gymbo-card-2); color: #fff; border: 1px solid var(--gymbo-border-soft);
  padding: 0.6rem 1rem; font-family: var(--font-data); font-size: 0.8rem; outline: none;
}

/* Grid de productos del shop -> reusa el grid del home */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid; gap: 1.5rem; margin: 0; padding: 0; list-style: none;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1280px) { .woocommerce ul.products.columns-4 { grid-template-columns: repeat(4, 1fr); } }
.woocommerce ul.products li.product { width: 100% !important; margin: 0 !important; float: none !important; }

/* La card de producto de Woo usa .gymbo-card (ver content-product.php) */
.gymbo-card .gymbo-card__atc { width: 100%; justify-content: center; }
.gymbo-card .added_to_cart { display: none; }

/* Mensajes Woo */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  font-family: var(--font-body); background: var(--gymbo-card); color: #fff;
  border-top: 3px solid var(--gymbo-purple); padding: 1rem 1.25rem; list-style: none; margin-bottom: 1.5rem;
}
.woocommerce-error { border-top-color: oklch(0.62 0.24 27); }
.woocommerce-message { border-top-color: var(--gymbo-lime); }
.woocommerce-message a.button, .woocommerce-info a.button { background: var(--gymbo-purple); color: #fff; }

/* ---------- Ficha de producto ---------- */
.single-product .gymbo-shop { padding-top: calc(var(--gymbo-nav-h) + 2rem); }
.single-product div.product { display: grid; grid-template-columns: 1fr; gap: 3rem; }
@media (min-width: 900px) { .single-product div.product { grid-template-columns: 1fr 1fr; align-items: start; } }
.single-product div.product .woocommerce-product-gallery { position: relative; }
.single-product div.product .woocommerce-product-gallery__wrapper img {
  clip-path: polygon(0 0, calc(100% - 20px) 0, 100% 20px, 100% 100%, 20px 100%, 0 calc(100% - 20px));
}
.single-product .product_title {
  font-family: var(--font-display); font-size: clamp(2.5rem, 6vw, 4.5rem); line-height: 0.9; letter-spacing: 0.02em; color: #fff; margin-bottom: 1rem;
}
.single-product .woocommerce-product-details__short-description { font-family: var(--font-body); color: rgba(255,255,255,0.65); line-height: 1.6; margin-bottom: 1.5rem; }
.single-product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price { font-family: var(--font-data); font-size: 2rem; font-weight: 700; color: #fff; }
.single-product .price del { color: rgba(255,255,255,0.3); font-size: 1.1rem; }
.single-product .price ins { text-decoration: none; color: var(--gymbo-lime); }
.woocommerce div.product form.cart { margin: 1.5rem 0; display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; }
.woocommerce div.product form.cart .quantity input.qty {
  width: 4.5rem; padding: 0.85rem 0.5rem; text-align: center; background: var(--gymbo-card-2);
  border: 1px solid var(--gymbo-border-soft); color: #fff; font-family: var(--font-data);
}
.woocommerce .star-rating span { color: var(--gymbo-lime); }
.woocommerce .woocommerce-product-rating { margin-bottom: 1rem; }
.single-product .product_meta { font-family: var(--font-data); font-size: 0.75rem; color: rgba(255,255,255,0.4); margin-top: 1.5rem; }
.single-product .product_meta a { color: var(--gymbo-purple-light); }

/* Tabs */
.woocommerce-tabs { grid-column: 1 / -1; margin-top: 3rem; }
.woocommerce-tabs ul.tabs { display: flex; gap: 0.5rem; flex-wrap: wrap; border-bottom: 1px solid var(--gymbo-border); padding: 0; margin-bottom: 1.5rem; }
.woocommerce-tabs ul.tabs li { list-style: none; }
.woocommerce-tabs ul.tabs li a {
  font-family: var(--font-condensed); font-size: 0.95rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em;
  color: rgba(255,255,255,0.5); padding: 0.75rem 1.25rem; display: inline-block;
}
.woocommerce-tabs ul.tabs li.active a { color: #fff; border-bottom: 2px solid var(--gymbo-lime); }
.woocommerce-tabs .panel { font-family: var(--font-body); color: rgba(255,255,255,0.7); line-height: 1.7; }
.woocommerce-tabs h2 { font-family: var(--font-condensed); color: #fff; }

/* Productos relacionados / upsells */
.related.products, .upsells.products { grid-column: 1 / -1; margin-top: 3rem; }
.related.products > h2, .upsells.products > h2,
.cross-sells > h2 { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.5rem); color: #fff; margin-bottom: 1.5rem; letter-spacing: 0.02em; }

/* ---------- Botones Woo unificados con la marca ---------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.gymbo-card__atc {
  position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  background: var(--gymbo-purple); color: #fff; border: none; cursor: pointer;
  font-family: var(--font-condensed); font-size: 0.95rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em;
  padding: 0.85rem 1.5rem; border-radius: 0; line-height: 1;
  clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
  transition: background 0.2s, box-shadow 0.2s, transform 0.2s;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.gymbo-card__atc:hover { background: var(--gymbo-purple-glow); box-shadow: 0 0 24px oklch(0.48 0.28 295 / 50%); color: #fff; }
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #place_order,
.single_add_to_cart_button { background: var(--gymbo-lime); color: var(--gymbo-black); }
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.single_add_to_cart_button:hover,
.woocommerce #place_order:hover { background: var(--gymbo-lime); color: var(--gymbo-black); box-shadow: 0 0 30px oklch(0.92 0.28 130 / 60%); transform: translateY(-1px); }
.gymbo-card__atc.loading, .woocommerce button.button.loading { opacity: 0.7; }
.gymbo-card__atc.added::after { content: ' ✓'; }

/* ---------- Carrito ---------- */
.woocommerce table.shop_table {
  width: 100%; border-collapse: collapse; background: var(--gymbo-card); color: #fff; border: 1px solid var(--gymbo-border-soft);
  font-family: var(--font-body);
}
.woocommerce table.shop_table th { font-family: var(--font-condensed); text-transform: uppercase; letter-spacing: 0.1em; color: #fff; padding: 1rem; text-align: left; background: var(--gymbo-card-2); }
.woocommerce table.shop_table td { padding: 1rem; border-top: 1px solid var(--gymbo-border-soft); }
.woocommerce table.shop_table img { width: 64px; }
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-cart .cart-collaterals { width: 100%; }
.cart_totals h2, .woocommerce-checkout h3, .woocommerce-cart h2 { font-family: var(--font-condensed); color: #fff; text-transform: uppercase; letter-spacing: 0.1em; }

/* Inputs de formularios (checkout, account, etc.) */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout input, .woocommerce-account input[type="text"],
.woocommerce-account input[type="password"], .woocommerce-account input[type="email"] {
  background: var(--gymbo-card-2); border: 1px solid var(--gymbo-border-soft); color: #fff;
  padding: 0.85rem 1rem; font-family: var(--font-body); outline: none; border-radius: 0;
}
.woocommerce form .form-row label { font-family: var(--font-data); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.08em; color: rgba(255,255,255,0.6); }

/* Notice de "añadido" mini */
.gymbo-toast-wrap { position: fixed; right: 1rem; bottom: 1rem; z-index: 9999; display: flex; flex-direction: column; gap: 0.5rem; }
.gymbo-toast {
  background: var(--gymbo-card); border: 1px solid oklch(0.48 0.28 295 / 50%); color: #fff;
  font-family: var(--font-condensed); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700;
  padding: 0.85rem 1.25rem; box-shadow: 0 10px 40px oklch(0.06 0.01 280 / 80%);
  clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
  transform: translateX(120%); transition: transform 0.4s var(--ease-out); display: flex; align-items: center; gap: 0.5rem;
}
.gymbo-toast.show { transform: translateX(0); }
.gymbo-toast--ok { border-color: oklch(0.92 0.28 130 / 60%); }
.gymbo-toast--ok b { color: var(--gymbo-lime); }

/* ---------- Carrito / Checkout / Cuenta (renderizan vía page.php) ---------- */
body.woocommerce-cart .gymbo-page .entry-content,
body.woocommerce-checkout .gymbo-page .entry-content,
body.woocommerce-account .gymbo-page .entry-content { max-width: none; }

body.woocommerce-cart .gymbo-page,
body.woocommerce-checkout .gymbo-page,
body.woocommerce-account .gymbo-page { padding-top: calc(var(--gymbo-nav-h) + 2rem); }

/* Layout de carrito y checkout en dos columnas en desktop */
@media (min-width: 992px) {
	.woocommerce-cart .cart-collaterals { display: flex; justify-content: flex-end; margin-top: 1.5rem; }
	.woocommerce-cart .cart-collaterals .cart_totals { width: 420px; max-width: 100%; }
	.woocommerce-checkout .col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
	.woocommerce-checkout #order_review,
	.woocommerce-checkout #order_review_heading { width: 100%; }
}
.woocommerce-checkout #order_review { background: var(--gymbo-card); padding: 1.5rem; border: 1px solid var(--gymbo-border-soft); margin-top: 1rem; }

/* Cuenta: navegación lateral */
.woocommerce-account .woocommerce-MyAccount-navigation ul { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1.5rem; }
.woocommerce-account .woocommerce-MyAccount-navigation li a {
	font-family: var(--font-condensed); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700;
	padding: 0.5rem 1rem; background: var(--gymbo-card); border: 1px solid var(--gymbo-border-soft); color: rgba(255,255,255,0.7);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { background: var(--gymbo-purple); color: #fff; border-color: var(--gymbo-purple); }

/* Quantity buttons / inputs en carrito */
.woocommerce .quantity input.qty { background: var(--gymbo-card-2); border: 1px solid var(--gymbo-border-soft); color: #fff; }

/* Tablas responsive mínimas */
@media (max-width: 600px) {
	.woocommerce table.shop_table thead { display: none; }
	.woocommerce table.shop_table tr { display: block; border-bottom: 1px solid var(--gymbo-border); }
	.woocommerce table.shop_table td { display: flex; justify-content: space-between; border: none; }
}
