/* =============================================================================
   WooCommerce Checkout RUL – Stylesheet
   Version: 1.0.0
   ============================================================================= */

:root {
  /* Brand palette */
  --wcbc-primary:       #6c63ff;
  --wcbc-primary-dark:  #5a52d5;
  --wcbc-primary-light: #ede9ff;
  --wcbc-accent:        #ff6584;

  /* Neutrals */
  --wcbc-bg:            #f4f6fb;
  --wcbc-surface:       #ffffff;
  --wcbc-border:        #e2e8f0;
  --wcbc-border-focus:  #6c63ff;
  --wcbc-text:          #1e293b;
  --wcbc-text-muted:    #64748b;
  --wcbc-text-light:    #94a3b8;

  /* States */
  --wcbc-success:       #10b981;
  --wcbc-error:         #ef4444;
  --wcbc-warning:       #f59e0b;

  /* Sizing */
  --wcbc-radius:        12px;
  --wcbc-radius-sm:     8px;
  --wcbc-radius-xs:     6px;
  --wcbc-shadow:        0 4px 24px rgba(108,99,255,.08), 0 1px 4px rgba(0,0,0,.04);
  --wcbc-shadow-lg:     0 12px 40px rgba(108,99,255,.14), 0 2px 8px rgba(0,0,0,.06);
  --wcbc-transition:    .22s cubic-bezier(.4,0,.2,1);
}

/* =============================================================================
   Page layout
   ============================================================================= */
.wcbc-rul-checkout {
  background: var(--wcbc-bg);
  color: var(--wcbc-text);
}

.wcbc-rul-checkout .woocommerce {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 20px 60px;
}

/* H1 page title */
.wcbc-rul-checkout h1.entry-title,
.wcbc-rul-checkout .page-title {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  text-align: center;
  color: var(--wcbc-text);
  margin: 40px 0 8px;
  letter-spacing: -.02em;
}

/* =============================================================================
   Two-column checkout layout
   ============================================================================= */
.wcbc-rul-checkout .woocommerce-checkout {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 32px;
  align-items: start;
}

.wcbc-rul-checkout .col2-set {
  grid-column: 1;
  display: flex;
  flex-direction: column;
  /* gap: 24px; */
}

.wcbc-rul-checkout #order_review_col {
  grid-column: 2;
}

.wcbc-rul-checkout #order_review_heading,
.wcbc-rul-checkout #order_review {
  grid-column: auto;
}

/* =============================================================================
   Cards / sections
   ============================================================================= */
/* .wcbc-rul-checkout .col2-set .col-1, */
.wcbc-rul-checkout .col2-set .col-2,
.wcbc-rul-checkout #customer_details,
.wcbc-rul-checkout .woocommerce-shipping-fields,
.wcbc-rul-checkout .woocommerce-additional-fields
/* .wcbc-rul-checkout #payment  */
{
  background: var(--wcbc-surface);
  border-radius: var(--wcbc-radius);
  box-shadow: var(--wcbc-shadow);
  padding: 32px;
  border: 1px solid var(--wcbc-border);
  transition: box-shadow var(--wcbc-transition);
}

/* written */

.woocommerce .col2-set .col-1, .woocommerce-page .col2-set .col-1 {
    float: left;
    width: 100%;
}

.woocommerce form .form-row-first, .woocommerce form .form-row-last, .woocommerce-page form .form-row-first, .woocommerce-page form .form-row-last {
    width: 100%;
    overflow: visible;
}

.woocommerce form .form-row {
    padding: 8px 0;
}
.woocommerce-checkout #payment div.payment_box .form-row{
  margin: 0;
}

.woocommerce-error::before, .woocommerce-info::before, .woocommerce-message::before {
   display: none;
}

/* written */


/* =============================================================================
   Section headers (billing / shipping)
   ============================================================================= */
.wcbc-section-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--wcbc-border);
}

.wcbc-section-header h3 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--wcbc-text);
  letter-spacing: -.01em;
}

.wcbc-section-icon {
  width: 38px;
  height: 38px;
  background: var(--wcbc-primary-light);
  border-radius: var(--wcbc-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--wcbc-primary);
  flex-shrink: 0;
}

.wcbc-section-icon svg {
  width: 18px;
  height: 18px;
}

/* Hide default WC headings replaced by our custom ones */
.wcbc-rul-checkout .woocommerce-billing-fields h3,
.wcbc-rul-checkout .woocommerce-shipping-fields h3,
.wcbc-rul-checkout .woocommerce-additional-fields h3 {
  display: none;
}

/* =============================================================================
   Form fields
   ============================================================================= */
.wcbc-rul-checkout .form-row {
  margin-bottom: 18px;
  position: relative;
}

.wcbc-rul-checkout .form-row label {
  display: block;
  font-size: .8rem;
  font-weight: 600;
  color: var(--wcbc-text-muted);
  margin-bottom: 6px;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.wcbc-rul-checkout .form-row .required {
  color: var(--wcbc-error);
}

.wcbc-rul-checkout .form-row input[type="text"],
.wcbc-rul-checkout .form-row input[type="email"],
.wcbc-rul-checkout .form-row input[type="tel"],
.wcbc-rul-checkout .form-row input[type="number"],
.wcbc-rul-checkout .form-row input[type="password"],
.wcbc-rul-checkout .form-row select,
.wcbc-rul-checkout .form-row textarea{
  width: 100%;
  padding: 12px 16px;
  font-size: .95rem;
  color: var(--wcbc-text);
  background: #f8fafc;
  border: 1.5px solid var(--wcbc-border);
  border-radius: var(--wcbc-radius-sm);
  outline: none;
  transition: border-color var(--wcbc-transition),
              box-shadow var(--wcbc-transition),
              background var(--wcbc-transition);
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
}

.wcbc-rul-checkout :where(.woocommerce) .select2-container .select2-selection {
  width: 100%;
  padding: 5px;
  font-size: .95rem;
  color: var(--wcbc-text);
  background: #f8fafc;
  border: 1.5px solid var(--wcbc-border);
  border-radius: var(--wcbc-radius-sm);
  outline: none;
  transition: border-color var(--wcbc-transition),
              box-shadow var(--wcbc-transition),
              background var(--wcbc-transition);
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none; 
}

.wcbc-rul-checkout .form-row input:focus,
.wcbc-rul-checkout .form-row select:focus,
.wcbc-rul-checkout .form-row textarea:focus {
  border-color: var(--wcbc-border-focus);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(108,99,255,.12);
}

.wcbc-rul-checkout .form-row input.input-text.wcbc-valid,
.wcbc-rul-checkout .form-row select.wcbc-valid {
  border-color: var(--wcbc-success);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2310b981' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 40px;
}

.wcbc-rul-checkout .form-row input.wcbc-error,
.wcbc-rul-checkout .form-row select.wcbc-error {
  border-color: var(--wcbc-error);
  background: #fff5f5;
  box-shadow: 0 0 0 4px rgba(239,68,68,.08);
}

/* Select arrow */
.wcbc-rul-checkout .form-row select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 40px;
}

/* Textarea */
.wcbc-rul-checkout .form-row textarea {
  resize: vertical;
  min-height: 96px;
}

/* Half-width fields (WooCommerce adds .form-row-first / .form-row-last) */
.wcbc-rul-checkout .form-row-first,
.wcbc-rul-checkout .form-row-last {
  width: calc(50% - 10px);
  display: inline-block;
  vertical-align: top;
}

.wcbc-rul-checkout .form-row-first {
  margin-right: 16px;
}

/* WC error notices under fields */
.wcbc-rul-checkout .woocommerce-error,
.wcbc-rul-checkout ul.woocommerce-error {
  background: #fff5f5;
  border-left: 4px solid var(--wcbc-error);
  border-radius: var(--wcbc-radius-sm);
  padding: 14px 18px;
  color: var(--wcbc-error);
  font-size: .88rem;
  font-weight: 500;
  list-style: none;
  margin-bottom: 20px;
}

.wcbc-rul-checkout .woocommerce-error li::before {
  content: "⚠ ";
}

.wcbc-rul-checkout .woocommerce-info {
  background: #eff6ff;
  border-left: 4px solid #3b82f6;
  border-radius: var(--wcbc-radius-sm);
  /* padding: 14px 18px; */
  color: #1d4ed8;
  font-size: .88rem;
  margin-bottom: 20px;
}

/* =============================================================================
   Login / coupon returning customer
   ============================================================================= */
.wcbc-rul-checkout .woocommerce-info a.showlogin,
.wcbc-rul-checkout .woocommerce-info a.showcoupon {
  color: var(--wcbc-primary);
  font-weight: 600;
  text-decoration: none;
}

.wcbc-rul-checkout .woocommerce-info a:hover {
  text-decoration: underline;
  background: transparent !important;
}

.wcbc-rul-checkout .login,
.wcbc-rul-checkout .checkout_coupon {
  display: none; /* hidden by default; jQuery slideToggle overrides with inline style */
  background: var(--wcbc-surface);
  border: 1.5px solid var(--wcbc-border);
  border-radius: var(--wcbc-radius);
  padding: 24px;
  margin-bottom: 24px;
}

/* =============================================================================
   Order review (right column)
   ============================================================================= */
.wcbc-rul-checkout #order_review_heading {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--wcbc-text);
  margin: 0 0 16px;
  letter-spacing: -.01em;
}

.wcbc-rul-checkout #order_review {
  background: var(--wcbc-surface);
  border-radius: var(--wcbc-radius);
  box-shadow: var(--wcbc-shadow);
  padding: 28px;
  border: 1px solid var(--wcbc-border);
  position: sticky;
  top: 24px;
}

/* Order table */
.wcbc-rul-checkout .woocommerce-checkout-review-order-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
}

.wcbc-rul-checkout .woocommerce-checkout-review-order-table th,
.wcbc-rul-checkout .woocommerce-checkout-review-order-table td {
  padding: 10px 0;
  border-bottom: 1px solid var(--wcbc-border);
  vertical-align: middle;
}

.wcbc-rul-checkout .woocommerce-checkout-review-order-table thead th {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--wcbc-text-muted);
  padding-bottom: 12px;
}

.wcbc-rul-checkout .woocommerce-checkout-review-order-table tfoot tr:last-child td,
.wcbc-rul-checkout .woocommerce-checkout-review-order-table tfoot tr:last-child th {
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--wcbc-text);
  border-bottom: none;
  border-top: 2px solid var(--wcbc-border);
  padding-top: 14px;
}

.wcbc-rul-checkout .product-quantity {
  color: var(--wcbc-text-muted);
  font-weight: 500;
}

/* =============================================================================
   Shipping methods
   ============================================================================= */
.wcbc-rul-checkout .woocommerce-shipping-totals {
  background: var(--wcbc-bg);
  border-radius: var(--wcbc-radius-sm);
  padding: 12px;
  margin: 4px 0;
}

.wcbc-rul-checkout #shipping_method li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.wcbc-rul-checkout #shipping_method label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .9rem;
  cursor: pointer;
  padding: 8px 12px;
  border-radius: var(--wcbc-radius-xs);
  transition: background var(--wcbc-transition);
}

.wcbc-rul-checkout #shipping_method label:hover {
  background: var(--wcbc-primary-light);
}

/* =============================================================================
   Payment section
   ============================================================================= */
.wcbc-rul-checkout #payment {
  margin-top: 0;
}

.wcbc-rul-checkout #payment .wc_payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.wcbc-rul-checkout #payment .wc_payment_methods li.payment_method {
  border: 1.5px solid var(--wcbc-border);
  border-radius: var(--wcbc-radius-sm);
  overflow: hidden;
  transition: border-color var(--wcbc-transition), box-shadow var(--wcbc-transition);
}

.wcbc-rul-checkout #payment .wc_payment_methods li.payment_method:has(input:checked) {
  border-color: var(--wcbc-primary);
  box-shadow: 0 0 0 3px var(--wcbc-primary-light);
}


/* =============================================================================
   Place Order button
   ============================================================================= */
.wcbc-rul-checkout #payment #place_order,
.wcbc-rul-checkout button.button[name="woocommerce_checkout_place_order"] {
  width: 100%;
  padding: 16px 24px;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .02em;
  color: #fff;
  background: linear-gradient(135deg, var(--wcbc-primary) 0%, var(--wcbc-primary-dark) 100%);
  border: none;
  border-radius: var(--wcbc-radius-sm);
  cursor: pointer;
  transition: transform var(--wcbc-transition),
              box-shadow var(--wcbc-transition),
              filter var(--wcbc-transition);
  box-shadow: 0 4px 16px rgba(108,99,255,.35);
  position: relative;
  overflow: hidden;
  margin-top: 4px;
}

.wcbc-rul-checkout #payment #place_order::before {
  content: '🔒  ';
  font-size: .9em;
}

.wcbc-rul-checkout #payment #place_order:hover,
.wcbc-rul-checkout button.button[name="woocommerce_checkout_place_order"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(108,99,255,.45);
  filter: brightness(1.05);
}

.wcbc-rul-checkout #payment #place_order:active {
  transform: translateY(0);
}

/* Loading state */
.wcbc-rul-checkout #payment #place_order.loading {
  pointer-events: none;
  opacity: .8;
}

/* =============================================================================
   Checkout terms / privacy
   ============================================================================= */
.wcbc-rul-checkout .woocommerce-terms-and-conditions-wrapper {
  font-size: .82rem;
  color: var(--wcbc-text-muted);
  margin-bottom: 16px;
  line-height: 1.6;
}

.wcbc-rul-checkout .woocommerce-terms-and-conditions-wrapper a {
  color: var(--wcbc-primary);
  text-decoration: none;
  font-weight: 500;
}

.wcbc-rul-checkout .woocommerce-terms-and-conditions-wrapper a:hover {
  text-decoration: underline;
}

/* =============================================================================
   Order received / Thank you page
   ============================================================================= */
.wcbc-rul-checkout .woocommerce-order {
  background: var(--wcbc-surface);
  border-radius: var(--wcbc-radius);
  box-shadow: var(--wcbc-shadow);
  padding: 40px;
  text-align: center;
  border: 1px solid var(--wcbc-border);
  margin-top: 24px;
}

.wcbc-rul-checkout .woocommerce-order-overview {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0;
  list-style: none;
  padding: 24px 0;
  margin: 24px 0;
  border-top: 1px solid var(--wcbc-border);
  border-bottom: 1px solid var(--wcbc-border);
}

.wcbc-rul-checkout .woocommerce-order-overview li {
  padding: 0 24px;
  border-right: 1px solid var(--wcbc-border);
  font-size: .9rem;
}

.wcbc-rul-checkout .woocommerce-order-overview li:last-child {
  border-right: none;
}

.wcbc-rul-checkout .woocommerce-order-overview strong {
  display: block;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--wcbc-text);
}

/* =============================================================================
   Field validation animation
   ============================================================================= */
@keyframes wcbc-shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-6px); }
  40%       { transform: translateX(6px); }
  60%       { transform: translateX(-4px); }
  80%       { transform: translateX(4px); }
}

.wcbc-shake {
  animation: wcbc-shake .4s ease;
}

@keyframes wcbc-fade-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.wcbc-rul-checkout .woocommerce-checkout {
  animation: wcbc-fade-in .45s ease;
}

/* =============================================================================
   Responsive – tablet
   ============================================================================= */
@media (max-width: 960px) {
  .wcbc-rul-checkout .woocommerce-checkout {
    grid-template-columns: 1fr;
  }

  .wcbc-rul-checkout #order_review_col {
    grid-column: 1;
  }

  .wcbc-rul-checkout #order_review_heading,
  .wcbc-rul-checkout #order_review {
    grid-column: auto;
    position: static;
  }
}

/* =============================================================================
   Responsive – mobile
   ============================================================================= */
@media (max-width: 600px) {
  .wcbc-rul-checkout .woocommerce {
    padding: 0 14px 40px;
  }

  .wcbc-rul-checkout .col2-set .col-1,
  .wcbc-rul-checkout .col2-set .col-2,
  .wcbc-rul-checkout #order_review,
  .wcbc-rul-checkout #payment {
    padding: 20px;
  }

  .wcbc-rul-checkout .form-row-first,
  .wcbc-rul-checkout .form-row-last {
    width: 100% !important;
    margin-right: 0;
    display: block;
  }

  .wcbc-trust-badges {
    gap: 12px;
  }
}

/* =============================================================================
   WooCommerce overlay / spinner
   ============================================================================= */
.wcbc-rul-checkout .blockOverlay {
  border-radius: var(--wcbc-radius);
}

/* =============================================================================
   Checkbox style override
   ============================================================================= */
.wcbc-rul-checkout input[type="checkbox"] {
  accent-color: var(--wcbc-primary);
  width: 16px;
  height: 16px;
}

/* =============================================================================
   "Ship to different address?" toggle
   ============================================================================= */
.wcbc-rul-checkout .woocommerce-shipping-fields h3 label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
}

/* =============================================================================
   Back to cart link
   ============================================================================= */
.wcbc-rul-checkout .wc-backward,
.wcbc-rul-checkout a.wc-backward {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--wcbc-text-muted);
  font-size: .88rem;
  text-decoration: none;
  font-weight: 500;
  transition: color var(--wcbc-transition);
}

.wcbc-rul-checkout .wc-backward::before {
  content: '←';
}

.wcbc-rul-checkout .wc-backward:hover {
  color: var(--wcbc-primary);
}
