/* ===================================================================
   Mi&Sa Boutique — Estilos WooCommerce
   Aplica a identidade visual em loja, produto, carrinho, checkout e conta.
   =================================================================== */

/* Esconde notices padrão feios e reestiliza */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  border-top-color: var(--rose) !important;
  background: var(--blush);
  color: var(--ink);
  border-radius: var(--r-sm);
  font-size: 14px;
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--rose-deep); }
.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 {
  background: var(--ink); color: var(--cream); border-radius: var(--r);
  font-size: 13px; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 12px 22px; transition: all .2s ease; border: none;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce a.button.alt:hover, .woocommerce button.button.alt:hover { background: var(--ink-soft); color: var(--cream); }
.woocommerce .button.loading { opacity: .7; }

/* ===================================================================
   PÁGINA DA LOJA — header + layout 2 colunas (filtros à esquerda)
   =================================================================== */
.shop-page-header { background: var(--blush); padding: 48px 0 40px; }
.shop-breadcrumb { font-size: 12px; color: var(--ink-soft); margin-bottom: 12px; }
.shop-breadcrumb a:hover { color: var(--rose-deep); }
.shop-page-header h1 { font-size: clamp(36px,5vw,64px); margin-bottom: 8px; }
.shop-page-header .shop-count { color: var(--ink-soft); font-size: 15px; }

.shop-layout {
  max-width: 1400px; margin: 0 auto; padding: 40px 32px 80px;
  display: grid; grid-template-columns: 260px 1fr; gap: 48px;
}
.shop-sidebar h3 { font-size: 16px; font-weight: 600; margin-bottom: 8px; }
.shop-sidebar .widget { border-bottom: 1px solid var(--line); padding: 18px 0; margin: 0; }
.shop-sidebar .widget-title, .shop-sidebar .widgettitle {
  font-size: 13px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; margin: 0 0 14px;
  font-family: var(--font-body);
}
.shop-sidebar ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.shop-sidebar ul li { font-size: 14px; }
.shop-sidebar ul li a { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.shop-sidebar ul li a:hover { color: var(--rose-deep); }
.shop-sidebar .count { color: var(--muted); font-size: 12px; }
.shop-sidebar .clear-filters { font-size: 11px; color: var(--rose-deep); text-transform: uppercase; letter-spacing: .1em; background: none; border: none; }

/* widgets de atributo / preço */
.widget_layered_nav ul li a::before { content: ''; }
.widget_price_filter .price_slider_wrapper .ui-widget-content { background: var(--line); border-radius: 4px; }
.widget_price_filter .ui-slider .ui-slider-range { background: var(--rose); }
.widget_price_filter .ui-slider .ui-slider-handle { background: var(--ink); border-radius: 50%; border: none; }
.widget_price_filter .price_label { font-size: 13px; color: var(--ink-soft); }
.widget_price_filter .button { padding: 8px 16px !important; font-size: 11px !important; }

/* swatches de cor (filtro) */
.misa-color-swatches { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.misa-color-swatches button { width: 36px; height: 36px; border-radius: 50%; border: 1px solid rgba(0,0,0,.1); padding: 0; }
.misa-color-swatches button.active { outline: 2px solid var(--ink); outline-offset: 2px; }

/* barra de resultado + ordenação */
.shop-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--line); gap: 16px; flex-wrap: wrap;
}
.shop-toolbar .woocommerce-result-count { margin: 0; color: var(--ink-soft); font-size: 13px; }
.shop-toolbar .woocommerce-ordering { margin: 0; display: flex; align-items: center; gap: 12px; }
.shop-toolbar .woocommerce-ordering::before { content: 'Ordenar:'; font-size: 13px; color: var(--ink-soft); }
.shop-toolbar select, .misa-select {
  padding: 10px 14px; border: 1px solid var(--line); border-radius: var(--r-sm);
  background: #fff; font-size: 14px; color: var(--ink); min-width: 200px;
}
.shop-toolbar select:focus, .misa-select:focus { outline: none; border-color: var(--rose); box-shadow: 0 0 0 3px rgba(201,123,123,.12); }

/* ===================================================================
   GRID + CARD DE PRODUTO (replica .product-card do mockup)
   =================================================================== */
.woocommerce ul.products, ul.products {
  display: grid !important; gap: 32px 24px; margin: 0; padding: 0; list-style: none;
}
ul.products.columns-3 { grid-template-columns: repeat(3, 1fr); }
ul.products.columns-4 { grid-template-columns: repeat(4, 1fr); }
.woocommerce ul.products li.product, ul.products li.product {
  width: auto !important; margin: 0 !important; float: none !important; text-align: left;
  position: relative; display: flex; flex-direction: column; gap: 12px;
}
ul.products li.product a { display: block; }
.misa-card-media {
  aspect-ratio: 3/4; background: var(--blush); border-radius: var(--r); overflow: hidden; position: relative;
}
.misa-card-media img, .woocommerce ul.products li.product a img {
  width: 100%; height: 100%; object-fit: cover; margin: 0; border-radius: 0; transition: transform .5s ease; display: block;
}
li.product:hover .misa-card-media img { transform: scale(1.04); }
.misa-card-media .misa-noimg { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); color: var(--rose-deep); font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  background: linear-gradient(135deg, var(--blush), var(--nude)); }
.misa-badge {
  position: absolute; top: 12px; left: 12px; background: var(--ink); color: var(--cream);
  font-size: 10px; letter-spacing: .1em; text-transform: uppercase; padding: 5px 10px; border-radius: 4px; z-index: 2;
}
.misa-badge.new { background: var(--rose); }
.misa-badge.sale { background: var(--gold); color: var(--ink); }
.misa-card-fav {
  position: absolute; top: 10px; right: 10px; width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,.9); backdrop-filter: blur(8px); display: flex; align-items: center; justify-content: center;
  z-index: 3; transition: all .2s; color: var(--ink); border: none;
}
.misa-card-fav:hover { background: #fff; transform: scale(1.08); }
.misa-card-fav svg { width: 18px; height: 18px; }
.misa-card-quick {
  position: absolute; bottom: 12px; left: 12px; right: 12px; background: rgba(255,255,255,.95);
  backdrop-filter: blur(8px); border-radius: var(--r-sm); padding: 10px; text-align: center; font-size: 11px;
  font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--ink); opacity: 0;
  transform: translateY(8px); transition: all .25s ease; z-index: 2; margin: 0;
}
li.product:hover .misa-card-quick { opacity: 1; transform: translateY(0); }
.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2, ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-body); font-size: 14px; font-weight: 500; color: var(--ink);
  line-height: 1.3; padding: 0; margin: 0;
}
.woocommerce ul.products li.product .price, ul.products li.product .price {
  font-size: 14px; color: var(--ink); margin: 0; display: flex; align-items: baseline; gap: 8px; font-weight: 600;
}
.woocommerce ul.products li.product .price del { color: var(--muted); font-weight: 400; font-size: 12px; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.misa-installment { font-size: 11px; color: var(--muted); }
.misa-card-colors { display: flex; gap: 4px; margin-top: 4px; }
.misa-card-colors .color-dot { width: 14px; height: 14px; border-radius: 50%; border: 1px solid rgba(0,0,0,.08); }
ul.products li.product .button, ul.products li.product .added_to_cart { display: none; } /* usa quick-add via overlay */

@media (max-width: 900px) {
  ul.products.columns-3, ul.products.columns-4 { grid-template-columns: repeat(2, 1fr); }
  .shop-layout { grid-template-columns: 1fr; gap: 24px; }
  .shop-sidebar { display: none; }
  .shop-sidebar.is-open { display: block; }
  .shop-filter-toggle { display: inline-flex !important; }
}
.shop-filter-toggle { display: none; align-items: center; gap: 8px; }

/* ===================================================================
   PÁGINA DE PRODUTO
   =================================================================== */
.single-product div.product { max-width: 1400px; margin: 0 auto; padding: 32px 32px 80px; }
.single-product .woocommerce-breadcrumb { font-size: 12px; color: var(--ink-soft); margin-bottom: 32px; }
.single-product div.product .product_title { font-family: var(--font-display); font-size: 32px; font-weight: 500; margin-bottom: 8px; }
.single-product div.product p.price, .single-product div.product span.price {
  color: var(--ink); font-family: var(--font-display); font-size: 36px; font-weight: 500;
}
.single-product div.product p.price del { font-size: 14px; color: var(--muted); font-family: var(--font-body); }
.single-product div.product p.price ins { text-decoration: none; }
.single-product .woocommerce-product-gallery { border-radius: var(--r); overflow: hidden; }
.single-product .woocommerce-product-gallery img { border-radius: var(--r); }
.single-product .quantity input.qty {
  width: 64px; height: 48px; border: 1px solid var(--line); border-radius: var(--r); text-align: center; font-weight: 600;
}
.single-product div.product form.cart .button {
  background: var(--ink); color: var(--cream); padding: 16px 28px; font-size: 14px; border-radius: var(--r);
}
.single-product .misa-pix-badge {
  display: inline-flex; align-items: center; gap: 6px; background: var(--blush); color: var(--rose-deep);
  padding: 6px 12px; border-radius: 6px; font-size: 12px; font-weight: 600; margin: 12px 0;
}
.single-product table.variations { margin-bottom: 16px; }
.single-product .woocommerce-tabs ul.tabs { border: none; padding: 0; }
.single-product .woocommerce-tabs ul.tabs::before { border-color: var(--line); }
.single-product .woocommerce-tabs ul.tabs li {
  background: none; border: none; border-radius: 0; padding: 0; margin: 0 32px 0 0;
}
.single-product .woocommerce-tabs ul.tabs li::before, .single-product .woocommerce-tabs ul.tabs li::after { display: none; }
.single-product .woocommerce-tabs ul.tabs li a { padding: 14px 0; color: var(--ink-soft); font-size: 14px; font-weight: 500; border-bottom: 2px solid transparent; }
.single-product .woocommerce-tabs ul.tabs li.active a { color: var(--ink); border-bottom-color: var(--rose); }
.single-product .related h2, .single-product .upsells h2 { font-family: var(--font-display); font-size: clamp(28px,3.5vw,44px); margin-bottom: 32px; }

/* ===================================================================
   CARRINHO + CHECKOUT
   =================================================================== */
.woocommerce-cart .wc-block-cart, .woocommerce-cart-form { background: #fff; border-radius: var(--r-lg); padding: 24px; box-shadow: var(--shadow-sm); }
.woocommerce table.shop_table { border-radius: var(--r); border-color: var(--line); }
.woocommerce table.shop_table th { font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); }
.cart-collaterals .cart_totals h2, .woocommerce-checkout h3 { font-family: var(--font-display); }
.woocommerce-checkout #payment { background: #fff; border-radius: var(--r-lg); }
.woocommerce-checkout #payment ul.payment_methods { border-color: var(--line); }
.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(--line); border-radius: var(--r-sm); padding: 12px 14px; font-size: 14px;
}
.woocommerce form .form-row input.input-text:focus { outline: none; border-color: var(--rose); box-shadow: 0 0 0 3px rgba(201,123,123,.12); }
.woocommerce .woocommerce-checkout-review-order { background: var(--bone); border-radius: var(--r-lg); padding: 24px; }
.woocommerce #payment #place_order, .wc-block-components-checkout-place-order-button {
  background: var(--ink) !important; color: var(--cream) !important; border-radius: var(--r) !important;
}
.woocommerce-checkout .misa-pix-note { background: var(--blush); color: var(--rose-deep); padding: 12px 16px; border-radius: var(--r-sm); font-size: 13px; font-weight: 600; margin-bottom: 16px; }

/* free shipping progress (carrinho) */
.misa-free-ship { background: var(--blush); padding: 16px 20px; border-radius: var(--r); font-size: 13px; margin-bottom: 24px; }
.misa-free-ship .bar { height: 6px; background: rgba(255,255,255,.6); border-radius: 3px; overflow: hidden; margin-top: 8px; }
.misa-free-ship .bar > span { display: block; height: 100%; background: var(--rose); transition: width .3s; }

/* ===================================================================
   MINHA CONTA
   =================================================================== */
.woocommerce-account .woocommerce-MyAccount-navigation { width: 240px; }
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block; padding: 12px 16px; border-radius: var(--r-sm); font-size: 14px; color: var(--ink); border: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a { background: var(--blush); color: var(--rose-deep); font-weight: 600; }
.woocommerce-account .woocommerce-MyAccount-content { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 32px; }

/* mini-cart widget */
.widget_shopping_cart_content .button { width: 100%; margin-top: 8px; }
