/* ─── MIRAI Checkout — Classic, Shopify Payments replica ─── */
/* Color tokens from Shopify checkout source --x-skeleton-color-global-* */

:root {
  --mck-blue:           #005BD1;
  --mck-blue-hover:     #0061E0;
  --mck-blue-dark:      #004CB3;
  --mck-blue-tint:      #E7F0FB;
  --mck-blue-tint-dark: #D5E5F8;
  --mck-gray-bg:        #F5F5F5;
  --mck-gray-bg-sub:    #EDEDED;
  --mck-border:         #DEDEDE;
  --mck-border-strong:  #D6D6D6;
  --mck-text:           #000000;
  --mck-text-subdued:   #707070;
  --mck-red:            #D42B2B;
  --mck-radius:         5px;
  --mck-radius-lg:      10px;
  --mck-green:          #008060;
}

/* ─── Global page reset ─── */
body.mirai-checkout-page {
  background: #ffffff;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--mck-text);
  margin: 0;
  -webkit-font-smoothing: antialiased;
}
body.mirai-checkout-page .site-content > .col-full,
body.mirai-checkout-page #primary,
body.mirai-checkout-page .site-main,
body.mirai-checkout-page #content,
body.mirai-checkout-page .col-full,
body.mirai-checkout-page article.page,
body.mirai-checkout-page .entry-content,
body.mirai-checkout-page article.post,
body.mirai-checkout-page .type-page {
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  border: none !important;
}
body.mirai-checkout-page .mck-form,
body.mirai-checkout-page .mck-layout {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
body.mirai-checkout-page .mck-summary {
  margin-top: 0 !important;
}
body.mirai-checkout-page .entry-header,
body.mirai-checkout-page .woocommerce-breadcrumb,
body.mirai-checkout-page .page-header,
body.mirai-checkout-page .storefront-handheld-footer-bar { display: none !important; }

/* Hide Stripe Link prompt + WC "Have a coupon?" banner */
body.mirai-checkout-page .woocommerce-form-coupon-toggle,
body.mirai-checkout-page .checkout_coupon,
body.mirai-checkout-page .wc-stripe-link-payment-method,
body.mirai-checkout-page .wc-stripe-link-payment-method-button-container,
body.mirai-checkout-page .wc-stripe-payment-request-button-separator,
body.mirai-checkout-page .wc-stripe-link-section,
body.mirai-checkout-page .wc-stripe-payment-element-link-section,
body.mirai-checkout-page .wc-stripe-link-button-section,
body.mirai-checkout-page .wc-stripe-link-button,
body.mirai-checkout-page [id*="stripe-link"],
body.mirai-checkout-page [class*="stripe-link"],
body.mirai-checkout-page [class*="StripeLink"],
body.mirai-checkout-page .woocommerce-info[class*="coupon"] { display: none !important; }

/* ─── Minimal checkout header (logo CENTERED, bag right) ─── */
.mck-header {
  background: #ffffff;
  border-bottom: 1px solid var(--mck-border);
  position: relative;
  z-index: 50;
}
.mck-header__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 20px 32px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}
.mck-header__logo { grid-column: 2; justify-self: center; }
.mck-header__logo img { height: 46px; width: auto; display: block; }
.mck-header__bag {
  grid-column: 3;
  justify-self: end;
  color: var(--mck-blue);
  text-decoration: none;
  position: relative;
  display: inline-flex;
  padding: 6px;
}
.mck-header__bag:hover { color: var(--mck-blue-hover); }
.mck-header__bag-count {
  position: absolute;
  top: -2px; right: -2px;
  background: var(--mck-red);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 16px; height: 16px;
  border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0 4px;
}
@media (max-width: 768px) {
  .mck-header__inner { padding: 16px; }
  .mck-header__logo img { height: 38px; }
}

/* ─── Minimal checkout footer ─── */
.mck-footer {
  border-top: 1px solid var(--mck-border);
  background: #ffffff;
  padding: 24px 16px;
}
.mck-footer__inner { max-width: 1280px; margin: 0 auto; }
.mck-footer__links { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; }
.mck-footer__links a {
  font-size: 13px;
  color: var(--mck-blue);
  text-decoration: underline;
  text-decoration-color: rgba(0, 91, 209, 0.35);
}
.mck-footer__links a:hover { text-decoration-color: var(--mck-blue); }
@media (max-width: 768px) {
  .mck-footer { padding: 20px 16px 80px; }
  .mck-footer__links { gap: 12px; }
  .mck-footer__links a { font-size: 12px; }
}

/* ─── Layout ─── */
.mck-form { margin: 0; padding: 0; background: #ffffff; }
.mck-layout { display: grid; min-height: calc(100vh - 200px); }

@media (min-width: 900px) {
  /* ── Shopify-style split: white form (left) + gray summary panel that bleeds to
     the right edge. Gray comes from a gradient on the full-bleed layout, so it always
     reaches the edge and fills full height; content is centered around the divider. ── */
  body.mirai-checkout-page .mck-form {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    padding: 0 !important;
    background: #ffffff;
  }
  .mck-layout {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: linear-gradient(to right, #ffffff 50%, var(--mck-gray-bg) 50%) !important;
  }
  /* FIELDS — left half, content hugs the center divider */
  .mck-fields {
    grid-column: 1 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    align-self: start !important;
    width: 100% !important;
    max-width: 564px !important;
    padding: 48px 56px 96px 24px !important;
    margin: 0 !important;
    background: transparent !important;
    box-sizing: border-box;
    display: block !important;
  }
  .mck-fields > * {
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    box-sizing: border-box;
  }
  /* SUMMARY — right half; gray comes from the layout gradient (bleeds to edge),
     content hugs the center divider and sticks while the form scrolls. */
  .mck-summary {
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: start !important;
    align-self: start !important;
    position: sticky !important;
    top: 0 !important;
    width: 100% !important;
    max-width: 480px !important;
    padding: 48px 24px 96px 56px !important;
    margin: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    box-sizing: border-box;
  }
  .mck-summary__inner {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    background: transparent !important;
    position: static !important;
  }
  .mck-summary__body,
  .mck-summary__items,
  .mck-summary__totals,
  .mck-summary__item { background: transparent !important; }

  .mck-summary__toggle { display: none !important; }
  .mck-summary__body { display: block !important; padding: 0 !important; }
}

@media (max-width: 899px) {
  .mck-layout { display: flex; flex-direction: column; }
  .mck-summary {
    order: -1;
    background: var(--mck-gray-bg) !important;
    padding: 0 !important;
    margin: 0 !important;
    border-bottom: 1px solid var(--mck-border) !important;
    width: 100% !important;
  }
  .mck-summary__inner { background: var(--mck-gray-bg) !important; }
  .mck-summary__toggle { background: transparent !important; }
  .mck-summary.is-open .mck-summary__body { background: var(--mck-gray-bg) !important; }
  .mck-fields {
    padding: 24px 16px 32px !important;
    background: #ffffff !important;
  }
}

/* ─── Summary panel ─── */
.mck-summary__inner { width: 100%; }

/* Neutraliza o CSS padrão do Storefront (#order_review float:right + largura ~35%) que espremia o resumo */
.mck-summary #order_review,
.mck-summary .woocommerce-checkout-review-order {
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
}

/* Toggle (visible always; clickable on mobile) */
.mck-summary__toggle {
  display: flex;
  align-items: center;
  width: 100%;
  background: transparent;
  border: none;
  padding: 16px;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  gap: 6px;
}
.mck-summary__toggle-label {
  font-size: 15px;
  font-weight: 600;
  color: var(--mck-blue);
}
.mck-summary__toggle-chev {
  color: var(--mck-blue);
  flex-shrink: 0;
  transition: transform .2s;
}
.mck-summary.is-open .mck-summary__toggle-chev { transform: rotate(180deg); }
.mck-summary__toggle-total {
  margin-left: auto;
  font-size: 16px;
  font-weight: 700;
  color: var(--mck-text);
}
.mck-summary__toggle-total .amount,
.mck-summary__toggle-total .woocommerce-Price-amount { color: var(--mck-text); font-weight: 700; }
.mck-summary__toggle:hover { background: rgba(0,91,209,0.04); }

/* Summary body */
@media (max-width: 899px) {
  .mck-summary__body { display: none; padding: 0 16px 16px; background: var(--mck-gray-bg); }
  .mck-summary.is-open .mck-summary__body { display: block; }
  .mck-summary.is-open .mck-summary__toggle { border-bottom: 1px solid var(--mck-border); }
}
@media (min-width: 900px) {
  .mck-summary__toggle { cursor: default; padding: 0 0 16px; pointer-events: none; }
  .mck-summary__toggle-label { font-size: 18px; color: var(--mck-text); }
  .mck-summary__toggle-chev { display: none; }
  .mck-summary__body { display: block; }
}

/* Items */
.mck-summary__items {
  border-top: 1px solid var(--mck-border);
  padding-top: 12px;
}
.mck-summary__item {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: 14px;
  padding: 12px 0;
  align-items: start;
}
.mck-summary__thumb {
  position: relative;
  width: 64px;
  height: 64px;
}
.mck-summary__thumb img {
  width: 64px;
  height: 64px;
  border-radius: 8px;
  border: 1px solid var(--mck-border);
  object-fit: cover;
  background: #fff;
}
.mck-summary__qty {
  position: absolute;
  top: -8px; right: -8px;
  background: var(--mck-red);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  min-width: 22px; height: 22px;
  padding: 0 6px;
  border-radius: 11px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--mck-gray-bg);
  box-sizing: border-box;
}
.mck-summary__details { min-width: 0; }
.mck-summary__name {
  font-size: 13px;
  margin: 0 0 4px;
  line-height: 1.4;
  color: var(--mck-text);
  font-weight: 600;
}
.mck-summary__desc {
  font-size: 13px;
  color: var(--mck-text);
  margin: 0 0 4px;
  line-height: 1.55;
  font-weight: 400;
  white-space: normal;
}
.mck-summary__variation { font-size: 12px; color: var(--mck-text-subdued); margin-top: 4px; }
.mck-summary__variation dl,
.mck-summary__variation p { margin: 0; }
.mck-summary__variation dt,
.mck-summary__variation dd { display: inline; margin: 0; font-weight: 400; }
.mck-summary__price {
  font-size: 14px;
  font-weight: 500;
  color: var(--mck-text);
  white-space: nowrap;
}

/* Coupon — Shopify-style: floating label, blue button when active, red error state */
.mck-summary__coupon-wrap {
  padding-top: 14px;
  border-top: 1px solid var(--mck-border);
  margin-top: 8px;
}
.mck-summary__coupon {
  display: flex;
  gap: 8px;
}
.mck-summary__coupon-field {
  flex: 1;
  position: relative;
}
.mck-summary__coupon-field input {
  width: 100%;
  padding: 18px 12px 6px;
  font-size: 14px;
  border: 1px solid var(--mck-border);
  border-radius: var(--mck-radius);
  background: #ffffff;
  color: var(--mck-text);
  height: 48px;
  box-sizing: border-box;
  transition: border-color .15s, box-shadow .15s;
}
.mck-summary__coupon-field input:focus {
  outline: none;
  border-color: var(--mck-blue);
  box-shadow: 0 0 0 1px var(--mck-blue);
}
.mck-summary__coupon-field label {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  color: var(--mck-text-subdued);
  pointer-events: none;
  transition: all .15s ease;
  background: transparent;
  margin: 0;
}
.mck-summary__coupon-field input:focus + label,
.mck-summary__coupon-field input:not(:placeholder-shown) + label {
  top: 9px;
  transform: translateY(0);
  font-size: 11px;
  color: var(--mck-text-subdued);
}

/* Apply button — gray by default, BLUE when input has value */
.mck-summary__coupon-btn {
  padding: 0 22px;
  height: 48px;
  font-size: 14px;
  font-weight: 600;
  background: var(--mck-gray-bg-sub);
  color: var(--mck-text-subdued);
  border: 1px solid var(--mck-border);
  border-radius: var(--mck-radius);
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  flex-shrink: 0;
  font-family: inherit;
}
.mck-summary__coupon-btn:hover:not(:disabled) { background: #dcdcdc; }
.mck-summary__coupon.is-active .mck-summary__coupon-btn,
.mck-summary__coupon-field:has(input:not(:placeholder-shown)) + .mck-summary__coupon-btn {
  background: var(--mck-blue);
  color: #ffffff;
  border-color: var(--mck-blue);
}
.mck-summary__coupon.is-active .mck-summary__coupon-btn:hover,
.mck-summary__coupon-field:has(input:not(:placeholder-shown)) + .mck-summary__coupon-btn:hover {
  background: var(--mck-blue-hover);
  border-color: var(--mck-blue-hover);
}

/* Error state */
.mck-summary__coupon.has-error .mck-summary__coupon-field input {
  border-color: var(--mck-red) !important;
  box-shadow: 0 0 0 1px var(--mck-red) !important;
}
.mck-summary__coupon.has-error .mck-summary__coupon-field label {
  color: var(--mck-red);
}
.mck-summary__coupon-error {
  display: none;
  margin: 8px 0 0;
  font-size: 13px;
  color: var(--mck-red);
  line-height: 1.4;
}
.mck-summary__coupon-error.is-visible { display: block; }

/* Totals */
.mck-summary__totals {
  padding-top: 14px;
  margin-top: 14px;
  border-top: 1px solid var(--mck-border);
}
.mck-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 6px 0;
  font-size: 14px;
  color: var(--mck-text);
}
.mck-summary__row--discount span:last-child { color: var(--mck-green); font-weight: 600; }
.mck-summary__shipping { color: var(--mck-text); font-weight: 400; }

/* Help icon (ⓘ) next to 送料 */
.mck-summary__shipping-label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.mck-summary__help {
  background: transparent;
  border: none;
  padding: 0;
  cursor: help;
  color: var(--mck-text-subdued);
  display: inline-flex;
  align-items: center;
  line-height: 1;
}
.mck-summary__help svg { display: block; }

/* Total row — bigger 合計 + JPY/¥ layout */
.mck-summary__row--total {
  border-top: 1px solid var(--mck-border);
  padding-top: 16px;
  margin-top: 10px;
  align-items: baseline;
}
.mck-summary__total-label {
  font-size: 20px;
  font-weight: 700;
  color: var(--mck-text);
}
.mck-summary__total-value {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
}
.mck-summary__total-value strong {
  font-size: 22px;
  font-weight: 700;
  color: var(--mck-text);
}
.mck-summary__currency {
  font-size: 12px;
  color: var(--mck-text-subdued);
  font-weight: 500;
}

/* ─── Form sections ─── */
.mck-section { margin-bottom: 28px; }
.mck-section__head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 12px; }
.mck-section__title { font-size: 18px; font-weight: 700; color: var(--mck-text); margin: 0; }
.mck-section__sub { font-size: 13px; color: var(--mck-text-subdued); margin: -6px 0 12px; }
.mck-link { font-size: 14px; color: var(--mck-blue); text-decoration: none; }
.mck-link:hover { text-decoration: underline; }

/* ─── Form fields: Shopify-style floating label ─── */
.mck-form .form-row {
  margin: 0 0 12px;
  padding: 0;
  position: relative;
}
.mck-form .form-row .required { display: none; }
.mck-form .form-row label.screen-reader-text {
  position: absolute !important;
  width: 1px; height: 1px;
  margin: -1px; padding: 0;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

/* Visible label = floating label inside the input */
.mck-form .form-row > label:not(.screen-reader-text) {
  display: block !important;
  position: absolute;
  left: 13px;
  top: 8px;
  font-size: 11px;
  font-weight: 400;
  color: var(--mck-text-subdued);
  pointer-events: none;
  z-index: 2;
  margin: 0 !important;
  padding: 0;
  line-height: 1;
  opacity: 0;
  transition: opacity .15s ease;
  background: transparent;
}

/* Show floating label when input is focused or filled */
.mck-form .form-row:has(input.input-text:focus) > label:not(.screen-reader-text),
.mck-form .form-row:has(input.input-text:not(:placeholder-shown)) > label:not(.screen-reader-text),
.mck-form .form-row:has(textarea:focus) > label:not(.screen-reader-text),
.mck-form .form-row:has(textarea:not(:placeholder-shown)) > label:not(.screen-reader-text) {
  opacity: 1;
}

/* Inputs */
.mck-form .woocommerce-input-wrapper { display: block; width: 100%; }
.mck-form .form-row input.input-text,
.mck-form .form-row textarea,
.mck-form .form-row select {
  width: 100%;
  font-size: 16px;
  padding: 14px 12px;
  border: 1px solid var(--mck-border);
  border-radius: var(--mck-radius);
  background: #ffffff;
  color: var(--mck-text);
  font-family: inherit;
  box-sizing: border-box;
  transition: border-color .15s, box-shadow .15s, padding .15s;
  height: 50px;
}
.mck-form .form-row input.input-text::placeholder,
.mck-form .form-row textarea::placeholder { color: var(--mck-text-subdued); opacity: 1; }
.mck-form .form-row input.input-text:focus,
.mck-form .form-row textarea:focus,
.mck-form .form-row select:focus {
  outline: none;
  border-color: var(--mck-blue);
  box-shadow: 0 0 0 1px var(--mck-blue);
}

/* Value stays vertically centered always (no floating label active) */
.mck-form .form-row:has(input.input-text:focus) input.input-text,
.mck-form .form-row:has(input.input-text:not(:placeholder-shown)) input.input-text,
.mck-form .form-row:has(textarea:focus) textarea,
.mck-form .form-row:has(textarea:not(:placeholder-shown)) textarea {
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

/* Filled state — light blue tint background (Shopify-style) */
.mck-form .form-row:has(input.input-text:not(:placeholder-shown)) input.input-text,
.mck-form .form-row:has(textarea:not(:placeholder-shown)) textarea {
  background: var(--mck-blue-tint) !important;
}
.mck-form .form-row:has(input.input-text:not(:placeholder-shown)),
.mck-form .form-row:has(textarea:not(:placeholder-shown)) {
  /* Optional: subtle blue tint can also extend if needed */
}

/* Focus state — stronger BLUE border (2px equivalent via box-shadow) */
.mck-form .form-row input.input-text:focus,
.mck-form .form-row textarea:focus,
.mck-form .form-row select:focus {
  border-color: var(--mck-blue) !important;
  box-shadow: 0 0 0 1.5px var(--mck-blue) !important;
}

/* Error state */
.mck-form .form-row.woocommerce-invalid input.input-text,
.mck-form .form-row.woocommerce-invalid select { border-color: var(--mck-red) !important; }

/* ─── Special: 国/地域 (country) — Select2 always shows floating label (default value: 日本) ─── */
.mck-form #billing_country_field > label:not(.screen-reader-text),
.mck-form #billing_state_field > label:not(.screen-reader-text) {
  opacity: 1 !important; /* always visible for selects */
}
.mck-form #billing_country_field .select2-container,
.mck-form #billing_state_field .select2-container { width: 100% !important; }
.mck-form #billing_country_field .select2-selection--single,
.mck-form #billing_state_field .select2-selection--single {
  height: 50px !important;
  border: 1px solid var(--mck-border) !important;
  border-radius: var(--mck-radius) !important;
  padding: 0 !important;
}
.mck-form #billing_country_field .select2-selection__rendered,
.mck-form #billing_state_field .select2-selection__rendered {
  line-height: 48px !important;
  padding-left: 13px !important;
  font-size: 16px !important;
  color: var(--mck-text) !important;
}
.mck-form #billing_country_field .select2-selection__arrow,
.mck-form #billing_state_field .select2-selection__arrow {
  height: 48px !important;
  right: 4px !important;
  top: 0 !important;
}

/* ─── 郵便番号: lupa (search) icon on the right ─── */
#billing_postcode_field { position: relative; }
#billing_postcode_field::after {
  content: '';
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23707070' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>") no-repeat center;
  background-size: contain;
  pointer-events: none;
}
#billing_postcode_field input { padding-right: 40px !important; }

/* ─── 携帯電話: help icon (?) on the right ─── */
#billing_phone_field { position: relative; }
#billing_phone_field::after {
  content: '';
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23707070' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><path d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'/><circle cx='12' cy='17' r='0.5' fill='%23707070'/></svg>") no-repeat center;
  background-size: contain;
  pointer-events: none;
}
#billing_phone_field input { padding-right: 40px !important; }

/* Section title bigger */
.mck-section__title { font-size: 22px; font-weight: 700; }

/* Side-by-side first/last name on desktop */
@media (min-width: 600px) {
  .mck-form #billing_last_name_field,
  .mck-form #billing_first_name_field {
    display: inline-block !important;
    width: calc(50% - 6px) !important;
    vertical-align: top;
    float: none !important;
  }
  .mck-form #billing_last_name_field { margin-right: 8px; }
  .mck-form #billing_postcode_field,
  .mck-form #billing_state_field {
    display: inline-block !important;
    width: calc(50% - 6px) !important;
    vertical-align: top;
    float: none !important;
  }
  .mck-form #billing_postcode_field { margin-right: 8px; }
}

/* Select2 focus state */
.mck-form .select2-container--default.select2-container--focus .select2-selection--single,
.mck-form .select2-container--default.select2-container--open .select2-selection--single {
  border-color: var(--mck-blue) !important;
  box-shadow: 0 0 0 1px var(--mck-blue) !important;
}

/* Checkbox */
.mck-checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--mck-text);
  cursor: pointer;
  margin: 8px 0 0;
  user-select: none;
}
.mck-checkbox input[type="checkbox"] {
  width: 18px; height: 18px;
  margin: 0;
  accent-color: var(--mck-blue);
}

/* ─── Express payment (Apple Pay / Google Pay) — HIDDEN until wired ─── */
body.mirai-checkout-page .mck-express,
body.mirai-checkout-page .mck-express-divider,
body.mirai-checkout-page #mck-express-payment,
body.mirai-checkout-page #mck-express-buttons {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}
.mck-express__label {
  text-align: center;
  font-size: 13px;
  color: var(--mck-text-subdued);
  margin: 0 0 10px;
  font-weight: 500;
}
#mck-express-buttons { display: grid; gap: 8px; grid-template-columns: 1fr; }
@media (min-width: 600px) { #mck-express-buttons { grid-template-columns: repeat(2, 1fr); } }
#mck-express-buttons:empty { display: none; }
#mck-express-buttons:empty + .mck-express-divider { display: none; }
.mck-express:has(#mck-express-buttons:empty) { display: none; }

.mck-express-divider {
  display: flex;
  align-items: center;
  text-align: center;
  margin: 18px 0;
  font-size: 13px;
  color: var(--mck-text-subdued);
}
.mck-express-divider::before,
.mck-express-divider::after {
  content: '';
  flex: 1;
  border-bottom: 1px solid var(--mck-border);
}
.mck-express-divider::before { margin-right: 12px; }
.mck-express-divider::after { margin-left: 12px; }

/* ─── Shipping methods ─── */
/* Static shipping info card */
.mck-shipping-card {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--mck-blue-tint);
  border: 2px solid var(--mck-blue);
  border-radius: var(--mck-radius);
}
.mck-shipping-card__icon {
  width: 36px; height: 36px;
  background: var(--mck-blue);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mck-shipping-card__icon svg { display: block; }
.mck-shipping-card__body { min-width: 0; }
.mck-shipping-card__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--mck-text);
  margin: 0;
  line-height: 1.2;
}
.mck-shipping-card__sub {
  font-size: 12px;
  color: var(--mck-text-subdued);
  margin: 3px 0 0;
}
.mck-shipping-card__price {
  font-size: 15px;
  font-weight: 700;
  color: var(--mck-text);
}
ul#shipping_method { list-style: none; padding: 0; margin: 0; }
ul#shipping_method li {
  background: #ffffff;
  border: 1px solid var(--mck-border);
  border-radius: var(--mck-radius);
  padding: 14px 14px 14px 44px;
  margin: 0 0 -1px;
  position: relative;
  cursor: pointer;
  font-size: 14px;
}
ul#shipping_method input[type="radio"] {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px; height: 18px;
  margin: 0;
  accent-color: var(--mck-blue);
}

/* ─── Payment methods (Shopify-style: blue tint + white-dot radio) ─── */
body.mirai-checkout-page .mck-payment__list,
body.mirai-checkout-page ul.payment_methods,
body.mirai-checkout-page ul.wc_payment_methods {
  list-style: none !important;
  list-style-type: none !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.mirai-checkout-page .mck-payment__option,
body.mirai-checkout-page li.wc_payment_method,
body.mirai-checkout-page li.payment_method_stripe {
  list-style: none !important;
  list-style-type: none !important;
}
body.mirai-checkout-page .mck-payment__option::marker,
body.mirai-checkout-page li.wc_payment_method::marker { content: '' !important; display: none !important; }
.mck-payment__option {
  background: #ffffff;
  border: 1px solid var(--mck-border);
  margin: 0;
  position: relative;
  overflow: visible;
}
.mck-payment__option:first-child {
  border-top-left-radius: var(--mck-radius);
  border-top-right-radius: var(--mck-radius);
}
.mck-payment__option:last-child {
  border-bottom-left-radius: var(--mck-radius);
  border-bottom-right-radius: var(--mck-radius);
}
.mck-payment__option + .mck-payment__option { border-top: none; }
.mck-payment__option.is-selected {
  background: #ffffff;
  border: 2px solid var(--mck-blue) !important;
  z-index: 2;
  margin-top: -1px;
}
.mck-payment__option.is-selected + .mck-payment__option { border-top: 1px solid var(--mck-border); }

/* Header label — light blue tint ONLY on selected option header (Shopify style) */
.mck-payment__label {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  cursor: pointer;
  font-size: 14px;
  color: var(--mck-text);
  font-weight: 600;
  margin: 0;
  width: 100%;
  box-sizing: border-box;
  background: transparent;
}
.mck-payment__radio-fake { grid-column: 1; }
.mck-payment__name {
  grid-column: 2;
  white-space: nowrap;
  justify-self: start;
}
.mck-payment__brands {
  grid-column: 3;
  justify-self: end;
}
/* Force native radio fully hidden — display:none to beat Storefront/WC custom radio paints */
body.mirai-checkout-page input[type="radio"].mck-payment__radio,
body.mirai-checkout-page .mck-payment__label input[type="radio"],
body.mirai-checkout-page .mck-payment__option input[type="radio"].input-radio,
body.mirai-checkout-page input.input-radio[type="radio"][name="payment_method"],
body.mirai-checkout-page .mck-payment__option input.input-radio {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  opacity: 0 !important;
}
.mck-payment__option.is-selected .mck-payment__label {
  background: var(--mck-blue-tint);
  border-bottom: 1px solid var(--mck-border);
}
.mck-payment__radio { position: absolute; opacity: 0; pointer-events: none; }
/* Fake radio hidden — user removed visual indicator */
body.mirai-checkout-page .mck-payment__radio-fake { display: none !important; }

/* Brands container — already grid-positioned to col 3, just style inner layout */
.mck-payment__brands {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  position: relative;
}
.mck-payment__brand-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.mck-payment__brand {
  width: 38px !important;
  height: 24px !important;
  display: block;
  object-fit: contain;
  border: none;
  background: transparent;
  flex-shrink: 0;
}
/* "+X" subtle badge */
.mck-payment__brand-more {
  background: transparent !important;
  border: none !important;
  padding: 0 4px !important;
  height: 24px;
  font-size: 12px;
  font-weight: 500;
  color: var(--mck-text-subdued) !important;
  cursor: pointer;
  font-family: inherit;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  box-sizing: border-box;
}
.mck-payment__brand-more:hover { color: var(--mck-text) !important; }
.mck-payment__brand-tooltip {
  position: absolute;
  bottom: calc(100% + 12px);
  right: -8px;
  background: #2b2b2b;
  border: none;
  border-radius: 10px;
  padding: 10px;
  display: none;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  z-index: 50;
  width: max-content;
  max-width: 220px;
}
.mck-payment__brand-tooltip.is-open { display: grid; }
.mck-payment__brand-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  right: 16px;
  border: 7px solid transparent;
  border-top-color: #2b2b2b;
}
.mck-payment__brand-tooltip img {
  width: 42px;
  height: 26px;
  object-fit: contain;
  background: #ffffff;
  border-radius: 4px;
  display: block;
  padding: 3px;
  box-sizing: border-box;
}

.mck-payment__box {
  background: var(--mck-gray-bg);
  padding: 16px 0 0;
  font-size: 14px;
  color: var(--mck-text);
  margin: 0;
}
.mck-payment__box .wc-stripe-upe-element,
.mck-payment__box #wc-stripe-upe-form { padding: 0 16px 16px !important; margin: 0 !important; }
.mck-payment__box p { margin: 0 0 10px; }
.mck-payment__box input,
.mck-payment__box select {
  width: 100%;
  padding: 13px 12px;
  font-size: 16px;
  border: 1px solid var(--mck-border);
  border-radius: var(--mck-radius);
  background: #ffffff;
  margin-bottom: 8px;
  box-sizing: border-box;
  height: 50px;
}
.mck-payment__box input:focus,
.mck-payment__box select:focus {
  outline: none;
  border-color: var(--mck-blue);
  box-shadow: 0 0 0 1px var(--mck-blue);
}

/* Hide brand icons inside Stripe Elements card number */
.StripeElement .__PrivateStripeElement iframe + div,
.wc-stripe-elements-field .Brand,
.wc-stripe-card-icons-container,
.wc-stripe-payment-element .Card .Brand { display: none !important; }

/* ─── Discount add link ─── */
.mck-discount-add {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: #ffffff;
  border: 1px solid var(--mck-border);
  border-radius: var(--mck-radius);
  color: var(--mck-text);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  margin: 24px 0 12px;
  font-family: inherit;
}
.mck-discount-add svg { flex-shrink: 0; color: var(--mck-text); }
.mck-discount-add:hover { background: var(--mck-gray-bg); }

/* ─── Mini summary (mobile): bar + inline expandable panel (open by default) ─── */
.mck-mini-summary {
  background: var(--mck-gray-bg);
  border: 1px solid var(--mck-border);
  border-radius: var(--mck-radius);
  margin: 12px 0 16px;
  overflow: hidden;
}
.mck-mini-summary__bar {
  display: grid;
  grid-template-columns: 44px 1fr auto;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  outline: none !important;
  -webkit-tap-highlight-color: transparent;
}
.mck-mini-summary__thumb img {
  width: 44px; height: 44px;
  border-radius: 6px;
  border: 1px solid var(--mck-border);
  object-fit: cover;
  background: #fff;
  display: block;
}
.mck-mini-summary__meta { min-width: 0; }
.mck-mini-summary__label {
  display: block;
  font-size: 15px;
  font-weight: 700;
  color: var(--mck-text);
  line-height: 1.2;
}
.mck-mini-summary__count {
  display: block;
  font-size: 12px;
  color: var(--mck-text-subdued);
  margin-top: 2px;
}
.mck-mini-summary__total {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  color: var(--mck-text);
}
.mck-mini-summary__total small { font-size: 11px; color: var(--mck-text-subdued); font-weight: 500; }
.mck-mini-summary__total strong { font-size: 18px; font-weight: 700; color: var(--mck-text); }
.mck-mini-summary__chev {
  color: var(--mck-text-subdued);
  margin-left: 4px;
  align-self: center;
  transition: transform .2s;
}
.mck-mini-summary.is-open .mck-mini-summary__chev { transform: rotate(180deg); }
.mck-mini-summary__panel {
  display: none;
  padding: 0 14px 14px;
  border-top: 1px solid var(--mck-border);
  background: #ffffff;
}
.mck-mini-summary.is-open .mck-mini-summary__panel { display: block; }
.mck-mini-summary__panel .mck-summary__items { border-top: none; }
/* Desktop: full summary lives in the right column → hide the mini bar */
@media (min-width: 900px) { .mck-mini-summary { display: none; } }
/* Mobile: the mini-summary IS the order summary → hide the top accordion (no duplication) */
@media (max-width: 899px) { .mck-summary { display: none !important; } }

/* ─── Place order button ─── */
.mck-place-order { margin-top: 18px; }
.mck-place-order-btn,
button#place_order {
  background: var(--mck-blue) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: var(--mck-radius) !important;
  padding: 16px 24px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em !important;
  width: 100%;
  min-height: 56px;
  cursor: pointer;
  transition: background .15s;
  font-family: inherit;
  text-shadow: none !important;
  box-shadow: none !important;
}
.mck-place-order-btn:hover,
button#place_order:hover { background: var(--mck-blue-hover) !important; }

/* Terms */
.woocommerce-terms-and-conditions-wrapper {
  font-size: 13px;
  color: var(--mck-text-subdued);
  margin-bottom: 14px;
  line-height: 1.5;
}
.woocommerce-terms-and-conditions-wrapper a { color: var(--mck-blue); }

/* Hide WC privacy policy notice that leaks English text (we have our own terms link) */
.woocommerce-privacy-policy-text { display: none !important; }

/* ─── Notices ─── */
.woocommerce-NoticeGroup,
.woocommerce-notices-wrapper { margin-bottom: 18px; }
.woocommerce-error,
.woocommerce-message,
.woocommerce-info {
  background: var(--mck-blue-tint);
  border: 1px solid var(--mck-blue);
  border-radius: var(--mck-radius);
  padding: 12px 14px;
  font-size: 14px;
  color: var(--mck-text);
  list-style: none;
  margin: 0 0 16px;
}
.woocommerce-error { background: #fce8e6; border-color: var(--mck-red); }

.processing { opacity: 0.6; pointer-events: none; }
.blockUI.blockOverlay { background: rgba(255,255,255,0.7) !important; }

/* ─── THANK YOU PAGE — Shopify-style professional ─── */
.mck-thanks {
  max-width: 720px;
  margin: 0 auto;
  padding: 32px 16px 64px;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--mck-text);
}
.mck-thanks-h2 { font-size: 18px; font-weight: 700; color: var(--mck-text); margin: 0 0 14px; }
.mck-thanks-h3 { font-size: 14px; font-weight: 700; color: var(--mck-text); margin: 0 0 10px; text-transform: uppercase; letter-spacing: 0.04em; }

/* Hero */
.mck-thanks-hero { text-align: center; padding: 24px 0 32px; }
.mck-thanks-hero__icon { width: 64px; height: 64px; margin: 0 auto 18px; }
.mck-thanks-hero__icon svg { width: 100%; height: 100%; display: block; }
.mck-thanks-hero__order { font-size: 13px; color: var(--mck-text-subdued); margin: 0 0 8px; letter-spacing: 0.04em; }
.mck-thanks-hero__title { font-size: 26px; font-weight: 700; color: var(--mck-text); margin: 0 0 12px; line-height: 1.3; }
.mck-thanks-hero__sub { font-size: 14px; color: var(--mck-text-subdued); margin: 0; line-height: 1.6; }
.mck-thanks-hero__sub strong { color: var(--mck-text); font-weight: 600; }
@media (max-width: 600px) {
  .mck-thanks-hero__title { font-size: 22px; }
  .mck-thanks-hero__icon { width: 56px; height: 56px; }
}

/* Timeline */
.mck-thanks-timeline { background: var(--mck-gray-bg); border-radius: var(--mck-radius); padding: 24px; margin-bottom: 24px; }
.mck-thanks-steps { list-style: none; padding: 0; margin: 0; }
.mck-thanks-step { display: grid; grid-template-columns: 24px 1fr; gap: 14px; padding: 10px 0; position: relative; }
.mck-thanks-step:not(:last-child)::after { content: ''; position: absolute; left: 11px; top: 30px; bottom: -10px; width: 2px; background: var(--mck-border); }
.mck-thanks-step--done:not(:last-child)::after { background: #008060; }
.mck-thanks-step__dot { width: 12px; height: 12px; border-radius: 50%; background: #ffffff; border: 2px solid var(--mck-border); margin: 6px auto 0; position: relative; z-index: 1; }
.mck-thanks-step--done .mck-thanks-step__dot { background: #008060; border-color: #008060; }
.mck-thanks-step__title { font-size: 14px; font-weight: 600; color: var(--mck-text); margin: 0; }
.mck-thanks-step__date { font-size: 12px; color: var(--mck-text-subdued); margin: 2px 0 0; }

/* Sections */
.mck-thanks-section { background: #ffffff; border: 1px solid var(--mck-border); border-radius: var(--mck-radius); padding: 20px; margin-bottom: 24px; }

/* Items */
.mck-thanks-items { margin: 0 0 16px; }
.mck-thanks-item { display: grid; grid-template-columns: 64px 1fr auto; gap: 14px; padding: 12px 0; align-items: start; border-bottom: 1px solid var(--mck-border); }
.mck-thanks-item:last-child { border-bottom: none; }
.mck-thanks-item__thumb-wrap { position: relative; width: 64px; height: 64px; }
.mck-thanks-item__thumb,
.mck-thanks-item__thumb-wrap img { width: 64px; height: 64px; border-radius: 6px; border: 1px solid var(--mck-border); object-fit: cover; background: #fff; }
.mck-thanks-item__qty { position: absolute; top: -8px; right: -8px; background: var(--mck-red); color: #fff; font-size: 11px; font-weight: 700; min-width: 22px; height: 22px; padding: 0 6px; border-radius: 11px; display: inline-flex; align-items: center; justify-content: center; border: 1.5px solid #fff; box-sizing: border-box; }
.mck-thanks-item__details { min-width: 0; }
.mck-thanks-item__name { font-size: 14px; font-weight: 600; color: var(--mck-text); margin: 0 0 4px; line-height: 1.4; }
.mck-thanks-item__variation { font-size: 12px; color: var(--mck-text-subdued); margin: 0; }
.mck-thanks-item__price { font-size: 14px; font-weight: 600; color: var(--mck-text); white-space: nowrap; }

/* Totals */
.mck-thanks-totals { border-top: 1px solid var(--mck-border); padding-top: 14px; margin-top: 14px; }
.mck-thanks-row { display: flex; justify-content: space-between; align-items: baseline; padding: 6px 0; font-size: 14px; color: var(--mck-text); }
.mck-thanks-row--discount span:last-child { color: #008060; font-weight: 600; }
.mck-thanks-shipping-free { color: var(--mck-text); font-weight: 500; }
.mck-thanks-row--total { border-top: 1px solid var(--mck-border); padding-top: 14px; margin-top: 8px; font-size: 18px; font-weight: 700; }
.mck-thanks-row--total span:last-child { display: inline-flex; align-items: baseline; gap: 6px; }
.mck-thanks-row--total small { font-size: 12px; color: var(--mck-text-subdued); font-weight: 500; }
.mck-thanks-row--total strong { font-size: 22px; }

/* Grid: address + payment */
.mck-thanks-grid { display: grid; grid-template-columns: 1fr; gap: 16px; margin-bottom: 24px; }
@media (min-width: 600px) { .mck-thanks-grid { grid-template-columns: 1fr 1fr; } }
.mck-thanks-card { background: #ffffff; border: 1px solid var(--mck-border); border-radius: var(--mck-radius); padding: 18px; }
.mck-thanks-address { font-style: normal; font-size: 14px; color: var(--mck-text); line-height: 1.7; }
.mck-thanks-payment { font-size: 14px; color: var(--mck-text); margin: 0; line-height: 1.6; }

/* Trust signals */
.mck-thanks-trust { display: grid; grid-template-columns: 1fr; gap: 14px; background: var(--mck-gray-bg); border-radius: var(--mck-radius); padding: 20px; margin-bottom: 28px; }
@media (min-width: 600px) { .mck-thanks-trust { grid-template-columns: repeat(3, 1fr); } }
.mck-thanks-trust__item { display: flex; align-items: center; gap: 12px; }
.mck-thanks-trust__item svg { color: var(--mck-blue); flex-shrink: 0; }
.mck-thanks-trust__title { font-size: 13px; font-weight: 600; color: var(--mck-text); margin: 0; }
.mck-thanks-trust__sub { font-size: 12px; color: var(--mck-text-subdued); margin: 2px 0 0; }

/* CTA */
.mck-thanks-cta-wrap { text-align: center; margin: 0 0 24px; }
.mck-thanks-btn { display: inline-block; padding: 14px 32px; border-radius: var(--mck-radius); font-size: 15px; font-weight: 600; text-decoration: none; border: 1px solid var(--mck-border); background: #ffffff; color: var(--mck-text); transition: background .15s, border-color .15s; }
.mck-thanks-btn:hover { background: var(--mck-gray-bg); }
.mck-thanks-btn--primary { background: var(--mck-blue); border-color: var(--mck-blue); color: #ffffff; }
.mck-thanks-btn--primary:hover { background: var(--mck-blue-hover); border-color: var(--mck-blue-hover); color: #ffffff; }

/* Support footer */
.mck-thanks-support { text-align: center; font-size: 13px; color: var(--mck-text-subdued); margin: 0; }
.mck-thanks-support a { color: var(--mck-blue); text-decoration: none; }
.mck-thanks-support a:hover { text-decoration: underline; }
.mck-thanks-closing { text-align: center; font-size: 13.5px; line-height: 1.9; color: var(--mck-text); margin: 26px auto 0; max-width: 520px; }
.mck-thanks-trust__sub a { color: var(--mck-blue); text-decoration: none; }
.mck-thanks-trust__sub a:hover { text-decoration: underline; }

/* Payment failed */
.mck-thanks-failed { text-align: center; padding: 40px 16px; }
.mck-thanks-failed h1 { font-size: 24px; color: var(--mck-red); margin: 0 0 12px; }
.mck-thanks-failed p { color: var(--mck-text-subdued); margin: 0 0 16px; }
.mck-thanks-failed__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* Hide WC default order details (we render our own) */
.woocommerce-order .woocommerce-order-overview,
.woocommerce-order .woocommerce-order-details,
.woocommerce-order .woocommerce-customer-details { display: none !important; }

/* Order received container reset */
.woocommerce-order { max-width: 100% !important; margin: 0 !important; padding: 0 !important; }
