/* ===================== WOOCOMMERCE CUENTAMANIA ===================== */
/* Override general WooCommerce CSS on specific pages */

/* Formularios y campos (Globales UI) */
.cm-grid { display:grid; gap:var(--sp-4); }
.cm-grid--2 { grid-template-columns: repeat(minmax(0, 1fr), 2); }
@media (min-width: 768px) {
    .cm-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.cm-field { display:flex; flex-direction:column; gap:var(--sp-2); margin-bottom: 1em; }
.cm-field__label { font-weight:600; color:#fff; font-size:.95rem; text-transform:uppercase; letter-spacing:.02em; display:block; }
.cm-field__input,
.cm-field__textarea,
.cm-field__select { background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.16); border-radius:12px; color:#fff; padding:var(--sp-3) var(--sp-4); font-size:1rem; font-family:var(--ff-body-alt); width: 100%; transition: border-color 0.3s, box-shadow 0.3s; box-sizing: border-box; }
.cm-field__input:focus,
.cm-field__textarea:focus,
.cm-field__select:focus { outline:none; box-shadow: var(--focus-ring, 0 0 0 3px rgba(144, 122, 255, 0.25)); border-color: rgba(144, 122, 255, 0.5); background: rgba(255,255,255,.08); }
.cm-field__textarea { resize: vertical; min-height: 110px; }
.cm-field__hint { color: var(--c-muted, #a1a1aa); font-size:.85rem; margin-top: 4px; display: block; }
.cm-field.woocommerce-invalid .cm-field__input { border-color: #ef4444; background: rgba(239, 68, 68, 0.05); }

/* Ocultar labels de WooCommerce que estorban y mostrar los propios */
.woocommerce form .form-row label { display: none; }
.woocommerce form .form-row .cm-field__label { display: block; }
.woocommerce form .form-row { padding: 0; margin-bottom: 0; float: none; width: 100%; }
.woocommerce form .form-row.form-row-first, .woocommerce form .form-row.form-row-last { width: 100%; float: none; }

/* Select2 overrides for states */
.select2-container .select2-selection--single { background: rgba(255,255,255,.05) !important; border: 1px solid rgba(255,255,255,.16) !important; border-radius: 12px !important; height: 48px !important; }
.select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 46px !important; color: #fff !important; padding-left: 16px !important; }
.select2-container--default .select2-selection--single .select2-selection__arrow { height: 46px !important; right: 10px !important; }
.select2-dropdown { background-color: #1a1625 !important; border: 1px solid rgba(255,255,255,.16) !important; border-radius: 8px !important; color: #fff !important; }
.select2-container--default .select2-results__option[aria-selected=true], .select2-container--default .select2-results__option[data-selected=true] { background-color: rgba(144, 122, 255, 0.2) !important; }
.select2-container--default .select2-results__option--highlighted[aria-selected], .select2-container--default .select2-results__option--highlighted[data-selected] { background-color: var(--c-primary, #7556ff) !important; color: white !important; }

/* CHECKOUT STRUCTURE */
.cm-checkout-page { background: var(--c-bg, #0f0d1a); }
.cm-checkout__body { padding: clamp(36px, 6vw, 56px) 0; }
.cm-checkout__layout { display:grid; gap: clamp(28px, 5vw, 42px); grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr); align-items:start; }

.cm-checkout__form { background: linear-gradient(160deg, rgba(18,16,28,.92), rgba(14,12,24,.86)); border:1px solid rgba(255,255,255,.08); border-radius:24px; padding: clamp(24px, 4vw, 38px); box-shadow: 0 28px 65px rgba(9,6,22,.55); }
.cm-checkout-form { display:flex; flex-direction:column; gap:var(--sp-8, 2rem); }
.cm-checkout-step { border:0; margin:0 0 var(--sp-8, 2rem); padding:0; display:grid; gap:var(--sp-4, 1rem); }
.cm-checkout-step__title { font-size: 1.2rem;margin: 0 0 0.75em;font-weight:600; letter-spacing:.02em; color:#fff; width: 100%; border-bottom: 1px solid rgba(255,255,255,0.08); padding-bottom: 0.5em; }

/* Radio Cards (Métodos de pago) */
.cm-checkout-payments { display:grid; gap:var(--sp-4, 1rem); list-style: none; padding: 0; margin: 0; }
ul.wc_payment_methods { list-style: none !important; padding: 0 !important; margin: 0 !important; display: grid; gap: 1rem; }
li.wc_payment_method { margin: 0 !important; padding: 0 !important; background: none !important; list-style: none !important; }
li.wc_payment_method input[type="radio"] { display: none !important; }

.cm-radio-card { display:flex; align-items:flex-start; gap:var(--sp-4, 1rem); padding:var(--sp-4, 1rem) var(--sp-5, 1.25rem); border-radius:16px; border:1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.04); cursor:pointer; transition:border-color .24s ease, box-shadow .24s ease, transform .24s ease; margin-bottom: 0 !important; }
.cm-radio-card::before { content:""; width:18px; height:18px; border-radius:50%; border:2px solid rgba(255,255,255,.45); display:inline-grid; place-items:center; margin:0; flex-shrink: 0; margin-top: 2px; }
li.wc_payment_method input[type="radio"]:checked + .cm-radio-card::before { background: radial-gradient(circle, #8c7bff 40%, transparent 45%); border-color: #8c7bff; }
.cm-radio-card__content { display:grid; gap:var(--sp-2, 0.5rem); width: 100%; }
.cm-radio-card__title { font-weight:600; color:#fff; display: block; margin:0; padding:0; line-height:1.2; }
.cm-radio-card__desc { color: rgba(255,255,255,.78); font-size:.95rem; display: block; line-height:1.3; margin:0; }
.cm-radio-card__meta { color: var(--c-muted, #a1a1aa); font-size:.85rem; display: block; margin:0; }
.cm-radio-card:hover,
li.wc_payment_method input[type="radio"]:checked + .cm-radio-card { border-color: rgba(148,127,255,.55); box-shadow: 0 18px 40px rgba(32,20,68,.45); transform: translateY(-2px); }

.payment_box { background: rgba(255,255,255,.05); border-radius: 8px; padding: 1em; font-size: 0.9em; color: var(--c-muted, #a1a1aa); margin-top: 0.5em; border-left: 2px solid var(--c-primary, #7556ff); }

/* Checkboxes Terms */
.cm-checkbox { display:flex; gap:var(--sp-3, 0.75rem); align-items:flex-start; color: var(--c-muted, #a1a1aa); font-size:.92rem; cursor: pointer; }
.cm-checkbox input[type="checkbox"] { margin-top: 4px; width: 16px; height: 16px; accent-color: var(--c-primary, #7556ff); border-radius: 4px; }
.cm-checkbox a { color: var(--c-primary-light, #c6b5ff); text-decoration: underline; }

/* Place Order Button */
#place_order.button { width:100%; flex-direction:column; align-items:center; justify-content:center; font-size:1.05rem; padding: 16px 20px; box-shadow: 0 24px 40px rgba(103,84,255,.35); border-radius: 12px; background: var(--btn-bg-primary, linear-gradient(135deg, #7556ff, #543bf5)); color: #fff; border: 0; cursor: pointer; transition: transform 0.2s, box-shadow 0.2s; font-weight: 600; text-align: center; }
#place_order.button:hover { transform: translateY(-2px); box-shadow: 0 28px 50px rgba(103,84,255,.45); }
.cm-checkout__submit-note { display:block; font-size:.85rem; font-weight:400; color:rgba(255,255,255,.8); margin-top:8px; text-align: center; }

/* SUMMARY CARD (Sidebar order review) */
.cm-checkout__summary { display:grid; gap:var(--sp-5, 1.25rem); position:sticky; top:120px; }
.cm-summary-card { background: linear-gradient(155deg, rgba(25,20,46,.96), rgba(12,11,24,.88)); border:1px solid rgba(255,255,255,.1); border-radius: 20px; padding:var(--sp-6, 1.5rem); box-shadow: 0 26px 60px rgba(10,6,32,.5); }
.cm-summary-card__header { display:flex; justify-content:space-between; align-items:center; gap:var(--sp-3, 0.75rem); margin-bottom:var(--sp-4, 1rem); }
.cm-summary-card__header h2 { margin:0; font-size:1.15rem; color:#fff; font-weight: 700; border: none; padding: 0; }
.cm-summary-card__item { display:flex; justify-content:space-between; align-items:flex-start; gap:var(--sp-3, 0.75rem); padding: 12px 0; color:#fff; border-bottom:1px solid rgba(255,255,255,.08); }
.cm-summary-card__item:last-of-type { border-bottom:0; }
.cm-summary-card__item > div { display: flex; flex-direction: column; }
.cm-summary-card__item strong { display: block; font-weight: 500; font-size: 1rem; color: #fff; margin:0; }
.cm-summary-card__item small { display:block; color: var(--c-muted, #a1a1aa); margin-top:4px; font-size: 0.85rem; }
.cm-summary-card__total { display:flex; justify-content:space-between; align-items:center; font-size:1.1rem; font-weight:600; color:#fff; margin: 20px 0 8px; padding-top: 16px; border-top: 1px dashed rgba(255,255,255,.15); }
.cm-summary-card__note { color: var(--c-muted, #a1a1aa); font-size:.9rem; line-height:1.5; margin-top: 12px; }

/* Order review table reset to fit summary card */
.woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; margin: 0; padding: 0; background: transparent; }
.woocommerce-checkout-review-order-table th, 
.woocommerce-checkout-review-order-table td { padding: 12px 0; border: 0; border-bottom: 1px solid rgba(255,255,255,.08); text-align: left; background: transparent; color: #fff; }
.woocommerce-checkout-review-order-table thead th { font-weight: 600; text-transform: uppercase; font-size: 0.8em; color: var(--c-muted, #a1a1aa); }
.woocommerce-checkout-review-order-table tbody td.product-name { font-weight: 500; }
.woocommerce-checkout-review-order-table tbody td.product-total { text-align: right; }
.woocommerce-checkout-review-order-table tfoot th { font-weight: 400; color: var(--c-muted, #a1a1aa); }
.woocommerce-checkout-review-order-table tfoot td { text-align: right; font-weight: 600; }
.woocommerce-checkout-review-order-table tfoot tr.order-total th,
.woocommerce-checkout-review-order-table tfoot tr.order-total td { border-top: 1px dashed rgba(255,255,255,.15); font-size: 1.1rem; padding-top: 16px; color: #fff; }

.cm-summary-info { background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius: 16px; padding:var(--sp-6, 1.5rem); display:grid; gap:var(--sp-4, 1rem); margin-top: 1.5rem; }
.cm-summary-info h3 { margin:0; font-size:1.05rem; color:#fff; }
.cm-summary-steps { margin:0; padding-left: 1.25rem; color:rgba(255,255,255,.82); display:grid; gap: 0.5rem; font-size:.95rem; }
.cm-summary-support { background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius: 12px; padding: 1rem; display:grid; gap: 0.5rem; text-align: center; margin-top: 0.5rem; }
.cm-summary-support .cm-btn { margin: 0 auto; display: inline-flex; }

/* ACCOUNT PAGE (My Account) */
.cm-card { background: var(--card-bg, rgba(25,20,46,0.5)); border-radius: var(--card-radius, 20px); border: 1px solid rgba(255,255,255,0.08); padding: var(--sp-6, 1.5rem); box-shadow: 0 10px 30px rgba(0,0,0,0.2); margin-bottom: 2rem; }
.cm-account-login__layout { display: grid; gap: 2rem; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); align-items: start; }
.woocommerce-account .woocommerce-MyAccount-content { width: 100%; float: none; }
.woocommerce-account .woocommerce-MyAccount-content h3 { color: #fff; margin-bottom: 1em; font-size: 1.4rem; border-bottom: 1px solid rgba(255,255,255,.1); padding-bottom: 0.5em; }
.woocommerce-account .woocommerce-Message { background: rgba(144, 122, 255, 0.1); border-left: 4px solid var(--c-primary, #7556ff); color: #fff; padding: 1.2em; border-radius: 8px; margin-bottom: 1.5em; font-size: 0.95rem; }
.woocommerce-account .woocommerce-info { background: rgba(255, 255, 255, 0.05); border-top: 3px solid #4be7c8; color: #fff; padding: 1.2em; border-radius: 8px; margin-bottom: 1.5em; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 1em; }
.woocommerce-account .woocommerce-info a.showlogin { display: inline-block; padding: 8px 16px; background: rgba(255,255,255,0.1); color: #fff; border-radius: 6px; text-decoration: none; font-weight: 500; font-size: 0.9rem; }
.woocommerce-account .woocommerce-error { background: rgba(239, 68, 68, 0.1); border-left: 4px solid #ef4444; color: #fff; padding: 1.2em; border-radius: 8px; margin-bottom: 1.5em; list-style: none; }

/* My Account Table */
.woocommerce-MyAccount-orders { width: 100%; border-collapse: collapse; text-align: left; }
.woocommerce-MyAccount-orders th, .woocommerce-MyAccount-orders td { padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,0.08); color: #fff; font-size: 0.95rem; }
.woocommerce-MyAccount-orders thead th { font-weight: 600; color: var(--c-muted, #a1a1aa); text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.05em; background: rgba(255,255,255,0.02); }
.woocommerce-MyAccount-orders tbody tr:hover td { background: rgba(255,255,255,0.02); }
.woocommerce-MyAccount-orders td .button { padding: 6px 12px; background: rgba(255,255,255,0.1); color: #fff; border-radius: 6px; text-decoration: none; font-size: 0.85rem; font-weight: 500; transition: background 0.2s; display: inline-block; }
.woocommerce-MyAccount-orders td .button:hover { background: rgba(255,255,255,0.15); }

/* Login/Register Form Submit */
.woocommerce-form-login .button,
.woocommerce-form-register .button { width: 100%; padding: 14px; border-radius: 10px; background: var(--btn-bg-primary, linear-gradient(135deg, #7556ff, #543bf5)); color: #fff; font-weight: 600; border: none; cursor: pointer; transition: transform 0.2s; font-size: 1rem; }
.woocommerce-form-login .button:hover,
.woocommerce-form-register .button:hover { transform: translateY(-2px); }

/* CART TABLE STYLES */
table.shop_table.cart { width: 100%; border-collapse: collapse; margin: 0; padding: 0; background: transparent; border: none; }
table.shop_table.cart th, 
table.shop_table.cart td { padding: 16px 12px; border: 0; border-bottom: 1px solid rgba(255,255,255,.08); text-align: left; background: transparent; color: #fff; vertical-align: middle; }
table.shop_table.cart thead th { font-weight: 600; text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.05em; color: var(--c-muted, #a1a1aa); border-bottom: 1px solid rgba(255,255,255,.15); }
table.shop_table.cart tbody td.product-name a { color: #fff; font-weight: 600; background: none; text-decoration: none; }
table.shop_table.cart tbody td.product-name a:hover { color: var(--c-primary-light, #c6b5ff); }
table.shop_table.cart tbody td.product-thumbnail img { border-radius: 8px; max-width: 64px; height: auto; border: 1px solid rgba(255,255,255,.1); box-shadow: 0 4px 12px rgba(0,0,0,.2); }
table.shop_table.cart tbody td.product-remove a { color: #ef4444; font-size: 1.5rem; text-decoration: none; font-weight: bold; }
table.shop_table.cart tbody td.product-remove a:hover { color: #f87171; }
table.shop_table.cart td.actions { padding-top: 1.5rem; text-align: right; border-bottom: none; }
table.shop_table.cart td.actions .coupon { float: left; display: flex; gap: 0.5rem; }
table.shop_table.cart td.actions .button { padding: 12px 20px; border-radius: 8px; background: rgba(255,255,255,.1); color: #fff; border: 1px solid rgba(255,255,255,.2); cursor: pointer; font-weight: 500; transition: all 0.2s; }
table.shop_table.cart td.actions .button:hover { background: rgba(255,255,255,.2); box-shadow: 0 4px 12px rgba(0,0,0,.2); }

/* Cart Collaterals (Totals) */
.cart-collaterals .cart_totals { width: 100%; float: none; }
.cart-collaterals .cart_totals h2 { display: none; /* Handled by cm-summary-card layout */ }
.cart-collaterals .cart_totals table.shop_table { width: 100%; border-collapse: separate; border-spacing: 0; background: transparent; border: none; margin-bottom: 1.5rem; }
.cart-collaterals .cart_totals table.shop_table th,
.cart-collaterals .cart_totals table.shop_table td { padding: 12px 0; border: none; border-bottom: 1px solid rgba(255,255,255,.08); color: #fff; background: transparent; }
.cart-collaterals .cart_totals table.shop_table th { text-align: left; font-weight: 500; color: var(--c-muted, #a1a1aa); }
.cart-collaterals .cart_totals table.shop_table td { text-align: right; font-weight: 600; }
.cart-collaterals .cart_totals table.shop_table tr.order-total th,
.cart-collaterals .cart_totals table.shop_table tr.order-total td { border-top: 1px dashed rgba(255,255,255,.15); border-bottom: none; font-size: 1.1rem; padding-top: 16px; color: #fff; }
.cart-collaterals .checkout-button { width: 100%; display: block; text-align: center; padding: 16px 20px; box-shadow: 0 24px 40px rgba(103,84,255,.35); border-radius: 12px; background: var(--btn-bg-primary, linear-gradient(135deg, #7556ff, #543bf5)); color: #fff; text-decoration: none; font-weight: 600; transition: transform 0.2s, box-shadow 0.2s; }
.cart-collaterals .checkout-button:hover { transform: translateY(-2px); box-shadow: 0 28px 50px rgba(103,84,255,.45); }

@media (max-width: 1080px) {
  .cm-checkout__layout { grid-template-columns: 1fr; }
  .cm-checkout__summary { position:static; }
}
@media (max-width: 760px) {
  .cm-grid--2 { grid-template-columns: 1fr; }
  table.shop_table.cart thead { display: none; }
  table.shop_table.cart tr { display: block; border-bottom: 2px dashed rgba(255,255,255,.1); padding-bottom: 1rem; margin-bottom: 1rem; }
  table.shop_table.cart td { display: flex; justify-content: space-between; align-items: center; border-bottom: none; padding: 8px 0; }
  table.shop_table.cart td::before { content: attr(data-title) ": "; font-weight: 600; color: var(--c-muted, #a1a1aa); text-transform: uppercase; font-size: 0.8rem; }
  table.shop_table.cart td.product-remove, table.shop_table.cart td.product-thumbnail { display: block; text-align: center; }
  table.shop_table.cart td.product-remove::before, table.shop_table.cart td.product-thumbnail::before { display: none; }
  table.shop_table.cart td.actions { flex-direction: column; align-items: stretch; gap: 0.5rem; }
  table.shop_table.cart td.actions .coupon { width: 100%; flex-direction: column; }
  table.shop_table.cart td.actions .coupon .input-text, table.shop_table.cart td.actions .coupon .button { width: 100%; }
}

/* WOOCOMMERCE COMPONENT OVERRIDES & LAYOUTS */

/* WooCommerce Inputs Override to match .cm-field__input */
.woocommerce form .form-row input.input-text, 
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  color: #fff !important;
  border-radius: 8px !important;
  padding: 12px 14px !important;
  box-shadow: none !important;
  width: 100%;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--c-primary, #7556ff) !important;
  background: rgba(255,255,255,0.08) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(117, 86, 255, 0.2) !important;
}

/* Form field labels and headings */
.woocommerce form .form-row label {
  color: var(--c-text, #f8f8f2);
  font-weight: 500;
  margin-bottom: 6px;
  display: block;
}
.woocommerce-checkout h3, .woocommerce-account h3, .woocommerce-cart h2 {
  font-family: var(--f-display, "Space Grotesk", sans-serif);
  font-size: 1.25rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
  margin-bottom: 1.5rem;
  margin-top: 1rem;
}
.woocommerce-checkout #order_review_heading { display: none; }

/* ACCOUNT LAYOUTS */
.cm-account-login__layout {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  align-items: start;
}
.cm-auth-title { font-size: 2rem; letter-spacing: -0.03em; margin-bottom: 0.5rem; }
.cm-auth-desc { margin-bottom: 2rem; }
.cm-auth-actions { margin-top: 2rem; }
.cm-auth-helper { margin-top: 1rem; text-align: center; }

/* Logged in Account Grid */
.grid.cards-3 {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  align-items: start;
}

/* My Account Navigation native replacement */
.woocommerce-MyAccount-navigation { display: none !important; }
.woocommerce-MyAccount-content { width: 100% !important; float: none !important; }


/* Force specific checkout fields to 100% width (overriding Woo auto-grids) */
#billing_email_field,
#billing_phone_field,
#order_comments_field {
    width: 100% !important;
    float: none !important;
    clear: both !important;
}

/* Hide WooCommerce optional text append to match mockup */
.woocommerce-checkout form .optional {
    display: none !important;
}

