/* =========================================================================
   Sir Neko GP — Side-cart drawer + carrito/checkout (Fase 5). MOBILE-FIRST.
   ========================================================================= */

/* ---------- Side-cart drawer (rediseño Fase 5) ----------
   Estructura: cabecera fija · lista de items SCROLLEABLE · footer (subtotal + nota +
   botones) PINEADO al fondo. Resuelve el "espacio vacío enorme" y el texto pegado. */
.sn-drawer { position: fixed; inset: 0; z-index: 1000; }
.sn-drawer__overlay { position: absolute; inset: 0; background: rgba(28,28,28,.45); }
.sn-drawer__panel {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 100vw;   /* mobile: full-screen (desktop lo limita a 410px más abajo) */
  background: var(--sn-cream);
  display: flex;
  flex-direction: column;
  box-shadow: -10px 0 40px rgba(28,28,28,.18);
  transition: transform .3s var(--sn-spring);
}
.sn-drawer__panel--out { transform: translateX(100%); }
@media (prefers-reduced-motion: reduce) { .sn-drawer__panel { transition: none; } }
/* que el drawer no quede tapado por la admin-bar (solo en preview admin) */
.admin-bar .sn-drawer__panel { top: 46px; }
@media (min-width: 783px) { .admin-bar .sn-drawer__panel { top: 32px; } }

/* cabecera (fija) */
.sn-drawer__head {
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 1.25rem;
  border-bottom: 1px solid var(--sn-border);
}
.sn-drawer__title { font-weight: var(--sn-fw-bold); font-size: 1.05rem; text-transform: uppercase; letter-spacing: var(--sn-ls-wide); }
.sn-drawer__close {
  display: grid; place-items: center;
  width: 2.25rem; height: 2.25rem;
  background: rgba(28,28,28,.05); border: none; border-radius: 50%;
  cursor: pointer; color: var(--sn-ink); padding: 0;
  transition: background .18s ease;
}
.sn-drawer__close:hover { background: rgba(28,28,28,.12); }
.sn-drawer__close:focus-visible { outline: 2px solid var(--sn-green); outline-offset: 2px; }

/* cuerpo = columna flex; la LISTA scrollea, el footer queda abajo.
   .sn-drawer__body = wrapper estable (no lo toca WC); .widget_shopping_cart_content
   = lo reemplaza WC al refrescar fragments, por eso el flex se declara en AMBOS. */
.sn-drawer__body { flex: 1 1 auto; display: flex; flex-direction: column; overflow: hidden; min-height: 0; padding: 0; }
.sn-drawer .widget_shopping_cart_content { flex: 1 1 auto; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }

/* estado vacío */
.sn-drawer .woocommerce-mini-cart__empty-message { margin: auto; color: var(--sn-muted); padding: 2rem; text-align: center; }

/* lista de items: ÚNICA zona scrolleable */
.sn-drawer ul.woocommerce-mini-cart { flex: 1 1 auto; overflow-y: auto; list-style: none; margin: 0; padding: .25rem 1.25rem; }

/* item: imagen a la izquierda (absolute), contenido a la derecha, remove arriba-der */
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item {
  position: relative;
  padding: 1.1rem 2.2rem 1.1rem 84px;
  border-bottom: 1px solid var(--sn-border);
  margin: 0;
}
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item:last-child { border-bottom: none; }
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item img {
  position: absolute;
  left: 0; top: 1.1rem;
  width: 64px; height: 64px;
  float: none;
  object-fit: cover;
  border-radius: var(--sn-radius-sm);
  margin: 0;
  background: var(--sn-cream-2);
}
/* título: clamp a 2 líneas */
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item > a:not(.remove) {
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; line-clamp: 2; overflow: hidden;
  color: var(--sn-ink);
  font-weight: var(--sn-fw-semibold);
  font-size: .9rem;
  line-height: 1.3;
}
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item .quantity {
  display: block;
  margin-top: .4rem;
  color: var(--sn-muted);
  font-size: .88rem;
}
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item .quantity .woocommerce-Price-amount { color: var(--sn-ink); font-weight: var(--sn-fw-bold); }
/* stepper de cantidad (− N +) + subtotal de línea a la derecha (reemplaza el "N × $" nativo) */
.sn-drawer .sn-cart-line { display: flex; align-items: center; justify-content: space-between; gap: .5rem; margin-top: .55rem; }
.sn-drawer .sn-cart-qty { display: inline-flex; align-items: center; gap: .15rem; border: 1px solid var(--sn-border); border-radius: var(--sn-radius-pill); padding: .12rem; background: var(--sn-white); }
.sn-drawer .sn-cart-qty.sn-qty-loading { opacity: .45; pointer-events: none; }
.sn-drawer .sn-qty-btn { width: 1.65rem; height: 1.65rem; display: grid; place-items: center; border: none; background: transparent; color: var(--sn-ink); font-size: 1.05rem; line-height: 1; cursor: pointer; border-radius: 50%; transition: background .15s ease; padding: 0; }
.sn-drawer .sn-qty-btn:hover { background: rgba(28,28,28,.08); }
.sn-drawer .sn-qty-btn:focus-visible { outline: 2px solid var(--sn-green); outline-offset: 1px; }
.sn-drawer .sn-qty-val { min-width: 1.6rem; text-align: center; font-weight: var(--sn-fw-semibold); font-size: .85rem; }
.sn-drawer .sn-cart-price { color: var(--sn-ink); font-weight: var(--sn-fw-bold); font-size: 1rem; white-space: nowrap; }
/* remove: X dibujada con pseudo-elementos (el glifo × de Josefin se ve como asterisco) */
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item a.remove {
  position: absolute; right: 0; top: 1rem;
  width: 1.6rem; height: 1.6rem;
  display: grid; place-items: center;
  border-radius: 50%; background: rgba(28,28,28,.06);
  font-size: 0 !important;
  color: var(--sn-ink) !important; text-decoration: none;
  transition: background .18s ease, color .18s ease;
}
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item a.remove::before,
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item a.remove::after {
  content: ""; position: absolute;
  width: 11px; height: 1.6px; border-radius: 2px; background: currentColor;
}
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item a.remove::before { transform: rotate(45deg); }
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item a.remove::after { transform: rotate(-45deg); }
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item a.remove:hover { background: var(--sn-blush); color: #b91c1c !important; }
.sn-drawer ul.woocommerce-mini-cart li.woocommerce-mini-cart-item a.remove:focus-visible { outline: 2px solid var(--sn-green); outline-offset: 2px; }

/* footer (pineado): subtotal + nota + botones */
.sn-drawer .woocommerce-mini-cart__total {
  flex-shrink: 0;
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 1rem 1.25rem .4rem;
  font-weight: var(--sn-fw-bold); font-size: 1rem;
  border-top: 2px solid var(--sn-ink);
}
.sn-drawer .woocommerce-mini-cart__total .woocommerce-Price-amount { color: var(--sn-ink); font-size: 1.25rem; }
.sn-drawer .sn-cart-note { flex-shrink: 0; margin: 0; padding: 0 1.25rem .6rem; color: var(--sn-muted); font-size: .74rem; text-align: center; }
.sn-drawer .woocommerce-mini-cart__buttons { flex-shrink: 0; display: grid; gap: .55rem; margin: 0; padding: .2rem 1.25rem 1.25rem; }
.sn-drawer .woocommerce-mini-cart__buttons .button {
  display: flex; align-items: center; justify-content: center;
  min-height: 48px; margin: 0; text-align: center;
  border-radius: var(--sn-radius-pill);
  font-weight: var(--sn-fw-bold); text-transform: uppercase; letter-spacing: var(--sn-ls-wide); font-size: .75rem;
}
/* checkout = primario verde, arriba (order) */
.sn-drawer .woocommerce-mini-cart__buttons .checkout { order: -1; background: var(--sn-green); color: var(--sn-white); }
.sn-drawer .woocommerce-mini-cart__buttons .checkout:hover { background: var(--sn-green-dark); color: var(--sn-white); }
/* ver carrito = secundario ghost */
.sn-drawer .woocommerce-mini-cart__buttons .button:not(.checkout) { background: transparent; color: var(--sn-ink); border: 1.5px solid var(--sn-border); }
.sn-drawer .woocommerce-mini-cart__buttons .button:not(.checkout):hover { background: var(--sn-ink); color: var(--sn-white); border-color: var(--sn-ink); }
.sn-drawer .woocommerce-mini-cart__buttons .button:focus-visible { outline: 2px solid var(--sn-green); outline-offset: 2px; }

/* ---------- Página de carrito (layout moderno, estilo Barberry) ---------- */
/* 2 columnas: items (izquierda) + totales (derecha). El notice ocupa toda la fila. */
.woocommerce-cart .woocommerce {
  display: flex; flex-wrap: wrap; align-items: flex-start; gap: var(--sn-space-6) var(--sn-space-5);
}
.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper { flex: 1 1 100%; }
.woocommerce-cart .woocommerce-cart-form { flex: 1 1 48%; max-width: 50%; min-width: 0; margin: 0; }
.woocommerce-cart .cart-collaterals { flex: 1 1 48%; max-width: 50%; min-width: 320px; float: none !important; width: auto !important; }
.woocommerce-cart .cart-collaterals .cart_totals { width: auto !important; float: none !important; }
@media (max-width: 860px) {
  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-cart .cart-collaterals { flex: 1 1 100%; max-width: none; }
}

/* la tabla deja de ser tabla: cada producto es una card en fila */
.woocommerce-cart table.shop_table { border: none; background: transparent; border-spacing: 0; display: block; }
.woocommerce-cart table.shop_table thead { display: none; }
.woocommerce-cart table.shop_table tbody { display: block; }
.woocommerce-cart table.shop_table tbody tr.cart_item {
  display: flex; align-items: center; flex-wrap: wrap; gap: .5rem 1rem;
  background: var(--sn-white); border: 1px solid var(--sn-border); border-radius: var(--sn-radius-lg);
  box-shadow: var(--sn-shadow-sm); padding: .9rem 1.1rem; margin: 0 0 .8rem;
}
@media (max-width: 640px) {
  .woocommerce-cart table.shop_table tbody tr.cart_item { flex-wrap: wrap; position: relative; padding: 1rem; }
  .woocommerce-cart .cart_item td::before { display: none !important; } /* labels responsive de WC (Producto:/Precio:/…) */
  .cart_item .product-thumbnail { order: 1; }
  .cart_item .product-name { order: 2; flex: 1 1 0; min-width: 0; text-align: left !important; padding-right: 1.6rem; }
  .cart_item .product-remove { order: 3; position: absolute; top: .6rem; right: .7rem; margin: 0; }
  .cart_item .product-price { display: none !important; } /* redundante con el subtotal en mobile */
  .cart_item .product-quantity { order: 4; margin-top: .6rem; }
  .cart_item .product-subtotal { order: 5; margin-left: auto; margin-top: .6rem; }
  /* cupón: input + botón apilados a lo ancho (no se cortan ni desbordan) */
  .woocommerce-cart .woocommerce-cart-form .actions { flex-wrap: wrap; }
  .woocommerce-cart .woocommerce-cart-form .actions .coupon { flex-wrap: wrap; max-width: none; flex: 1 1 100%; }
  .woocommerce-cart .woocommerce-cart-form .actions .coupon .input-text { flex: 1 1 100%; width: 100%; min-width: 0; }
  .woocommerce-cart .woocommerce-cart-form .actions .coupon .button { flex: 1 1 100%; width: 100%; }
  .woocommerce-cart .cart-collaterals { min-width: 0; }
}
.woocommerce-cart table.shop_table tbody tr.cart_item td { border: none !important; padding: 0; display: block; }
.cart_item .product-thumbnail { order: 1; flex-shrink: 0; }
.cart_item .product-thumbnail img { width: 64px; height: 64px; object-fit: cover; border-radius: var(--sn-radius); display: block; }
.cart_item .product-name { order: 2; flex: 1 1 auto; min-width: 120px; }
.cart_item .product-name a { color: var(--sn-ink); font-weight: var(--sn-fw-semibold); font-size: .95rem; line-height: 1.3; }
.cart_item .product-price { order: 3; flex-shrink: 0; color: var(--sn-muted); font-weight: var(--sn-fw-semibold); font-size: .9rem; }
.cart_item .product-quantity { order: 4; flex-shrink: 0; }
.cart_item .product-subtotal { order: 5; flex-shrink: 0; color: var(--sn-green-dark); font-weight: var(--sn-fw-bold); }
.cart_item .product-remove { order: 6; flex-shrink: 0; }
.cart_item .product-remove a.remove {
  color: var(--sn-muted) !important; font-size: 1.3rem; width: auto; height: auto; line-height: 1; font-weight: 400;
}
.cart_item .product-remove a.remove:hover { color: #c0392b !important; background: transparent !important; }

/* totales (card a la derecha) */
.woocommerce-cart .cart-collaterals .cart_totals { background: var(--sn-white); border: 1px solid var(--sn-border); border-radius: var(--sn-radius-lg); padding: 1.5rem; box-shadow: var(--sn-shadow-md); }
.woocommerce-cart .cart_totals h2 { font-size: 1.25rem; margin-top: 0; }
.woocommerce-cart .cart_totals table { border: none; width: 100%; }
.woocommerce-cart .cart_totals table th, .woocommerce-cart .cart_totals table td { border: none; padding: .7rem 0; vertical-align: top; }
.woocommerce-cart .cart_totals table th { text-align: left; font-weight: var(--sn-fw-semibold); color: var(--sn-ink); white-space: nowrap; }
.woocommerce-cart .cart_totals table td { text-align: right; }
/* totales: sin bordes internos ni labels responsive duplicados (el "Envío:" doble) */
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td { border: none !important; }
.woocommerce-cart .cart_totals td::before { display: none !important; }
/* fila de Envío: label "Envío" una vez + métodos a ancho COMPLETO (cada uno en 1 línea, sin cortarse) */
.woocommerce-cart .cart_totals tr.shipping { display: block !important; width: 100% !important; }
.woocommerce-cart .cart_totals tr.shipping th,
.woocommerce-cart .cart_totals tr.shipping td { display: block !important; width: 100% !important; float: none !important; text-align: left !important; white-space: normal; }
.woocommerce-cart .cart_totals tr.shipping th { padding: .9rem 0 .3rem; }
.woocommerce-cart .cart_totals tr.shipping td { padding: 0; }
.woocommerce-cart .cart_totals tr.shipping #shipping_method { margin: 0; padding: 0; list-style: none; width: 100%; }
.woocommerce-cart .cart_totals tr.shipping #shipping_method li { padding: .3rem 0; line-height: 1.4; width: 100%; display: flex; flex-wrap: wrap; align-items: baseline; gap: .35rem; }
.woocommerce-cart .cart_totals tr.shipping #shipping_method li label { display: inline; }
.woocommerce-cart .cart_totals tr.shipping .woocommerce-shipping-destination { color: var(--sn-muted); font-size: .85rem; margin-top: .5rem; }

/* fila de acciones: SOLO el cupón (el "Actualizar carrito" se oculta — auto-update por JS) */
.woocommerce-cart .woocommerce-cart-form .actions {
  display: flex; align-items: center; gap: .6rem; margin-top: 1rem; padding: 0 !important;
  border: none !important; background: transparent !important; box-shadow: none !important;
}
.woocommerce-cart .woocommerce-cart-form .actions .coupon {
  display: flex; align-items: center; gap: .6rem; flex: 1 1 100%; max-width: 640px;
}
.woocommerce-cart .woocommerce-cart-form .actions .coupon .input-text {
  flex: 1 1 auto; width: auto; min-width: 220px; margin: 0; height: auto;
  padding: .9em 1.25em; border: 1.5px solid var(--sn-border); border-radius: var(--sn-radius-pill);
  background: var(--sn-white); color: var(--sn-ink);
}
.woocommerce-cart .woocommerce-cart-form .actions .coupon .button { white-space: nowrap; border-radius: var(--sn-radius-pill); padding: .9em 1.6em; }
.woocommerce-cart .woocommerce-cart-form .actions button[name="update_cart"] { display: none !important; }
/* la fila de acciones NO es una card (sacar el recuadro/línea del container) */
.woocommerce-cart table.shop_table td.actions,
.woocommerce-cart table.shop_table tbody tr:not(.cart_item) {
  background: transparent !important; border: none !important; box-shadow: none !important; padding: 0 !important; margin: 0 !important;
}

/* selector de cantidad (pill) en la página de carrito */
.woocommerce-cart .product-quantity .quantity {
  display: inline-flex; align-items: center; gap: .1rem;
  border: 1.5px solid var(--sn-border); border-radius: 999px; padding: .2rem; background: var(--sn-white);
}
.woocommerce-cart .product-quantity .quantity .sn-qty-btn {
  width: 2rem; height: 2rem; border: none; background: transparent; color: var(--sn-ink);
  font-size: 18px; line-height: 1; cursor: pointer; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; transition: background .15s ease;
}
.woocommerce-cart .product-quantity .quantity .sn-qty-btn:hover { background: rgba(28,28,28,.08); }
.woocommerce-cart .product-quantity .quantity input.qty {
  width: 2.2rem; height: auto; margin: 0; min-height: 0 !important; padding: 0 !important;
  border: none !important; background: transparent !important; box-shadow: none !important; outline: none !important;
  text-align: center; font-weight: 600; color: var(--sn-ink); -moz-appearance: textfield;
}
.woocommerce-cart .product-quantity .quantity input.qty::-webkit-outer-spin-button,
.woocommerce-cart .product-quantity .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* (el "Actualizar carrito" se oculta; el carrito se auto-actualiza por JS al cambiar la cantidad) */
/* boton FINALIZAR COMPRA: verde, texto en linea, ancho completo */
.woocommerce .wc-proceed-to-checkout a.checkout-button {
  display: block; width: 100%; text-align: center;
  background: var(--sn-green); color: var(--sn-white);
  border-radius: var(--sn-radius-sm);
  font-size: .78rem; letter-spacing: .04em; padding: 1em .6em;
  white-space: normal; line-height: 1.25;
}
.woocommerce .wc-proceed-to-checkout a.checkout-button:hover { background: var(--sn-ink); color: var(--sn-white); }
/* boton "actualizar carrito" cuando esta activo */
.woocommerce-cart .actions .button:not(:disabled) { background: var(--sn-ink); color: var(--sn-white); }

/* ---------- Checkout ---------- */
.woocommerce-checkout #payment { background: var(--sn-cream-2); border-radius: var(--sn-radius-lg); }
.woocommerce-checkout .woocommerce-checkout-review-order-table { background: var(--sn-white); border-radius: var(--sn-radius-lg); padding: 1rem; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.select2-container .select2-selection {
  border: 1px solid var(--sn-border);
  border-radius: var(--sn-radius-sm);
  padding: .7em .9em;
  font-family: var(--sn-font);
  background: var(--sn-white);
}
.woocommerce form .form-row label { font-weight: var(--sn-fw-semibold); font-size: .85rem; }

/* ---------- My Account ---------- */
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .35rem; }
.woocommerce-account .woocommerce-MyAccount-navigation li a {
  display: block; padding: .7em 1em; border-radius: var(--sn-radius-sm);
  color: var(--sn-ink); background: var(--sn-white); box-shadow: var(--sn-shadow-sm);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { background: var(--sn-ink); color: var(--sn-white); }

/* ----- My Account: Direcciones (facturación / envío) ----- */
.woocommerce-account .woocommerce-Addresses,
.woocommerce-account .addresses {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--sn-space-5); margin-top: var(--sn-space-4);
}
/* el clearfix ::before/::after de WC (.col2-set) se vuelve grid-item y descoloca las cards */
.woocommerce-account .woocommerce-Addresses::before,
.woocommerce-account .woocommerce-Addresses::after,
.woocommerce-account .addresses::before,
.woocommerce-account .addresses::after { content: none !important; display: none !important; }
@media (max-width: 768px) {
  .woocommerce-account .woocommerce-Addresses,
  .woocommerce-account .addresses { grid-template-columns: 1fr; }
}
.woocommerce-account .woocommerce-Address {
  float: none !important; width: auto !important; margin: 0 !important;
  background: var(--sn-white); border: 1px solid var(--sn-border);
  border-radius: var(--sn-radius-lg); padding: var(--sn-space-5); box-shadow: var(--sn-shadow-sm);
}
/* título compacto + link "Editar" alineado a la derecha (no el display gigante) */
.woocommerce-account .woocommerce-Address-title {
  display: flex; align-items: baseline; justify-content: space-between; gap: 1rem;
  margin: 0 0 var(--sn-space-4); padding-bottom: var(--sn-space-3);
  border-bottom: 1.5px solid var(--sn-cream-2);
}
.woocommerce-account .woocommerce-Address-title h2,
.woocommerce-account .woocommerce-Address-title h3 {
  margin: 0; font-size: 1.15rem !important; font-weight: var(--sn-fw-bold);
  letter-spacing: var(--sn-ls-tight); color: var(--sn-ink); line-height: 1.2;
}
.woocommerce-account .woocommerce-Address-title .edit {
  flex-shrink: 0; font-size: .76rem; font-weight: var(--sn-fw-semibold);
  text-transform: uppercase; letter-spacing: var(--sn-ls-wide); color: var(--sn-green-dark); white-space: nowrap;
}
.woocommerce-account .woocommerce-Address-title .edit:hover { color: var(--sn-green); }
.woocommerce-account address {
  font-style: normal; line-height: 1.7; color: var(--sn-gray-700); font-size: .95rem; margin: 0;
}

/* ---------- Desktop ---------- */
@media (min-width: 768px) {
  .sn-drawer__panel { width: 410px; }
}
@media (min-width: 1024px) {
  /* cart: layout flex (definido arriba), ya no usa float */
  .woocommerce-checkout .col2-set { float: left; width: 52%; }
  .woocommerce-checkout #order_review, .woocommerce-checkout #order_review_heading { float: right; width: 44%; }
}
