body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 500;
}
body::-webkit-scrollbar { display: none; }
*, *::before, *::after { line-height: 1; margin: 0; padding: 0; box-sizing: border-box; }
img { display: block; max-width: 100%; height: auto; }

h1, h2, .alert-text {
  position: absolute; width: 1px; height: 1px; padding: 0;
  overflow: hidden; clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(0 0 99.9% 99.9%);
  clip-path: inset(0 0 99.9% 99.9%); border: 0;
}

section { position: relative; max-width: 750px; margin-left: auto; margin-right: auto; }

html, body { overflow-x: hidden; }

:root {
  --pink:          #e0174a;
  --pink-dark:     #c4003a;
  --pink-light:    #fce8ef;
  --pink-mid:      #fbd0dc;
  --pink-bg:       #fff5f7;
  --gray-line:     #ccc;
  --gray-bg:       #f4f4f4;
  --gray-border:   #e0e0e0;

  --form-accent:       #e0174a;
  --form-required-bg:  #e0174a;
  --form-th-bg:        #fdf2f5;
  --form-border:       #e8e8e8;
  --form-input-border: #c8c8c8;
  --form-input-bg:     #ffffff;
  --form-submit-bg:    #e0174a;
  --form-submit-hover: #c4003a;
  --form-label-color:  #2c2c2c;
}

.plan-list01 { position: absolute; left: 50%; transform: translate(-50%, 0); top: 410px; }
.plan-list { list-style: none; width: 610px; display: grid; grid-template-columns: 1fr 1fr; gap: 25px 22px; letter-spacing: 0.05em; }
.plan-list a { color: #464646; text-decoration: none; display: block; }
.plan-list a:hover { opacity: 0.6; }
.plan-list .plan-item-name { font-weight: bold; font-size: 25px; text-align: center; margin: 8px 0; }
.plan-list .plan-price { display: flex; justify-content: center; gap: 0 15px; align-items: flex-end; }
.plan-list .tax { font-size: 19px; position: relative; top: -3px; }
.plan-list .tax:before { position: absolute; left: 0; bottom: 8px; transform: rotate(-9deg); content: ''; width: 115px; height: 1px; background: #464646; display: block; }
.plan-list .tax span { font-size: 15px; }
.plan-list .no-tax { font-size: 30px; color: #f17676; }

.plan-link-btn-group { position: relative; z-index: 1; max-width: 750px; margin: 0 auto; padding: 0 40px 48px; display: flex; flex-direction: column; gap: 20px; background: #fff; }
.plan-link-btn { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 26px 36px; border-radius: 100px; font-size: 28px; font-weight: 800; font-family: inherit; color: #fff; text-decoration: none; letter-spacing: 0.04em; line-height: 1.4; position: relative; overflow: hidden; border: none; box-sizing: border-box; transition: transform .2s, box-shadow .2s, opacity .2s; -webkit-tap-highlight-color: transparent; }
.plan-link-btn--purple { background: linear-gradient(135deg, #b89ee0 0%, #8b6cc8 40%, #7055b8 100%); box-shadow: 0 8px 28px rgba(112,85,184,.42); }
.plan-link-btn--blue { background: linear-gradient(135deg, #90c4ee 0%, #6aaade 40%, #5090ce 100%); box-shadow: 0 8px 28px rgba(80,144,206,.42); }
.plan-link-btn::before { content: ''; position: absolute; inset: 2px; border-radius: 100px; border: 1.5px solid rgba(255,255,255,.4); pointer-events: none; }
.plan-link-btn::after { content: ''; position: absolute; top: 0; left: -100%; width: 55%; height: 100%; background: linear-gradient(105deg, transparent 20%, rgba(255,255,255,.2) 50%, transparent 80%); animation: planBtnShimmer 3.2s ease-in-out infinite; pointer-events: none; }
.plan-link-btn--blue::after { animation-delay: 1.6s; }
@keyframes planBtnShimmer { 0% { left: -100%; } 45% { left: 140%; } 100% { left: 140%; } }
.plan-link-btn__arrow { font-size: 28px; flex-shrink: 0; margin-left: 16px; display: inline-block; transition: transform .25s ease; }
.plan-link-btn:hover { transform: translateY(-3px); opacity: .92; }
.plan-link-btn:hover .plan-link-btn__arrow { transform: translateX(6px); }
.plan-link-btn:active { transform: scale(.97); opacity: .85; transition: transform .08s; }

#faq { background: #C4C4FA; padding-bottom: 100px; }
#faq img { margin: 0 auto; width: 100%; max-width: 750px; }

#legal-info { background: #f7f7f7; padding: 30px 0; border-top: 1px solid #ddd; }
#legal-info .legal-inner { width: 90%; max-width: 960px; margin: 0 auto; font-size: 12px; color: #444; line-height: 1.7; }
#legal-info h3 { font-size: 14px; font-weight: bold; margin: 20px 0 10px; }
#legal-info ul { margin: 0 0 20px; padding-left: 1.2em; }
#legal-info li { margin-bottom: 8px; }

.plan-section { width: 100%; max-width: 750px; margin: 0 auto; background-color: var(--pink-light); background-image: linear-gradient(rgba(220,160,180,.22) 1px, transparent 1px), linear-gradient(90deg, rgba(220,160,180,.22) 1px, transparent 1px); background-size: 28px 28px; overflow: hidden; padding-bottom: 52px; position: relative; z-index: 1; }
#main-section { margin-top: 16px; }
.top-banner { display: flex; align-items: stretch; min-height: 72px; }
.top-banner-left { background: var(--pink); color: #fff; font-size: 26px; font-weight: 900; line-height: 1.25; display: flex; align-items: center; justify-content: center; padding: 10px 22px; text-align: center; min-width: 148px; }
.top-banner-right { background: var(--pink-mid); flex: 1; display: flex; align-items: center; justify-content: center; padding: 10px 28px; font-size: 30px; font-weight: 900; color: #222; }
.section-title { text-align: center; margin: 40px 0 32px; padding: 0 32px; }
.section-title h2 { font-size: 44px !important; font-weight: 900; color: var(--pink); text-decoration: underline; text-underline-offset: 8px; text-decoration-thickness: 2px; display: inline-block; position: static !important; width: auto !important; height: auto !important; clip: auto !important; -webkit-clip-path: none !important; clip-path: none !important; overflow: visible !important; }
.block { padding: 0 44px; margin-bottom: 28px; }
.block-label { font-size: 26px; font-weight: 700; color: #333; margin-bottom: 16px; }
.notes { padding: 0 44px; margin-top: 32px; }
.notes p { font-size: 22px; color: #444; line-height: 1.7; }

.capacity-track { display: flex; justify-content: center; gap: 18px; position: relative; }
.capacity-pill { display: none; }
.capacity-btn { flex: 1; min-width: 0; text-align: center; padding: 12px 8px; border-radius: 50px; font-size: 28px; font-weight: 700; font-family: inherit; cursor: pointer; border: 2px solid #999; background: #fff; color: #333; position: relative; z-index: 1; user-select: none; -webkit-tap-highlight-color: transparent; }
.capacity-btn.selected { background: var(--pink); color: #fff; border-color: var(--pink); box-shadow: 0 4px 16px rgba(224,23,74,.35); }
.capacity-btn:active { transform: scale(.93); }

.plan-buttons { display: flex; flex-direction: column; gap: 16px; }
.plan-btn { width: 100%; padding: 26px 30px; border-radius: 14px; font-size: 30px; font-weight: 700; font-family: inherit; cursor: pointer; border: 2px solid var(--gray-line); background: var(--gray-bg); color: #333; text-align: left; position: relative; overflow: hidden; transition: border-color .2s, color .2s, background .2s, opacity .2s, box-shadow .2s; user-select: none; -webkit-tap-highlight-color: transparent; }
.plan-btn.dimmed { opacity: .5; }
.plan-btn.selected { background: #fff; border: 2.5px solid var(--pink); color: var(--pink); opacity: 1; box-shadow: 0 4px 20px rgba(224,23,74,.15); }
.plan-btn:active { transform: scale(.98); transition: transform .08s; }
.plan-btn .lens-sweep { display: none; }

.check-mark { position: absolute; right: 20px; top: 50%; transform: translateY(-50%); width: 34px; height: 34px; border-radius: 50%; background: var(--pink); display: flex; align-items: center; justify-content: center; scale: 0; transition: scale .25s cubic-bezier(.34,1.56,.64,1); }
.check-mark svg { width: 18px; height: 18px; fill: none; stroke: #fff; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 24; stroke-dashoffset: 24; }
.plan-btn.selected .check-mark { scale: 1; }
.plan-btn.selected .check-mark svg { stroke-dashoffset: 0; transition: stroke-dashoffset .25s .05s ease-out; }

.plan-select-toast { display: none; margin-top: 16px; padding: 14px 20px; background: #fff5f7; border: 1.5px solid var(--pink); border-radius: 10px; font-size: 24px; font-weight: 700; color: var(--pink); text-align: center; animation: toastFadeIn .25s ease; }
.plan-select-toast.visible { display: block; }
@keyframes toastFadeIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
@keyframes planShake { 0%, 100% { transform: translateX(0); } 20% { transform: translateX(-6px); } 40% { transform: translateX(6px); } 60% { transform: translateX(-4px); } 80% { transform: translateX(4px); } }
.plan-btn.shake { animation: planShake .4s ease; }

.price-slot-wrap { overflow: hidden; height: 52px; display: flex; align-items: center; position: relative; }
.price-slot { font-size: 40px; font-weight: 900; color: #222; letter-spacing: -0.02em; display: inline-block; transition: opacity .15s ease; }
.price-flash { display: none; }

.purchase-popup {
  position: fixed; bottom: 0; left: 50%;
  transform: translateX(-50%) translateY(110%);
  width: 100%; max-width: 750px;
  background: #fff; border-radius: 28px 28px 0 0;
  box-shadow: 0 -4px 24px rgba(0,0,0,.12);
  padding: 24px 36px 38px; z-index: 1002;
  transition: transform .3s ease-out, opacity .2s ease-out;
  opacity: 0; pointer-events: none;
  will-change: opacity; touch-action: pan-y;
}
.purchase-popup.visible {
  transform: translateX(-50%) translateY(0);
  opacity: 1; pointer-events: auto;
  animation: popupFadeIn .25s ease-out both;
  transition: none;
}
@keyframes popupFadeIn { from { opacity: 0; } to { opacity: 1; } }
.popup-glow-line, .popup-scan { display: none; }
.popup-handle { width: 60px; height: 5px; background: #ddd; border-radius: 3px; margin: 0 auto 22px; cursor: grab; }
.purchase-popup.dragging { transition: none; }
.popup-price-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 22px; }
.popup-price-label { font-size: 28px; font-weight: 700; color: #333; }
.popup-cta { width: 100%; padding: 30px 36px; border-radius: 50px; border: none; cursor: pointer; font-size: 34px; font-weight: 900; font-family: inherit; letter-spacing: 0.04em; color: #fff; background: linear-gradient(135deg, #f46b8b 0%, #e8254f 50%, #d01040 100%); box-shadow: 0 6px 24px rgba(224,23,74,.38); display: flex; align-items: center; justify-content: center; gap: 20px; position: relative; transition: box-shadow .2s, transform .15s, opacity .15s; -webkit-tap-highlight-color: transparent; box-sizing: border-box; }
.popup-cta:hover { opacity: .92; transform: translateY(-2px); }
.popup-cta:active { transform: scale(.96) !important; opacity: .88; }
.cta-arrow { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,.28); font-size: 20px; flex-shrink: 0; }
.ripple { position: absolute; border-radius: 50%; transform: scale(0); animation: rippleAnim .5s ease-out forwards; pointer-events: none; }
@keyframes rippleAnim { to { transform: scale(4.5); opacity: 0; } }
.popup-overlay { position: fixed; inset: 0; z-index: 999; background: transparent; pointer-events: none; display: none; }
.popup-overlay.active { display: block; pointer-events: auto; }

.lp-form-section-outer {
  width: 100%; max-width: 750px; margin: 0 auto;
  background: #fff;
  padding: 0 0 60px;
  font-family: "Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","Meiryo",-apple-system,sans-serif;
}
.lp-form-section-title {
  font-size: 18px; font-weight: 900; color: #1a1a1a;
  text-align: center; padding: 32px 20px 26px; position: relative; margin: 0;
}
.lp-form-section-title::after {
  content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 56px; height: 3px; background: var(--form-accent); border-radius: 2px;
}

.form_container_ec,
.form_container_sp_ec,
.form_main_container_ec,
.form_main_container_sp_ec {
  background: #fff !important;
  font-family: "Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","Meiryo",-apple-system,sans-serif;
  max-width: 750px;
  margin: 0 auto;
  padding: 0 !important;
}

form#new-view,
form#login-view,
form.form_main_container_ec,
form.form_main_container_sp_ec {
  background: #fff !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
  padding: 0 !important;
  margin: 0 !important;
}

.landing_form_label_ec,
.landing_form_label_sp_ec,
h3.landing_form_label_ec,
h4.landing_form_label_ec,
h3.landing_form_label_sp_ec,
h4.landing_form_label_sp_ec {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  max-width: 700px !important;
  margin: 0 auto !important;
  background: var(--form-accent) !important;
  color: #fff !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  padding: 26px 32px !important;
  letter-spacing: 0.04em !important;
  line-height: 1.4 !important;
  border-radius: 0 !important;
  text-align: center !important;
  box-sizing: border-box !important;
}
.landing_form_label_ec::before,
.landing_form_label_sp_ec::before { display: none !important; }

.purchase_message_ec,
.purchase_message_sp_ec {
  max-width: 700px !important;
  margin: 0 auto !important;
  padding: 18px 24px !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  color: #444 !important;
  background: #fff !important;
  border-bottom: none !important;
  text-align: center !important;
  box-sizing: border-box !important;
}
.purchase_message_ec p,
.purchase_message_sp_ec p {
  margin: 0 !important;
  text-align: center !important;
}

table.landing_form_ec,
table.landing_form_sp_ec,
#lp-form table.landing_form_ec,
#lp-form table.landing_form_sp_ec {
  display: table !important;
  width: 100% !important;
  max-width: 700px !important;
  margin: 0 auto !important;
  border-collapse: collapse !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  background: #fff !important;
  border: none !important;
  box-shadow: none !important;
}
table.landing_form_ec tbody,
table.landing_form_sp_ec tbody {
  display: table-row-group !important;
  background: #fff !important;
}
table.landing_form_ec tr,
table.landing_form_sp_ec tr {
  display: table-row !important;
  border: none !important;
  border-bottom: 1px solid var(--form-border) !important;
  background: #fff !important;
}
table.landing_form_ec tr:last-child,
table.landing_form_sp_ec tr:last-child { border-bottom: none !important; }

table.landing_form_ec th,
table.landing_form_sp_ec th {
  display: table-cell !important;
  width: 260px !important;
  min-width: 260px !important;
  max-width: 260px !important;
  padding: 24px 20px !important;
  background: var(--form-th-bg) !important;
  border: none !important;
  border-right: none !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--form-label-color) !important;
  vertical-align: middle !important;
  text-align: left !important;
  line-height: 1.5 !important;
  word-break: break-word !important;
  overflow-wrap: break-word !important;
  white-space: normal !important;
  box-sizing: border-box !important;
}

table.landing_form_ec th .form_box_label_ec,
table.landing_form_sp_ec th .form_box_label_ec,
table.landing_form_ec th .form_box_label_sp_ec,
table.landing_form_sp_ec th .form_box_label_sp_ec {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: inherit !important;
  line-height: inherit !important;
  flex-wrap: wrap !important;
}
table.landing_form_ec th .form_box_label_ec strong,
table.landing_form_ec th strong,
table.landing_form_sp_ec th .form_box_label_ec strong,
table.landing_form_sp_ec th .form_box_label_sp_ec strong,
table.landing_form_sp_ec th strong {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--form-label-color) !important;
  line-height: 1.4 !important;
  flex: 0 1 auto !important;
  word-break: break-word !important;
  overflow-wrap: break-word !important;
  white-space: normal !important;
  max-width: 100% !important;
}

table.landing_form_ec td,
table.landing_form_sp_ec td {
  display: table-cell !important;
  padding: 20px 20px !important;
  background: #fff !important;
  vertical-align: middle !important;
  border: none !important;
  box-sizing: border-box !important;
}

span.form_required_ec,
span.form_required_sp_ec,
.form_required_ec,
.form_required_sp_ec {
  display: inline-block !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  background: var(--form-required-bg) !important;
  color: #fff !important;
  padding: 4px 10px !important;
  border-radius: 3px !important;
  margin: 0 !important;
  vertical-align: middle !important;
  line-height: 1.4 !important;
  flex-shrink: 0 !important;
  letter-spacing: 0.05em !important;
}

table.landing_form_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
table.landing_form_ec select,
table.landing_form_sp_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
table.landing_form_sp_ec select,
.form_container_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
.form_container_ec select,
.form_container_sp_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
.form_container_sp_ec select,
.form_main_container_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
.form_main_container_ec select,
.form_main_container_sp_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
.form_main_container_sp_ec select,
#lp-form input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
#lp-form select {
  width: 100% !important;
  height: 52px !important;
  min-height: 52px !important;
  max-height: 52px !important;
  padding: 0 14px !important;
  font-size: 16px !important;
  font-family: inherit !important;
  color: #1a1a1a !important;
  background: #ffffff !important;
  border: 1px solid var(--form-input-border) !important;
  border-radius: 4px !important;
  line-height: 50px !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  outline: none !important;
  text-indent: 0 !important;
  box-shadow: none !important;
  vertical-align: middle !important;
  transition: border-color .15s, box-shadow .15s;
}

@media screen and (max-width: 750px) {
  #lp-form input,
  #lp-form select,
  #lp-form textarea {
    font-size: 16px !important;
  }
}

table.landing_form_ec textarea,
.form_container_ec textarea,
.form_main_container_ec textarea,
#lp-form textarea {
  width: 100% !important;
  min-height: 120px !important;
  padding: 14px !important;
  font-size: 14px !important;
  font-family: inherit !important;
  color: #1a1a1a !important;
  background: #ffffff !important;
  border: 1px solid var(--form-input-border) !important;
  border-radius: 4px !important;
  line-height: 1.6 !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  outline: none !important;
  text-indent: 0 !important;
  box-shadow: none !important;
  resize: vertical !important;
  transition: border-color .15s, box-shadow .15s;
}

table.landing_form_ec input:focus,
table.landing_form_ec select:focus,
table.landing_form_ec textarea:focus,
.form_container_ec input:focus,
.form_container_ec select:focus,
.form_container_ec textarea:focus,
.form_main_container_ec input:focus,
.form_main_container_ec select:focus,
.form_main_container_ec textarea:focus,
#lp-form input:focus,
#lp-form select:focus,
#lp-form textarea:focus {
  border: 1px solid var(--pink) !important;
  box-shadow: 0 0 0 2px rgba(224,23,74,.12) !important;
}

.form_container_ec input::placeholder,
.form_container_ec textarea::placeholder,
.form_main_container_ec input::placeholder,
.form_main_container_ec textarea::placeholder { color: #bbb !important; }

table.landing_form_ec select,
.form_container_ec select,
.form_main_container_ec select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23e0174a' d='M6 8L0 0h12z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  padding-right: 36px !important;
  cursor: pointer !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 50px !important;
}

table.landing_form_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
.form_container_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
.form_main_container_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
#lp-form input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]) {
  padding: 0 14px !important;
  line-height: 50px !important;
}

.form_container_ec input[type="checkbox"],
.form_container_ec input[type="radio"],
.form_main_container_ec input[type="checkbox"],
.form_main_container_ec input[type="radio"],
.agreement_view_ec input[type="checkbox"],
.agreement_view_sp_ec input[type="checkbox"],
.login_message_box_ec input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin-right: 6px !important;
  vertical-align: middle !important;
  cursor: pointer !important;
  accent-color: var(--pink) !important;
  flex-shrink: 0 !important;
}

.form_container_ec a,
.form_main_container_ec a,
.agreement_view_ec a,
.agreement_view_sp_ec a {
  color: var(--pink) !important;
  text-decoration: underline !important;
}

table.landing_form_ec tr.input_variant_ec td,
tr.input_variant_ec td {
  padding: 20px 20px !important;
}
table.landing_form_ec tr.input_variant_ec td > #product_container,
tr.input_variant_ec td > #product_container,
#product_container {
  padding: 0 !important;
  margin: 0 0 0 48px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: nowrap !important;
  width: calc(100% - 48px) !important;
  max-width: calc(100% - 48px) !important;
  box-sizing: border-box !important;
}
tr.input_variant_ec select,
tr.input_variant_ec input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]) {
  flex: 1 1 auto !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: block !important;
}
tr.input_variant_ec select[name*="quantity"],
tr.input_variant_ec select[name*="amount"],
#product_container select[name*="quantity"],
#product_container select[name*="amount"],
#product_container select:last-of-type:not(:only-of-type),
#product_container select:nth-of-type(2) {
  flex: 0 0 90px !important;
  width: 90px !important;
  max-width: 90px !important;
  min-width: 90px !important;
}
tr.input_variant_ec > td > select:not(#product_container select),
tr.input_variant_ec > td > input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]):not(#product_container input) {
  margin-left: 48px !important;
  max-width: calc(100% - 48px) !important;
}

tr.input_name_ec .form_group_ec,
tr.input_kana_ec .form_group_ec {
  display: flex !important;
  flex-direction: row !important;
  gap: 16px !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
}
tr.input_name_ec .form_group_ec .col-12,
tr.input_kana_ec .form_group_ec .col-12 {
  flex: 1 1 50% !important;
  min-width: 0 !important;
  width: auto !important;
  max-width: 50% !important;
  padding: 0 !important;
  margin: 0 !important;
}
tr.input_name_ec .form_group_ec .col-12 > p,
tr.input_kana_ec .form_group_ec .col-12 > p {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 !important;
  width: 100% !important;
}
tr.input_name_ec .form_group_ec label,
tr.input_kana_ec .form_group_ec label {
  flex: 0 0 auto !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #333 !important;
  white-space: nowrap !important;
  margin: 0 !important;
  min-width: 0 !important;
}
tr.input_name_ec .form_group_ec input,
tr.input_kana_ec .form_group_ec input,
tr.input_name_ec .form_group_ec .col-12 input,
tr.input_kana_ec .form_group_ec .col-12 input,
tr.input_name_ec .form_group_ec .col-12 > p input,
tr.input_kana_ec .form_group_ec .col-12 > p input {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
}

tr.input_zip_ec td .form_group_ec,
tr.input_postal_ec td .form_group_ec,
tr.input_zip_ec td .form_group_ec > p,
tr.input_postal_ec td .form_group_ec > p {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
  justify-content: flex-start !important;
}
tr.input_zip_ec td .form_group_ec label,
tr.input_postal_ec td .form_group_ec label {
  flex: 0 0 auto !important;
  font-size: 15px !important;
  color: #555 !important;
  margin: 0 !important;
  min-width: 16px !important;
  line-height: 1 !important;
}
input.input_box_zip_ec,
input[name*="[zip01]"],
input[name*="[zip02]"],
input[name*="zip01"],
input[name*="zip02"],
input#order_billing_address_attributes_zip01,
input#order_shipping_address_attributes_zip01 {
  letter-spacing: 0.05em !important;
  flex: 0 0 auto !important;
}
input.input_box_zip_ec[name*="[zip01]"],
input[name="order[billing_address_attributes][zip01]"],
input[name="order[shipping_address_attributes][zip01]"],
input#order_billing_address_attributes_zip01,
input#order_shipping_address_attributes_zip01,
tr.input_zip_ec td input.input_box_zip_ec[name*="[zip01]"],
tr.input_postal_ec td input.input_box_zip_ec[name*="[zip01]"] {
  width: 110px !important;
  max-width: 110px !important;
  min-width: 110px !important;
  flex: 0 0 110px !important;
  flex-grow: 0 !important;
  flex-shrink: 0 !important;
  flex-basis: 110px !important;
}
input.input_box_zip_ec[name*="[zip02]"],
input[name="order[billing_address_attributes][zip02]"],
input[name="order[shipping_address_attributes][zip02]"],
tr.input_zip_ec td input.input_box_zip_ec[name*="[zip02]"],
tr.input_postal_ec td input.input_box_zip_ec[name*="[zip02]"],
tr.input_zip_ec td input[name*="[zip02]"],
tr.input_postal_ec td input[name*="[zip02]"] {
  width: 130px !important;
  max-width: 130px !important;
  min-width: 130px !important;
  flex: 0 0 130px !important;
  flex-grow: 0 !important;
  flex-shrink: 0 !important;
  flex-basis: 130px !important;
}

.lp-tel-hidden .input_box_tel1_ec,
.lp-tel-hidden .input_box_tel2_ec,
.lp-tel-hidden .input_box_tel3_ec,
.lp-tel-hidden input[name*="tel01"],
.lp-tel-hidden input[name*="tel02"],
.lp-tel-hidden input[name*="tel03"],
.lp-tel-hidden br,
.lp-tel-hidden span:empty,
.lp-tel-hidden > p > span {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}
.lp-tel-unified {
  display: block !important;
  width: 70% !important;
  max-width: 70% !important;
  min-width: 240px !important;
  height: 52px !important;
  min-height: 52px !important;
  padding: 0 14px !important;
  font-size: 14px !important;
  font-family: inherit !important;
  color: #1a1a1a !important;
  background: #ffffff !important;
  background-color: #ffffff !important;
  border: 1px solid #c8c8c8 !important;
  border-radius: 4px !important;
  line-height: 50px !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  outline: none !important;
  letter-spacing: 0.05em !important;
}
.lp-tel-unified:focus {
  border: 1px solid #e0174a !important;
  box-shadow: 0 0 0 2px rgba(224, 23, 74, 0.12) !important;
}
.lp-tel-unified.inputError {
  border: 2px solid #e0174a !important;
  background: #fff0f4 !important;
  background-color: #fff0f4 !important;
  box-shadow: 0 0 0 2px rgba(224, 23, 74, 0.15) !important;
  animation: inputErrorFlash .4s ease !important;
}

tr.input_zip_ec .form_group_ec br,
tr.input_postal_ec .form_group_ec br,
tr.input_tel_ec .form_group_ec br {
  display: none !important;
}

tr[class*="customer_number"],
tr[class*="customer_no"],
tr.input_customer_number_ec,
tr.input_customer_no_ec,
div[class*="customer_number"],
div[class*="customer_no"],
.input_customer_number_ec,
.input_customer_number_sp_ec,
.input_customer_no_ec,
.input_customer_no_sp_ec,
tr:has(input[name*="customer_number"]),
tr:has(input[name*="customer_no"]),
input[name*="customer_number"],
input[name*="customer_no"],
.input_customer_number_ec + p,
.input_customer_no_ec + p {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
}

tr.input_tel_ec td .form_group_ec {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}
.input_box_tel_ec,
input.input_box_tel_ec,
input.input_box_tel_ec.input_required_ec,
input[name="order[billing_address_attributes][tel01]"],
input[name="order[shipping_address_attributes][tel01]"],
input[name*="[tel01]"],
input[name*="tel01"]:not(.input_box_tel1_ec):not(.input_box_tel2_ec):not(.input_box_tel3_ec),
tr.input_tel_ec td input.input_box_tel_ec,
tr.input_tel_ec td input.input_required_ec,
tr.input_tel_ec td input[name*="tel01"] {
  width: 70% !important;
  max-width: 70% !important;
  min-width: 240px !important;
  flex: 1 1 70% !important;
  letter-spacing: 0.05em !important;
}

.input_box_pref_ec,
select[name*="prefecture_id"] {
  width: 240px !important;
  max-width: 240px !important;
}

tr.input_addr01_ec input,
tr.input_addr02_ec input,
tr.input_card_name_ec input,
tr.input_email_ec input,
tr.input_password_ec input,
.input_box_addr1_ec,
.input_box_addr2_ec,
.input_box_card_name_ec,
.input_box_email_ec,
.input_box_password_ec {
  width: 100% !important;
  max-width: 100% !important;
}

tr.input_card_expiration_ec td,
tr.input_card_expire_ec td,
tr.input_card_expiration_ec .form_group_ec,
tr.input_card_expire_ec .form_group_ec {
  display: block !important;
}
tr.input_card_expiration_ec .form_group_ec p,
tr.input_card_expire_ec .form_group_ec p {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 !important;
  flex-wrap: wrap !important;
}
tr.input_card_expiration_ec select,
tr.input_card_expire_ec select {
  width: 90px !important;
  max-width: 90px !important;
  flex: none !important;
}
tr.input_card_expiration_ec .form_group_ec p span,
tr.input_card_expire_ec .form_group_ec p span {
  flex-shrink: 0 !important;
  font-size: 14px !important;
  color: #555 !important;
}
tr.input_card_expiration_ec .caution_ec,
tr.input_card_expire_ec .caution_ec {
  margin-top: 8px !important;
  font-size: 12px !important;
  color: #777 !important;
}

.input_box_card_cvv_ec,
input[id*="cvv"] {
  width: 140px !important;
  max-width: 140px !important;
}

.input_box_card_number_ec {
  width: 100% !important;
  letter-spacing: 0.1em !important;
}

#container_payment_schedule select,
#container_delivery_schedule_by_date select,
#container_delivery_schedule_by_term select,
#container_delivery_schedule_by_day_of_week select {
  width: auto !important;
  min-width: 120px !important;
  display: inline-block !important;
  margin: 4px !important;
}

.caution_ec,
td > .caution_ec,
td p.caution_ec {
  margin-top: 8px !important;
  font-size: 12px !important;
  color: #888 !important;
  line-height: 1.6 !important;
}
.caution_ec ul {
  padding-left: 20px !important;
  margin: 8px 0 !important;
}
.caution_ec li {
  font-size: 12px !important;
  line-height: 1.6 !important;
  color: #666 !important;
  margin-bottom: 4px !important;
}
.caution_ec img {
  max-width: 100% !important;
  margin-top: 8px !important;
}

.submit_ec {
  max-width: 700px !important;
  margin: 0 auto !important;
  text-align: center !important;
  padding: 40px 20px !important;
  background: #fff !important;
  box-sizing: border-box !important;
}
.submit_ec center { display: block !important; }

input.submit_button_complete_ec,
button.submit_button_complete_ec,
input[type="submit"].submit_button_complete_ec,
.submit_ec input[type="submit"],
.submit_ec button[type="submit"],
.submit_ec center input[type="submit"],
form input[type="submit"][value*="ご注文"],
form input[type="submit"][value*="申し込"],
form input[type="submit"][value*="お申し込"] {
  display: inline-block !important;
  width: auto !important;
  min-width: 380px !important;
  max-width: 90% !important;
  padding: 24px 48px !important;
  background: linear-gradient(180deg, #ef4477 0%, var(--pink) 50%, #c10d3d 100%) !important;
  color: #fff !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  font-family: inherit !important;
  border: none !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  text-align: center !important;
  box-shadow: 0 6px 20px rgba(224,23,74,.35) !important;
  transition: box-shadow .15s, transform .15s, opacity .15s !important;
  letter-spacing: 0.08em !important;
  box-sizing: border-box !important;
  min-height: auto !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  text-indent: 0 !important;
  line-height: 1.3 !important;
}
input.submit_button_complete_ec:hover,
.submit_ec input[type="submit"]:hover,
.submit_ec button[type="submit"]:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(224,23,74,.45) !important;
  opacity: .95 !important;
}
input.submit_button_complete_ec:active,
.submit_ec input[type="submit"]:active {
  transform: scale(.98) !important;
}

input.login_button_ec,
.lp_login_form_btn {
  display: inline-block !important;
  width: auto !important;
  min-width: 200px !important;
  padding: 14px 32px !important;
  background: var(--form-accent) !important;
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  border: none !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
}

.agreement_view_ec,
.agreement_view_sp_ec {
  max-width: 700px !important;
  margin: 0 auto !important;
  padding: 28px 24px !important;
  background: #fff !important;
  border: none !important;
  border-top: 1px solid var(--form-border) !important;
  text-align: center !important;
  box-sizing: border-box !important;
}
.agreement_view_ec > input[type="checkbox"],
.agreement_view_sp_ec > input[type="checkbox"] {
  display: inline-block !important;
  vertical-align: middle !important;
  margin: 0 8px 0 0 !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  float: none !important;
}
.agreement_view_ec > label,
.agreement_view_sp_ec > label {
  display: inline !important;
  font-size: 13px !important;
  line-height: 1.8 !important;
  color: #333 !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  float: none !important;
  width: auto !important;
  cursor: pointer !important;
}
.agreement_view_ec a,
.agreement_view_sp_ec a,
.agreement_view_ec > label > a {
  color: var(--pink) !important;
  text-decoration: underline !important;
  white-space: nowrap !important;
  display: inline !important;
  font-weight: 600 !important;
}

.login_message_box_ec,
.login_message_box_sp_ec {
  margin: 24px auto !important;
  max-width: 700px !important;
  padding: 20px 24px !important;
  border: 1px solid var(--form-border) !important;
  border-radius: 6px !important;
  background: #fafafa !important;
  text-align: center !important;
}
.login_message_wrapper_ec {
  margin: 0 !important;
  font-size: 15px !important;
}
.login_message_wrapper_ec label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  cursor: pointer !important;
  color: #333 !important;
  font-size: 15px !important;
}

.login_message_ec { padding: 20px 24px !important; }
.login_message_ec p { font-size: 14px !important; color: #555 !important; margin-bottom: 16px !important; }

#AmazonPayOneClickOrderArea {
  margin: 0 auto 24px !important;
  padding: 0 !important;
  max-width: 700px !important;
  box-sizing: border-box !important;
}
.amazon_pay_box_ec,
.amazon_pay_box_sp_ec {
  padding: 24px 20px !important;
  margin: 0 auto !important;
  max-width: 700px !important;
  border: 1px solid var(--form-border) !important;
  border-radius: 8px !important;
  background: #fff !important;
  text-align: center !important;
  box-sizing: border-box !important;
}
.amazon_pay_title_ec,
.amazon_pay_title_sp_ec {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--pink) !important;
  margin-bottom: 16px !important;
  text-align: center !important;
}
.amazon_pay_button_wrapper_ec,
.amazon_pay_button_wrapper_sp_ec {
  margin: 0 auto 16px !important;
  text-align: center !important;
}
.amazon_pay_message_ec,
.amazon_pay_message_sp_ec {
  font-size: 13px !important;
  color: #555 !important;
  line-height: 1.7 !important;
  font-weight: 700 !important;
  text-align: center !important;
}

.lp-sync-banner {
  display: none;
  margin: 0 auto 16px;
  max-width: 700px;
  padding: 12px 20px;
  background: #fff0f4;
  border: 1px solid var(--pink-mid);
  border-radius: 4px;
  font-size: 14px; font-weight: 700; color: var(--pink);
  line-height: 1.5;
  text-align: center;
}
.lp-sync-banner.visible { display: block; }

.lp-notes-outer {
  margin: 24px auto 0;
  max-width: 700px;
  padding: 16px 20px;
  background: #f8f9fb;
  border-radius: 4px;
  border: 1px solid var(--form-border);
}
.lp-notes-outer p {
  font-size: 12px; color: #777; line-height: 1.9;
  margin-bottom: 4px;
  padding-left: 1.4em !important;
  position: relative;
}
.lp-notes-outer p::before {
  content: '※';
  position: absolute;
  left: 0 !important; top: 0 !important;
  color: #555; font-weight: 700;
}

.lp-debug {
  max-width: 750px; margin: 8px auto;
  background: #111; color: #0f0;
  font-family: monospace; font-size: 12px;
  padding: 12px 16px; border-radius: 6px; line-height: 1.9;
}

tr.input_password_ec td:has(input[type="password"])::after,
tr[class*="password"] td:has(input[type="password"])::after {
  content: '【パスワード設定ルール】 半角英数字8文字以上 ／ 数字を必ず1文字以上含む ／ メールアドレスと同じパスワードは使用不可';
  display: block;
  font-size: 12px; color: #888;
  margin-top: 8px; line-height: 1.6;
}

.formError,
div.formError,
body > .formError,
body > div.formError {
  display: block !important;
  visibility: visible !important;
  position: absolute !important;
  z-index: 99999 !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  opacity: 1 !important;
  overflow: visible !important;
  pointer-events: none !important;
  cursor: default !important;
}

.formError .formErrorContent,
div.formError .formErrorContent,
body > .formError .formErrorContent {
  display: block !important;
  visibility: visible !important;
  position: relative !important;
  background: rgba(224, 23, 74, 0.5) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 8px 14px !important;
  margin: 0 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1.5 !important;
  letter-spacing: 0.02em !important;
  box-shadow: 0 4px 16px rgba(224, 23, 74, 0.2) !important;
  width: auto !important;
  max-width: 280px !important;
  white-space: normal !important;
  word-break: break-word !important;
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Meiryo", -apple-system, sans-serif !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25) !important;
  opacity: 1 !important;
  pointer-events: none !important;
}

.formError .formErrorArrow,
div.formError .formErrorArrow {
  display: block !important;
  visibility: visible !important;
  position: absolute !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border-left: 6px solid transparent !important;
  border-right: 6px solid transparent !important;
  border-top: none !important;
  border-bottom: none !important;
  opacity: 1 !important;
  left: 18px !important;
}
.formError .formErrorArrow *,
div.formError .formErrorArrow * {
  display: none !important;
}

.formError.greenPopup .formErrorArrow,
.formError .formErrorArrow:not(.formErrorArrowTop):not(.line10) {
  bottom: -6px !important;
  top: auto !important;
  border-top: 6px solid rgba(224, 23, 74, 0.5) !important;
}

.formError .formErrorArrowTop,
.formError .formErrorArrow.formErrorArrowTop,
.formError .formErrorArrow.line10 {
  top: -6px !important;
  bottom: auto !important;
  border-bottom: 6px solid rgba(224, 23, 74, 0.5) !important;
  border-top: none !important;
}

.ui-tooltip,
.ui-tooltip-content {
  background: #e0174a !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 8px 14px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 16px rgba(224, 23, 74, 0.4) !important;
  z-index: 99999 !important;
}

@media screen and (max-width: 750px) {
  .formError .formErrorContent,
  div.formError .formErrorContent {
    font-size: 12px !important;
    padding: 7px 11px !important;
    max-width: calc(100vw - 40px) !important;
    border-radius: 5px !important;
  }
  .formError .formErrorArrow,
  div.formError .formErrorArrow {
    border-left-width: 5px !important;
    border-right-width: 5px !important;
    left: 14px !important;
  }
  .formError.greenPopup .formErrorArrow,
  .formError .formErrorArrow:not(.formErrorArrowTop):not(.line10) {
    bottom: -5px !important;
    border-top-width: 5px !important;
  }
  .formError .formErrorArrowTop,
  .formError .formErrorArrow.formErrorArrowTop,
  .formError .formErrorArrow.line10 {
    top: -5px !important;
    border-bottom-width: 5px !important;
  }
}

input.input_required_ec,
input.input_required_ec:not(.inputError),
table.landing_form_ec input.input_required_ec,
.form_container_ec input.input_required_ec,
.form_main_container_ec input.input_required_ec,
#lp-form input.input_required_ec {
  background: #ffffff !important;
  background-color: #ffffff !important;
}

input.inputError,
select.inputError,
textarea.inputError,
input.input_required_ec.inputError,
input.inputError.input_required_ec,
select.inputError.input_required_ec,
select.input_required_ec.inputError,
textarea.inputError.input_required_ec,
textarea.input_required_ec.inputError,
input[id^="form-validation-field-"].inputError,
select[id^="form-validation-field-"].inputError,
textarea[id^="form-validation-field-"].inputError,
table.landing_form_ec input.inputError,
table.landing_form_ec select.inputError,
table.landing_form_ec textarea.inputError,
.form_container_ec input.inputError,
.form_container_ec select.inputError,
.form_container_ec textarea.inputError,
.form_main_container_ec input.inputError,
.form_main_container_ec select.inputError,
.form_main_container_ec textarea.inputError,
#lp-form input.inputError,
#lp-form select.inputError,
#lp-form textarea.inputError {
  display: revert !important;
  visibility: visible !important;
  width: revert !important;
  height: 52px !important;
  min-height: 52px !important;
  opacity: 1 !important;
  position: static !important;
  overflow: visible !important;
  pointer-events: auto !important;
  border: 2px solid #e0174a !important;
  background: #fff0f4 !important;
  background-color: #fff0f4 !important;
  box-shadow: 0 0 0 2px rgba(224, 23, 74, 0.15) !important;
  outline: none !important;
  animation: inputErrorFlash .4s ease !important;
}

input.inputError:focus,
select.inputError:focus,
textarea.inputError:focus,
input.input_required_ec.inputError:focus,
input.inputError.input_required_ec:focus,
table.landing_form_ec input.inputError:focus,
.form_container_ec input.inputError:focus,
.form_main_container_ec input.inputError:focus,
#lp-form input.inputError:focus {
  border: 2px solid #e0174a !important;
  background: #fff0f4 !important;
  background-color: #fff0f4 !important;
  box-shadow: 0 0 0 3px rgba(224, 23, 74, 0.22) !important;
}

@keyframes inputErrorFlash {
  0%   { box-shadow: 0 0 0 0 rgba(224, 23, 74, 0); }
  50%  { box-shadow: 0 0 0 6px rgba(224, 23, 74, 0.28); }
  100% { box-shadow: 0 0 0 2px rgba(224, 23, 74, 0.15); }
}

input[type="checkbox"].inputError,
input[type="radio"].inputError,
input[type="checkbox"].input_required_ec.inputError,
input[type="radio"].input_required_ec.inputError {
  outline: 2px solid #e0174a !important;
  outline-offset: 2px !important;
  border-radius: 2px !important;
  background: transparent !important;
  box-shadow: none !important;
  animation: inputErrorFlash .4s ease !important;
}

table.landing_form_ec,
table.landing_form_ec tr,
table.landing_form_ec th,
table.landing_form_ec td,
form,
.form_main_container_sp_ec,
div[class*="input_"][class*="_sp_ec"],
div[class*="input_"][class*="_ec"] {
  overflow: visible !important;
}

#payment_method_description,
#shipping_carrier_description {
  margin-top: 12px !important;
  padding: 12px 16px !important;
  background: #f8f9fb !important;
  border-radius: 4px !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
  color: #555 !important;
  text-align: left !important;
}
#payment_method_description img {
  max-width: 100% !important;
  margin: 0 auto 8px !important;
  display: block !important;
}

.scheduled_delivery_date_text_ec {
  padding: 10px 14px !important;
  background: #f8f9fb !important;
  border-radius: 4px !important;
  font-size: 14px !important;
  color: #333 !important;
  margin-top: 6px !important;
  line-height: 1.6 !important;
  text-align: center !important;
}

tr[class*="delivery"] td,
tr[class*="shipping"] td.landing_form_tr_info,
tr:has(.scheduled_delivery_date_text_ec) td {
  text-align: center !important;
}

.charsLeft { color: var(--pink); font-weight: 700; }

.lp-form-section-outer *,
.form_container_ec *,
.form_main_container_ec * {
  box-sizing: border-box !important;
}
.lp-form-section-outer,
.form_container_ec,
.form_main_container_ec,
form#new-view,
form#login-view {
  max-width: 100% !important;
  overflow-x: hidden !important;
}
.lp-form-section-outer input,
.lp-form-section-outer select,
.lp-form-section-outer textarea,
.form_container_ec input,
.form_container_ec select,
.form_container_ec textarea,
.form_main_container_ec input,
.form_main_container_ec select,
.form_main_container_ec textarea {
  max-width: 100% !important;
  box-sizing: border-box !important;
}
.lp-form-section-outer label,
.lp-form-section-outer strong,
.lp-form-section-outer p,
.lp-form-section-outer span,
.form_container_ec label,
.form_container_ec strong,
.form_container_ec p,
.form_main_container_ec label,
.form_main_container_ec strong,
.form_main_container_ec p {
  word-break: break-word !important;
  overflow-wrap: break-word !important;
}

@media screen and (max-width: 750px) {

  #faq { padding-bottom: calc(100 / 750 * 100vw); }
  .plan-list01 { top: calc(410 / 750 * 100vw); }
  .plan-list { width: calc(610 / 750 * 100vw); gap: calc(25/750*100vw) calc(22/750*100vw); }
  .plan-list .plan-item-name { font-size: calc(25/750*100vw); margin: calc(8/750*100vw) 0; }
  .plan-list .plan-price { gap: 0 calc(15/750*100vw); }
  .plan-list .tax { font-size: calc(19/750*100vw); top: calc(-3/750*100vw); }
  .plan-list .tax:before { bottom: calc(8/750*100vw); width: calc(115/750*100vw); height: calc(1/750*100vw); }
  .plan-list .tax span { font-size: calc(15/750*100vw); }
  .plan-list .no-tax { font-size: calc(30/750*100vw); }
  .plan-link-btn-group { padding: 0 calc(40/750*100vw) calc(48/750*100vw); gap: calc(20/750*100vw); }
  .plan-link-btn { padding: calc(26/750*100vw) calc(36/750*100vw); font-size: calc(28/750*100vw); border-radius: calc(100/750*100vw); }
  .plan-link-btn__arrow { font-size: calc(28/750*100vw); margin-left: calc(16/750*100vw); }

  .top-banner-left { font-size: 16px; min-width: 90px; padding: 8px 12px; }
  .top-banner-right { font-size: 17px; padding: 8px 12px; }
  .section-title { padding: 0 16px; margin: 28px 0 24px; }
  .section-title h2 { font-size: 24px !important; }
  .block { padding: 0 16px; margin-bottom: 20px; }
  .block-label { font-size: 16px; margin-bottom: 12px; }
  .notes { padding: 0 16px; }
  .notes p { font-size: 14px; }
  .capacity-track { gap: 8px; }
  .capacity-btn { flex: 1; min-width: 0; padding: 10px 4px; font-size: 16px; }
  .plan-btn { padding: 16px 18px; font-size: 17px; }
  .plan-select-toast { font-size: 14px; margin-top: 12px; }

  .purchase-popup {
    left: 8px !important; right: 8px !important;
    width: auto !important; max-width: none !important;
    transform: translateY(110%) !important;
    padding: 14px 14px 20px;
    border-radius: 20px 20px 0 0;
  }
  .purchase-popup.visible {
    transform: translateY(0) !important;
    animation: popupFadeIn .22s ease-out both;
  }
  .popup-handle { margin-bottom: 10px; }
  .popup-price-row { margin-bottom: 10px; gap: 8px; }
  .popup-price-label { font-size: 14px; }
  .price-slot { font-size: 20px; }
  .price-slot-wrap { height: 32px; }
  .popup-cta { width: 100%; padding: 14px 12px; font-size: 16px; gap: 8px; border-radius: 40px; box-sizing: border-box; }
  .cta-arrow { width: 26px; height: 26px; font-size: 11px; }

  .lp-form-section-outer,
  .form_container_ec,
  .form_main_container_ec {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    max-width: 100% !important;
  }

  table.landing_form_ec,
  table.landing_form_sp_ec,
  #lp-form table.landing_form_ec,
  #lp-form table.landing_form_sp_ec {
    display: table !important;
    width: 100% !important;
    max-width: 100% !important;
    table-layout: fixed !important;
  }
  table.landing_form_ec tbody,
  table.landing_form_sp_ec tbody {
    display: table-row-group !important;
  }
  table.landing_form_ec tr,
  table.landing_form_sp_ec tr {
    display: table-row !important;
  }
  table.landing_form_ec th,
  table.landing_form_sp_ec th {
    display: table-cell !important;
    vertical-align: middle !important;
    width: 110px !important;
    min-width: 110px !important;
    max-width: 110px !important;
    padding: 14px 8px 14px 12px !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    white-space: normal !important;
    box-sizing: border-box !important;
  }
  table.landing_form_ec th .form_box_label_ec,
  table.landing_form_sp_ec th .form_box_label_ec,
  table.landing_form_ec th .form_box_label_sp_ec,
  table.landing_form_sp_ec th .form_box_label_sp_ec {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
  }
  table.landing_form_ec th strong,
  table.landing_form_ec th .form_box_label_ec strong,
  table.landing_form_sp_ec th strong,
  table.landing_form_sp_ec th .form_box_label_ec strong,
  table.landing_form_sp_ec th .form_box_label_sp_ec strong {
    font-size: 12px !important;
    line-height: 1.4 !important;
  }
  table.landing_form_ec td,
  table.landing_form_sp_ec td {
    display: table-cell !important;
    vertical-align: middle !important;
    width: auto !important;
    padding: 12px 10px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  .landing_form_label_ec,
  .landing_form_label_sp_ec {
    font-size: 17px !important;
    padding: 20px 16px !important;
    max-width: 100% !important;
  }
  .purchase_message_ec,
  .purchase_message_sp_ec,
  .agreement_view_ec,
  .agreement_view_sp_ec,
  #AmazonPayOneClickOrderArea,
  .amazon_pay_box_ec,
  .amazon_pay_box_sp_ec,
  .submit_ec {
    max-width: 100% !important;
  }

  table.landing_form_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  table.landing_form_ec select,
  table.landing_form_sp_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  table.landing_form_sp_ec select,
  .form_container_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  .form_container_ec select,
  .form_container_sp_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  .form_container_sp_ec select,
  .form_main_container_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  .form_main_container_ec select,
  .form_main_container_sp_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  .form_main_container_sp_ec select {
    font-size: 16px !important;
    padding: 0 10px !important;
  }

  tr.input_variant_ec td {
    padding: 12px 10px !important;
  }
  table.landing_form_ec tr.input_variant_ec td > #product_container,
  tr.input_variant_ec td > #product_container,
  #product_container {
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  tr.input_name_ec .form_group_ec,
  tr.input_kana_ec .form_group_ec {
    gap: 8px !important;
  }
  tr.input_name_ec .form_group_ec .col-12,
  tr.input_kana_ec .form_group_ec .col-12 {
    flex: 1 1 50% !important;
    max-width: 50% !important;
    min-width: 0 !important;
  }
  tr.input_name_ec .form_group_ec .col-12 > p,
  tr.input_kana_ec .form_group_ec .col-12 > p {
    gap: 4px !important;
  }
  tr.input_name_ec .form_group_ec label,
  tr.input_kana_ec .form_group_ec label {
    font-size: 12px !important;
    min-width: 28px !important;
  }

  input.input_box_zip_ec[name*="[zip01]"],
  input[name="order[billing_address_attributes][zip01]"],
  input[name="order[shipping_address_attributes][zip01]"] {
    width: 80px !important;
    max-width: 80px !important;
    min-width: 80px !important;
    flex: 0 0 80px !important;
    flex-basis: 80px !important;
  }
  input.input_box_zip_ec[name*="[zip02]"],
  input[name="order[billing_address_attributes][zip02]"],
  input[name="order[shipping_address_attributes][zip02]"] {
    width: 100px !important;
    max-width: 100px !important;
    min-width: 100px !important;
    flex: 0 0 100px !important;
    flex-basis: 100px !important;
  }
  tr.input_zip_ec td .form_group_ec,
  tr.input_postal_ec td .form_group_ec,
  tr.input_zip_ec td .form_group_ec > p,
  tr.input_postal_ec td .form_group_ec > p {
    gap: 6px !important;
  }

  .input_box_pref_ec,
  select[name*="prefecture_id"] {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .lp-tel-unified {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  tr.input_card_expiration_ec select,
  tr.input_card_expire_ec select {
    width: 80px !important;
    max-width: 80px !important;
    min-width: 80px !important;
    flex: 0 0 80px !important;
  }
  tr.input_card_expiration_ec .form_group_ec p,
  tr.input_card_expire_ec .form_group_ec p {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
    margin: 0 !important;
  }

  span.form_required_ec,
  span.form_required_sp_ec {
    font-size: 10px !important;
    padding: 2px 7px !important;
  }

  .agreement_view_ec,
  .agreement_view_sp_ec {
    padding: 20px 16px !important;
  }
  .agreement_view_ec > label,
  .agreement_view_sp_ec > label {
    font-size: 12px !important;
    line-height: 1.8 !important;
  }

  input.submit_button_complete_ec,
  .submit_ec input[type="submit"],
  .submit_ec button[type="submit"] {
    min-width: auto !important;
    width: calc(100% - 32px) !important;
    max-width: calc(100% - 32px) !important;
    font-size: 18px !important;
    padding: 20px 24px !important;
  }
  .submit_ec { padding: 28px 16px !important; }

  #AmazonPayOneClickOrderArea { padding: 0 16px !important; }
  .amazon_pay_box_ec,
  .amazon_pay_box_sp_ec { padding: 20px 16px !important; }

  .login_message_box_ec,
  .login_message_box_sp_ec {
    margin: 16px !important;
    padding: 14px 16px !important;
  }
  .login_message_wrapper_ec,
  .login_message_wrapper_ec label {
    font-size: 13px !important;
  }

  .lp-notes-outer { margin: 16px !important; }

  .purchase_message_ec,
  .purchase_message_sp_ec {
    padding: 14px 16px !important;
    font-size: 13px !important;
  }
}

@media screen and (max-width: 750px) {
  html body table.landing_form_ec,
  html body .form_container_ec table.landing_form_ec,
  html body .form_main_container_ec table.landing_form_ec,
  html body form#new-view table.landing_form_ec,
  html body form#login-view table.landing_form_ec {
    display: table !important;
    table-layout: fixed !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  html body table.landing_form_ec tbody,
  html body .form_container_ec table.landing_form_ec tbody {
    display: table-row-group !important;
  }
  html body table.landing_form_ec tr,
  html body table.landing_form_ec tbody tr,
  html body .form_container_ec table.landing_form_ec tr,
  html body .form_container_ec table.landing_form_ec tbody tr,
  html body form#new-view table.landing_form_ec tr {
    display: table-row !important;
    width: auto !important;
    float: none !important;
    clear: none !important;
  }
  html body table.landing_form_ec tr th,
  html body table.landing_form_ec tbody tr th,
  html body .form_container_ec table.landing_form_ec tr th,
  html body .form_container_ec table.landing_form_ec tbody tr th,
  html body form#new-view table.landing_form_ec tr th,
  html body form#new-view table.landing_form_ec tbody tr th {
    display: table-cell !important;
    float: none !important;
    clear: none !important;
    width: 110px !important;
    min-width: 110px !important;
    max-width: 110px !important;
    padding: 14px 8px 14px 12px !important;
    background: #fdf2f5 !important;
    vertical-align: middle !important;
    text-align: left !important;
    word-break: break-word !important;
    box-sizing: border-box !important;
  }
  html body table.landing_form_ec tr th strong,
  html body table.landing_form_ec tbody tr th strong {
    font-size: 12px !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
    white-space: normal !important;
    display: inline-block !important;
    float: none !important;
  }
  html body table.landing_form_ec tr th .form_box_label_ec,
  html body table.landing_form_ec tbody tr th .form_box_label_ec {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
    width: 100% !important;
  }
  html body table.landing_form_ec tr td,
  html body table.landing_form_ec tbody tr td,
  html body .form_container_ec table.landing_form_ec tr td,
  html body .form_container_ec table.landing_form_ec tbody tr td,
  html body form#new-view table.landing_form_ec tr td,
  html body form#new-view table.landing_form_ec tbody tr td {
    display: table-cell !important;
    float: none !important;
    clear: none !important;
    width: auto !important;
    padding: 12px 10px !important;
    background: #fff !important;
    vertical-align: middle !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }
  html body .form_container_ec,
  html body .form_main_container_ec {
    max-width: 100% !important;
    overflow-x: hidden !important;
  }
  html body table.landing_form_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  html body table.landing_form_ec select,
  html body .form_container_ec input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  html body .form_container_ec select {
    font-size: 16px !important;
  }
}

@media screen and (max-width: 750px) {

  div.input_name_sp_ec,
  div.input_kana_sp_ec,
  div.input_zip_sp_ec,
  div.input_prefecture_sp_ec,
  div.input_addr01_sp_ec,
  div.input_addr02_sp_ec,
  div.input_tel_sp_ec,
  div.input_email_sp_ec,
  div.input_password_sp_ec,
  div.input_birth_sp_ec,
  div.input_card_number_sp_ec,
  div.input_card_expiration_sp_ec,
  div.input_card_name_sp_ec,
  div.input_card_cvv_sp_ec,
  div.input_customer_number_sp_ec,
  div.input_shipping_address_id_sp_ec {
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch !important;
    gap: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    border-bottom: 1px solid #e8e8e8 !important;
    background: #fff !important;
    box-sizing: border-box !important;
  }

  div.input_customer_number_sp_ec {
    display: none !important;
  }

  div.input_name_sp_ec > .form_box_label_sp_ec,
  div.input_kana_sp_ec > .form_box_label_sp_ec,
  div.input_zip_sp_ec > .form_box_label_sp_ec,
  div.input_prefecture_sp_ec > .form_box_label_sp_ec,
  div.input_addr01_sp_ec > .form_box_label_sp_ec,
  div.input_addr02_sp_ec > .form_box_label_sp_ec,
  div.input_tel_sp_ec > .form_box_label_sp_ec,
  div.input_email_sp_ec > .form_box_label_sp_ec,
  div.input_password_sp_ec > .form_box_label_sp_ec,
  div.input_birth_sp_ec > .form_box_label_sp_ec,
  div.input_card_number_sp_ec > .form_box_label_sp_ec,
  div.input_card_expiration_sp_ec > .form_box_label_sp_ec,
  div.input_card_name_sp_ec > .form_box_label_sp_ec,
  div.input_card_cvv_sp_ec > .form_box_label_sp_ec,
  div.input_shipping_address_id_sp_ec > .form_box_label_sp_ec {
    flex: 0 0 110px !important;
    width: 110px !important;
    min-width: 110px !important;
    max-width: 110px !important;
    padding: 12px 8px 12px 12px !important;
    margin: 0 !important;
    background: #fdf2f5 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 5px !important;
    box-sizing: border-box !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
    color: #2c2c2c !important;
    font-weight: 700 !important;
    word-break: break-word !important;
  }
  div[class*="input_"][class*="_sp_ec"] > .form_box_label_sp_ec strong {
    font-size: 12px !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
    white-space: normal !important;
    display: inline-block !important;
  }

  div.input_name_sp_ec > .form_group_sp_ec,
  div.input_kana_sp_ec > .form_group_sp_ec,
  div.input_zip_sp_ec > .form_group_sp_ec,
  div.input_prefecture_sp_ec > .form_group_sp_ec,
  div.input_addr01_sp_ec > .form_group_sp_ec,
  div.input_addr02_sp_ec > .form_group_sp_ec,
  div.input_tel_sp_ec > .form_group_sp_ec,
  div.input_email_sp_ec > .form_group_sp_ec,
  div.input_password_sp_ec > .form_group_sp_ec,
  div.input_birth_sp_ec > .form_group_sp_ec,
  div.input_card_number_sp_ec > .form_group_sp_ec,
  div.input_card_expiration_sp_ec > .form_group_sp_ec,
  div.input_card_name_sp_ec > .form_group_sp_ec,
  div.input_card_cvv_sp_ec > .form_group_sp_ec,
  div.input_shipping_address_id_sp_ec > .form_group_sp_ec {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    padding: 10px !important;
    background: #fff !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
  }

  span.form_required_sp_ec {
    font-size: 10px !important;
    padding: 2px 6px !important;
    background: #e0174a !important;
    color: #fff !important;
    border-radius: 3px !important;
    font-weight: 800 !important;
    display: inline-block !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    letter-spacing: 0.05em !important;
  }

  div.input_name_sp_ec > .form_group_sp_ec,
  div.input_kana_sp_ec > .form_group_sp_ec {
    flex-direction: row !important;
    gap: 6px !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
  }
  div.input_name_sp_ec > .form_group_sp_ec > input,
  div.input_kana_sp_ec > .form_group_sp_ec > input {
    flex: 1 1 50% !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 50% !important;
  }

  div.input_zip_sp_ec > .form_group_sp_ec > p {
    display: flex !important;
    flex-direction: row !important;
    gap: 4px !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  input.input_box_zip1_sp_ec,
  input[name="order[billing_address_attributes][zip01]"],
  input[name="order[shipping_address_attributes][zip01]"] {
    flex: 0 0 65px !important;
    width: 65px !important;
    max-width: 65px !important;
    min-width: 65px !important;
  }
  input.input_box_zip2_sp_ec,
  input[name="order[billing_address_attributes][zip02]"],
  input[name="order[shipping_address_attributes][zip02]"] {
    flex: 0 0 80px !important;
    width: 80px !important;
    max-width: 80px !important;
    min-width: 80px !important;
  }
  div.input_zip_sp_ec > .form_group_sp_ec > p > span {
    flex: 0 0 auto !important;
    font-size: 13px !important;
    color: #555 !important;
  }

  div.input_tel_sp_ec > .form_group_sp_ec > p {
    display: flex !important;
    flex-direction: row !important;
    gap: 4px !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  input.input_box_tel1_sp_ec,
  input.input_box_tel2_sp_ec,
  input.input_box_tel3_sp_ec {
    flex: 1 1 auto !important;
    width: auto !important;
    min-width: 0 !important;
  }
  div.input_tel_sp_ec > .form_group_sp_ec > p > span {
    flex: 0 0 auto !important;
    font-size: 13px !important;
    color: #555 !important;
  }

  div.input_prefecture_sp_ec select,
  div.input_addr01_sp_ec input,
  div.input_addr02_sp_ec input,
  div.input_email_sp_ec input,
  div.input_password_sp_ec input,
  div.input_card_number_sp_ec input,
  div.input_card_name_sp_ec input {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  div.input_variant_sp_ec {
    padding: 14px 10px !important;
    border-bottom: 1px solid #e8e8e8 !important;
    background: #fff !important;
  }

  div.input_birth_sp_ec > .form_group_sp_ec {
    flex-direction: row !important;
    gap: 4px !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
  }
  div.input_birth_sp_ec select {
    flex: 1 1 auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  div.input_card_expiration_sp_ec > .form_group_sp_ec > p {
    display: flex !important;
    flex-direction: row !important;
    gap: 4px !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  div.input_card_expiration_sp_ec select {
    flex: 0 0 60px !important;
    width: 60px !important;
    max-width: 60px !important;
  }

  div[class*="input_"][class*="_sp_ec"] input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="file"]),
  div[class*="input_"][class*="_sp_ec"] select {
    height: 44px !important;
    min-height: 44px !important;
    max-height: 44px !important;
    font-size: 16px !important;
    padding: 0 8px !important;
    line-height: 42px !important;
    border: 1px solid #c8c8c8 !important;
    border-radius: 4px !important;
    background: #fff !important;
    color: #1a1a1a !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    outline: none !important;
  }

  div[class*="input_"][class*="_sp_ec"] select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23e0174a' d='M6 8L0 0h12z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    padding-right: 28px !important;
  }

  .caution_sp_ec {
    font-size: 11px !important;
    color: #888 !important;
    line-height: 1.5 !important;
    margin-top: 4px !important;
  }

  .submit_sp_ec {
    padding: 24px 16px !important;
    text-align: center !important;
    background: #fff !important;
  }
  input.submit_bottom_sp_ec,
  .submit_sp_ec input[type="submit"] {
    display: inline-block !important;
    width: calc(100% - 32px) !important;
    min-width: auto !important;
    padding: 18px 24px !important;
    background: linear-gradient(180deg, #ef4477 0%, #e0174a 50%, #c10d3d 100%) !important;
    color: #fff !important;
    font-size: 17px !important;
    font-weight: 900 !important;
    border: none !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    box-shadow: 0 4px 16px rgba(224,23,74,.3) !important;
    height: auto !important;
    min-height: auto !important;
    max-height: none !important;
    line-height: 1.3 !important;
    font-family: inherit !important;
  }

  .login_message_box_sp_ec {
    margin: 16px !important;
    padding: 14px 16px !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 6px !important;
    background: #fafafa !important;
  }

  .agreement_view_sp_ec {
    padding: 20px 16px !important;
    text-align: center !important;
    border-top: 1px solid #e8e8e8 !important;
    background: #fff !important;
  }
  .agreement_view_sp_ec label {
    font-size: 12px !important;
    line-height: 1.7 !important;
  }

  #product_container {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
    width: 100% !important;
    padding: 0 !important;
  }
}

.login_message_box_ec {
  text-align: left !important;
}
.login_message_box_ec .login_message_wrapper_ec {
  text-align: left !important;
}
.login_message_box_ec .login_message_wrapper_ec label {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  text-align: left !important;
}

@media screen and (min-width: 751px) {
  table.landing_form_ec tr.input_variant_ec td > #product_container,
  tr.input_variant_ec td > #product_container,
  #product_container {
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }
  tr.input_variant_ec > td > select,
  tr.input_variant_ec > td > input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]) {
    margin-left: 0 !important;
    max-width: 100% !important;
  }
}

.scheduled_delivery_date_text_ec,
.scheduled_delivery_date_text_sp_ec {
  text-align: left !important;
}
tr[class*="delivery"] td,
tr[class*="shipping"] td.landing_form_tr_info,
tr:has(.scheduled_delivery_date_text_ec) td {
  text-align: left !important;
}

@media screen and (max-width: 750px) {
  .login_message_box_ec,
  .login_message_box_sp_ec {
    margin: 16px 12px !important;
    padding: 14px 14px !important;
    max-width: calc(100% - 24px) !important;
    text-align: left !important;
    box-sizing: border-box !important;
  }
  .login_message_box_ec .login_message_wrapper_ec,
  .login_message_box_sp_ec .login_message_wrapper_ec {
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
  }
  .login_message_box_ec .login_message_wrapper_ec label,
  .login_message_box_sp_ec .login_message_wrapper_ec label,
  .login_message_box_ec label,
  .login_message_box_sp_ec label {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    color: #333 !important;
    cursor: pointer !important;
  }
  .login_message_box_ec input[type="checkbox"],
  .login_message_box_sp_ec input[type="checkbox"] {
    flex-shrink: 0 !important;
    width: 16px !important;
    height: 16px !important;
    margin: 0 !important;
    vertical-align: middle !important;
    accent-color: #e0174a !important;
  }
  .login_message_box_ec .login_message_wrapper_ec label > span,
  .login_message_box_sp_ec .login_message_wrapper_ec label > span {
    flex: 1 1 auto !important;
    word-break: break-word !important;
    line-height: 1.5 !important;
  }
}

@media screen and (max-width: 750px) {
  tr.input_card_expiration_ec .form_group_ec,
  tr.input_card_expire_ec .form_group_ec,
  tr.input_card_expiration_ec > td,
  tr.input_card_expire_ec > td,
  div.input_card_expiration_sp_ec .form_group_sp_ec,
  div.input_card_expire_sp_ec .form_group_sp_ec {
    display: block !important;
  }

  tr.input_card_expiration_ec .form_group_ec > p:first-of-type,
  tr.input_card_expire_ec .form_group_ec > p:first-of-type,
  tr.input_card_expiration_ec .form_group_ec > p:not(.caution_ec):not(.caution_sp_ec),
  tr.input_card_expire_ec .form_group_ec > p:not(.caution_ec):not(.caution_sp_ec),
  div.input_card_expiration_sp_ec .form_group_sp_ec > p:first-of-type,
  div.input_card_expiration_sp_ec .form_group_sp_ec > p:not(.caution_sp_ec):not(.caution_ec) {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 4px !important;
    flex-wrap: wrap !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
    width: 100% !important;
  }

  tr.input_card_expiration_ec .caution_ec,
  tr.input_card_expire_ec .caution_ec,
  tr.input_card_expiration_ec .form_group_ec > p.caution_ec,
  tr.input_card_expire_ec .form_group_ec > p.caution_ec,
  tr.input_card_expiration_ec .form_group_ec > p:not(:first-of-type),
  tr.input_card_expire_ec .form_group_ec > p:not(:first-of-type),
  div.input_card_expiration_sp_ec .caution_sp_ec,
  div.input_card_expire_sp_ec .caution_sp_ec {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 6px 0 0 0 !important;
    padding: 0 !important;
    font-size: 11px !important;
    line-height: 1.5 !important;
    color: #777 !important;
    flex: none !important;
    clear: both !important;
    order: 99 !important;
  }
}

@media screen and (max-width: 750px) {
  tr.input_card_expiration_ec select,
  tr.input_card_expire_ec select,
  div.input_card_expiration_sp_ec select,
  div.input_card_expire_sp_ec select {
    width: 72px !important;
    max-width: 72px !important;
    min-width: 72px !important;
    flex: 0 0 72px !important;
  }
  tr.input_card_expiration_ec .form_group_ec > p span,
  tr.input_card_expire_ec .form_group_ec > p span,
  div.input_card_expiration_sp_ec .form_group_sp_ec > p span,
  div.input_card_expire_sp_ec .form_group_sp_ec > p span {
    flex-shrink: 0 !important;
    font-size: 13px !important;
    color: #555 !important;
    padding: 0 2px !important;
  }
}

@media screen and (max-width: 750px) {

  html body .login_message_box_ec,
  html body .login_message_box_sp_ec,
  html body .form_container_ec .login_message_box_ec,
  html body .form_main_container_ec .login_message_box_ec {
    display: block !important;
    margin: 16px 12px !important;
    padding: 14px 16px !important;
    max-width: calc(100% - 24px) !important;
    width: auto !important;
    text-align: left !important;
    box-sizing: border-box !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 6px !important;
    background: #fafafa !important;
  }

  html body .login_message_box_ec .login_message_wrapper_ec,
  html body .login_message_box_sp_ec .login_message_wrapper_ec {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
    width: 100% !important;
  }

  html body .login_message_box_ec .login_message_wrapper_ec label,
  html body .login_message_box_sp_ec .login_message_wrapper_ec label,
  html body .login_message_box_ec > label,
  html body .login_message_box_sp_ec > label,
  html body .form_container_ec .login_message_box_ec label,
  html body .form_main_container_ec .login_message_box_ec label {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: #333 !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
  }

  html body .login_message_box_ec input[type="checkbox"],
  html body .login_message_box_sp_ec input[type="checkbox"],
  html body .login_message_box_ec label input[type="checkbox"],
  html body .login_message_box_sp_ec label input[type="checkbox"],
  html body .login_message_box_ec .login_message_wrapper_ec input[type="checkbox"],
  html body .login_message_box_sp_ec .login_message_wrapper_ec input[type="checkbox"] {
    flex: 0 0 18px !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
    max-width: 18px !important;
    max-height: 18px !important;
    margin: 0 !important;
    padding: 0 !important;
    vertical-align: middle !important;
    accent-color: #e0174a !important;
    display: inline-block !important;
    position: static !important;
    float: none !important;
    box-sizing: border-box !important;
  }

  html body tr.input_card_expiration_ec > td,
  html body tr.input_card_expire_ec > td,
  html body table.landing_form_ec tr.input_card_expiration_ec > td,
  html body table.landing_form_ec tr.input_card_expire_ec > td,
  html body table.landing_form_sp_ec tr.input_card_expiration_ec > td,
  html body table.landing_form_sp_ec tr.input_card_expire_ec > td {
    display: table-cell !important;
    vertical-align: middle !important;
    padding: 12px 10px !important;
    box-sizing: border-box !important;
  }

  html body tr.input_card_expiration_ec .form_group_ec,
  html body tr.input_card_expire_ec .form_group_ec,
  html body tr.input_card_expiration_ec td .form_group_ec,
  html body tr.input_card_expire_ec td .form_group_ec,
  html body table.landing_form_ec tr.input_card_expiration_ec .form_group_ec,
  html body table.landing_form_ec tr.input_card_expire_ec .form_group_ec {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
  }

  html body tr.input_card_expiration_ec .form_group_ec > p,
  html body tr.input_card_expire_ec .form_group_ec > p,
  html body table.landing_form_ec tr.input_card_expiration_ec .form_group_ec > p,
  html body table.landing_form_ec tr.input_card_expire_ec .form_group_ec > p {
    display: block !important;
    width: 100% !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
  }

  html body tr.input_card_expiration_ec .form_group_ec > p:first-of-type,
  html body tr.input_card_expire_ec .form_group_ec > p:first-of-type,
  html body table.landing_form_ec tr.input_card_expiration_ec .form_group_ec > p:first-of-type,
  html body table.landing_form_ec tr.input_card_expire_ec .form_group_ec > p:first-of-type {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    width: 100% !important;
    margin: 0 0 10px 0 !important;
    padding: 0 !important;
  }

  html body tr.input_card_expiration_ec .form_group_ec > p:first-of-type select,
  html body tr.input_card_expire_ec .form_group_ec > p:first-of-type select,
  html body tr.input_card_expiration_ec select,
  html body tr.input_card_expire_ec select,
  html body table.landing_form_ec tr.input_card_expiration_ec select,
  html body table.landing_form_ec tr.input_card_expire_ec select {
    flex: 0 0 80px !important;
    width: 80px !important;
    max-width: 80px !important;
    min-width: 80px !important;
    box-sizing: border-box !important;
  }

  html body tr.input_card_expiration_ec .form_group_ec > p:first-of-type > span,
  html body tr.input_card_expire_ec .form_group_ec > p:first-of-type > span,
  html body tr.input_card_expiration_ec td span:not(.form_required_ec):not(.form_required_sp_ec),
  html body tr.input_card_expire_ec td span:not(.form_required_ec):not(.form_required_sp_ec) {
    flex: 0 0 auto !important;
    font-size: 14px !important;
    color: #555 !important;
    padding: 0 2px !important;
    margin: 0 !important;
    white-space: nowrap !important;
  }

  html body tr.input_card_expiration_ec .form_group_ec > p:first-of-type br,
  html body tr.input_card_expire_ec .form_group_ec > p:first-of-type br {
    display: block !important;
    content: "" !important;
    flex-basis: 100% !important;
    width: 100% !important;
    height: 0 !important;
    margin: 6px 0 0 0 !important;
    line-height: 0 !important;
  }

  html body tr.input_card_expiration_ec .form_group_ec > p.caution_ec,
  html body tr.input_card_expire_ec .form_group_ec > p.caution_ec,
  html body tr.input_card_expiration_ec .caution_ec,
  html body tr.input_card_expire_ec .caution_ec,
  html body tr.input_card_expiration_ec td > .caution_ec,
  html body tr.input_card_expire_ec td > .caution_ec,
  html body tr.input_card_expiration_ec .form_group_ec > p:not(:first-of-type),
  html body tr.input_card_expire_ec .form_group_ec > p:not(:first-of-type) {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    clear: both !important;
    float: none !important;
    margin: 8px 0 0 0 !important;
    padding: 0 !important;
    font-size: 12px !important;
    line-height: 1.6 !important;
    color: #888 !important;
    flex-basis: 100% !important;
    order: 99 !important;
  }

  html body div.input_card_expiration_sp_ec .form_group_sp_ec,
  html body div.input_card_expire_sp_ec .form_group_sp_ec {
    display: block !important;
    width: 100% !important;
    padding: 10px !important;
    box-sizing: border-box !important;
  }
  html body div.input_card_expiration_sp_ec .form_group_sp_ec > p:first-of-type,
  html body div.input_card_expire_sp_ec .form_group_sp_ec > p:first-of-type {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    width: 100% !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
  }
  html body div.input_card_expiration_sp_ec .form_group_sp_ec select,
  html body div.input_card_expire_sp_ec .form_group_sp_ec select {
    flex: 0 0 72px !important;
    width: 72px !important;
    max-width: 72px !important;
    min-width: 72px !important;
    box-sizing: border-box !important;
  }
  html body div.input_card_expiration_sp_ec .caution_sp_ec,
  html body div.input_card_expire_sp_ec .caution_sp_ec,
  html body div.input_card_expiration_sp_ec .form_group_sp_ec > p.caution_sp_ec,
  html body div.input_card_expire_sp_ec .form_group_sp_ec > p.caution_sp_ec,
  html body div.input_card_expiration_sp_ec .form_group_sp_ec > p:not(:first-of-type),
  html body div.input_card_expire_sp_ec .form_group_sp_ec > p:not(:first-of-type) {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    clear: both !important;
    float: none !important;
    margin: 8px 0 0 0 !important;
    padding: 0 !important;
    font-size: 11px !important;
    line-height: 1.5 !important;
    color: #888 !important;
    flex-basis: 100% !important;
    order: 99 !important;
  }
}

@media screen and (max-width: 750px) {
  html body tr.input_card_expiration_ec td .form_group_ec,
  html body tr.input_card_expire_ec td .form_group_ec {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
  }
}

html body .login_message_box_ec,
html body .login_message_box_sp_ec {
  display: block !important;
  margin: 20px auto !important;
  max-width: 700px !important;
  padding: 0 !important;
  border: 1px solid #e8e8e8 !important;
  border-radius: 6px !important;
  background: #fafafa !important;
  text-align: left !important;
  box-sizing: border-box !important;
}

html body .login_message_box_ec .login_message_wrapper_ec,
html body .login_message_box_sp_ec .login_message_wrapper_ec {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 16px 20px !important;
  text-align: left !important;
  box-sizing: border-box !important;
}

html body .login_message_box_ec label,
html body .login_message_box_sp_ec label,
html body .login_message_box_ec .login_message_wrapper_ec label,
html body .login_message_box_sp_ec .login_message_wrapper_ec label {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  color: #333 !important;
  cursor: pointer !important;
  text-align: left !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

html body .login_message_box_ec input[type="checkbox"],
html body .login_message_box_sp_ec input[type="checkbox"],
html body .login_message_box_ec label input[type="checkbox"],
html body .login_message_box_sp_ec label input[type="checkbox"],
html body .login_message_box_ec .login_message_wrapper_ec input[type="checkbox"],
html body .login_message_box_sp_ec .login_message_wrapper_ec input[type="checkbox"] {
  flex: 0 0 18px !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  margin: 0 !important;
  margin-top: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-block: 0 !important;
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
  margin-inline: 0 !important;
  margin-inline-start: 0 !important;
  margin-inline-end: 0 !important;
  padding: 0 !important;
  vertical-align: middle !important;
  display: inline-block !important;
  position: static !important;
  float: none !important;
  box-sizing: border-box !important;
}

@media screen and (max-width: 750px) {
  html body .login_message_box_ec,
  html body .login_message_box_sp_ec {
    margin: 12px 12px !important;
    max-width: calc(100% - 24px) !important;
  }
  html body .login_message_box_ec .login_message_wrapper_ec,
  html body .login_message_box_sp_ec .login_message_wrapper_ec {
    padding: 0 14px !important;
    min-height: 38px !important;
    line-height: 1.3 !important;
  }
  html body .login_message_box_ec label,
  html body .login_message_box_sp_ec label {
    font-size: 13px !important;
    line-height: 1.5 !important;
  }
}

html body #payment_method_description:empty,
html body #shipping_carrier_description:empty,
html body #payment_method_description_sp:empty,
html body #shipping_carrier_description_sp:empty {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  height: 0 !important;
  min-height: 0 !important;
}

html body .lp-empty-hide,
html body .lp-empty-hide.lp-empty-hide {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
}

html body #payment_method_description,
html body #shipping_carrier_description {
  min-height: 0 !important;
}

html body select[name*="payment_method_id"] + div:empty,
html body select[name*="payment_method"] + div:empty {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

html body .login_message_box_ec,
html body .login_message_box_sp_ec {
  padding: 0 !important;
  line-height: 1 !important;
}

html body .login_message_box_ec .login_message_wrapper_ec,
html body .login_message_box_sp_ec .login_message_wrapper_ec {
  padding: 8px 16px !important;
  min-height: 0 !important;
  line-height: 1 !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
}

@media screen and (max-width: 750px) {
  html body .login_message_box_ec .login_message_wrapper_ec,
  html body .login_message_box_sp_ec .login_message_wrapper_ec {
    padding: 6px 14px !important;
  }
}

html body .login_message_box_ec label,
html body .login_message_box_sp_ec label,
html body .login_message_box_ec .login_message_wrapper_ec label,
html body .login_message_box_sp_ec .login_message_wrapper_ec label {
  margin: 0 !important;
  padding: 0 !important;
  min-height: 0 !important;
  line-height: 1.4 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
}

html body .login_message_box_ec input[type="checkbox"],
html body .login_message_box_ec input[type="checkbox"]:hover,
html body .login_message_box_ec input[type="checkbox"]:focus,
html body .login_message_box_ec input[type="checkbox"]:active,
html body .login_message_box_ec input[type="checkbox"]:checked,
html body .login_message_box_ec input[type="checkbox"].inputError,
html body .login_message_box_ec input[type="checkbox"].input_required_ec,
html body .login_message_box_ec input[type="checkbox"].input_required_ec.inputError,
html body .login_message_box_ec input[type="checkbox"].lp-custom-error,
html body .login_message_box_ec label input[type="checkbox"],
html body .login_message_box_ec .login_message_wrapper_ec input[type="checkbox"],
html body .login_message_box_sp_ec input[type="checkbox"],
html body .login_message_box_sp_ec input[type="checkbox"]:hover,
html body .login_message_box_sp_ec input[type="checkbox"]:focus,
html body .login_message_box_sp_ec input[type="checkbox"]:active,
html body .login_message_box_sp_ec input[type="checkbox"]:checked,
html body .login_message_box_sp_ec input[type="checkbox"].inputError,
html body .login_message_box_sp_ec input[type="checkbox"].input_required_ec,
html body .login_message_box_sp_ec input[type="checkbox"].input_required_ec.inputError,
html body .login_message_box_sp_ec input[type="checkbox"].lp-custom-error,
html body .login_message_box_sp_ec label input[type="checkbox"],
html body .login_message_box_sp_ec .login_message_wrapper_ec input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  margin: 0 !important;
  margin-top: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-block: 0 !important;
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
  margin-inline: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  outline: none !important;
  outline-offset: 0 !important;
  border: 1px solid #c8c8c8 !important;
  animation: none !important;
  -webkit-animation: none !important;
  transition: none !important;
  position: static !important;
  float: none !important;
  vertical-align: middle !important;
  line-height: 1 !important;
  flex: 0 0 18px !important;
  flex-grow: 0 !important;
  flex-shrink: 0 !important;
  flex-basis: 18px !important;
  display: inline-block !important;
  box-sizing: border-box !important;
  accent-color: #e0174a !important;
  -webkit-appearance: checkbox !important;
  -moz-appearance: checkbox !important;
  appearance: auto !important;
}

@media screen and (min-width: 751px) {
  html body table.landing_form_ec tr.input_variant_ec td#product_container,
  html body tr.input_variant_ec td#product_container,
  html body td#product_container {
    padding: 20px 20px !important;
  }

  html body table.landing_form_ec tr.input_variant_ec td#product_container > .form_group_ec,
  html body tr.input_variant_ec td#product_container > .form_group_ec,
  html body td#product_container > .form_group_ec {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
  }

  html body table.landing_form_ec tr.input_variant_ec td#product_container select#variant_id,
  html body tr.input_variant_ec td#product_container select#variant_id,
  html body td#product_container select#variant_id,
  html body td#product_container .form_group_ec > select {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: block !important;
  }

  html body td#product_container select#variant_id {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 14 10'%3E%3Cpath fill='%23e0174a' d='M7 10L0 0h14z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 18px center !important;
    background-size: 14px 10px !important;
    background-color: #ffffff !important;
    padding-right: 46px !important;
    border: 1.5px solid #e0174a !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
    cursor: pointer !important;
    transition: border-color .2s ease,
                background-color .2s ease,
                box-shadow .2s ease !important;
  }

  html body td#product_container select#variant_id:hover {
    border-color: #c4003a !important;
    background-color: #fff5f7 !important;
    box-shadow: 0 2px 10px rgba(224, 23, 74, 0.18) !important;
  }

  html body td#product_container select#variant_id:focus {
    border: 1.5px solid #e0174a !important;
    background-color: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(224, 23, 74, 0.22) !important;
    outline: none !important;
  }

  html body td#product_container select#variant_id:active {
    background-color: #fde8ee !important;
    transform: translateY(1px);
  }
}

@media screen and (max-width: 750px) {

  html body #container_scheduled_delivery_dates {
    padding: 14px 16px !important;
    margin: 0 !important;
    background: #fff !important;
    border-bottom: 1px solid #e8e8e8 !important;
    box-sizing: border-box !important;
  }

  html body #container_scheduled_delivery_dates > p.form_box_label_sp_ec,
  html body #container_scheduled_delivery_dates > .form_box_label_sp_ec {
    display: block !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #2c2c2c !important;
    line-height: 1.4 !important;
    background: transparent !important;
    flex: none !important;
    width: auto !important;
    max-width: 100% !important;
  }

  html body #container_scheduled_delivery_dates > p.form_box_label_sp_ec strong {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #2c2c2c !important;
  }

  html body .scheduled_delivery_date_text_sp_ec,
  html body #container_scheduled_delivery_dates .scheduled_delivery_date_text_sp_ec {
    padding: 12px 16px !important;
    background: #f8f9fb !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    color: #333 !important;
    margin: 0 !important;
    line-height: 1.6 !important;
    text-align: left !important;
    box-sizing: border-box !important;
  }

  html body .scheduled_delivery_date_text_sp_ec + .scheduled_delivery_date_text_sp_ec {
    margin-top: 8px !important;
  }

  html body div.agreement_view_sp_ec {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    padding: 20px 16px !important;
    text-align: left !important;
    border-top: 1px solid #e8e8e8 !important;
    background: #fff !important;
    box-sizing: border-box !important;
  }

  html body div.agreement_view_sp_ec > input[type="checkbox"] {
    margin: 3px 0 0 0 !important;
    flex: 0 0 16px !important;
    flex-shrink: 0 !important;
    float: none !important;
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    min-height: 16px !important;
    vertical-align: top !important;
    display: inline-block !important;
  }

  html body div.agreement_view_sp_ec > label {
    display: block !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    text-align: left !important;
    line-height: 1.7 !important;
    font-size: 13px !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    width: auto !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    color: #333 !important;
  }

  html body .purchase_message_ec,
  html body .purchase_message_sp_ec,
  html body div.purchase_message_sp_ec {
    padding: 9px 18px !important;
    margin-top: 4px !important;
    margin-bottom: 4px !important;
    line-height: 1.6 !important;
  }

  html body .purchase_message_ec p,
  html body .purchase_message_sp_ec p {
    margin: 0 !important;
    padding: 0 !important;
  }

  html body .login_message_box_ec .login_message_wrapper_ec,
  html body .login_message_box_sp_ec .login_message_wrapper_ec,
  html body .login_message_box_ec .login_message_wrapper_sp_ec,
  html body .login_message_box_sp_ec .login_message_wrapper_sp_ec,
  html body p.login_message_wrapper_ec,
  html body p.login_message_wrapper_sp_ec {
    padding: 14px 14px !important;
    margin: 0 !important;
    line-height: 1.5 !important;
    min-height: 0 !important;
  }
}

@media screen and (min-width: 751px) {
  .agreement_view_ec br.lp-break-agreement,
  .agreement_view_sp_ec br.lp-break-agreement {
    display: none !important;
  }
}

@media screen and (max-width: 750px) {

  html body div.input_tel_sp_ec .form_group_sp_ec span,
  html body div.input_tel_sp_ec .form_group_sp_ec > p > span,
  html body div.input_tel_sp_ec > .form_group_sp_ec > span {
    display: none !important;
  }

  html body div.input_tel_sp_ec .form_group_sp_ec > p,
  html body div.input_tel_sp_ec > .form_group_sp_ec > p {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
  }

  html body div.input_tel_sp_ec .form_group_sp_ec > p > input,
  html body div.input_tel_sp_ec .form_group_sp_ec input[type="tel"],
  html body div.input_tel_sp_ec .form_group_sp_ec input.input_box_tel_sp_ec {
    flex: 1 1 0 !important;
    width: auto !important;
    min-width: 0 !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }

  html body #product_container,
  html body #product_container.flex,
  html body #view-billing-information #product_container {
    display: block !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  html body #product_container div.input_variant_sp_ec,
  html body #product_container > div.input_variant_sp_ec {
    display: block !important;
    flex: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
    border-bottom: 1px solid #e8e8e8 !important;
    box-sizing: border-box !important;
    width: 100% !important;
  }

  html body #product_container div.input_variant_sp_ec > p.form_box_label_sp_ec,
  html body #product_container div.input_variant_sp_ec > .form_box_label_sp_ec {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    flex: none !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 18px 16px 10px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #2c2c2c !important;
    line-height: 1.4 !important;
  }

  html body #product_container div.input_variant_sp_ec > .form_group_sp_ec {
    display: block !important;
    flex: none !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 16px 18px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    box-sizing: border-box !important;
  }

  html body #product_container select#variant_id,
  html body #product_container select.input_box_product_sp_ec,
  html body #product_container div.input_variant_sp_ec select {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: none !important;
    margin: 0 !important;
    display: block !important;
    box-sizing: border-box !important;
  }

  html body #view-shipping-information > .hide-on-amazon-pay {
    display: block !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
    border-bottom: 1px solid #e8e8e8 !important;
    box-sizing: border-box !important;
    width: 100% !important;
  }

  html body #view-shipping-information > .hide-on-amazon-pay > p.form_box_label_sp_ec,
  html body #view-shipping-information > .hide-on-amazon-pay > .form_box_label_sp_ec {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    flex: none !important;
    width: auto !important;
    max-width: 100% !important;
    padding: 18px 16px 10px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #2c2c2c !important;
    line-height: 1.4 !important;
  }

  html body #view-shipping-information > .hide-on-amazon-pay > .form_group_sp_ec {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 16px 18px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    box-sizing: border-box !important;
  }

  html body #view-shipping-information select.input_box_shipping_address_sp_ec,
  html body #view-shipping-information select[name="order[shipping_address_id]"],
  html body #view-shipping-information select#shipping_address_id {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    display: block !important;
    box-sizing: border-box !important;
  }

  html body #view-payment-information > p.form_box_label_sp_ec {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    flex: none !important;
    width: auto !important;
    max-width: 100% !important;
    padding: 18px 16px 10px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #2c2c2c !important;
    line-height: 1.4 !important;
  }

  html body #view-payment-information > .form_group_sp_ec {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 16px 18px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    border-bottom: 1px solid #e8e8e8 !important;
    box-sizing: border-box !important;
  }

  html body #view-payment-information select.input_box_card_method_sp_ec,
  html body #view-payment-information select#payment_method_id {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    display: block !important;
    box-sizing: border-box !important;
  }
}

@media screen and (max-width: 900px) {
  html body tr.input_card_cvv_ec td ul,
  html body tr#view-input-card-cvv td ul,
  html body tr.input_card_cvv_ec td ul[style*="list-style"],
  html body tr#view-input-card-cvv ul[style*="list-style"],
  html body div.input_card_cvv_sp_ec ul,
  html body div.input_card_cvv_sp_ec ul[style*="list-style"],
  html body div[class*="input_card_cvv"] ul {
    list-style: none !important;
    list-style-type: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin: 8px 0 !important;
    background: transparent !important;
  }

  html body tr.input_card_cvv_ec td ul > li,
  html body tr#view-input-card-cvv td ul > li,
  html body div.input_card_cvv_sp_ec ul > li,
  html body div[class*="input_card_cvv"] ul > li {
    list-style: none !important;
    list-style-type: none !important;
    display: block !important;
    position: relative !important;
    padding: 0 0 0 12px !important;
    margin: 0 0 8px 0 !important;
    font-size: 11px !important;
    line-height: 1.6 !important;
    color: #555 !important;
    text-indent: 0 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    background: transparent !important;
  }

  html body tr.input_card_cvv_ec td ul > li:last-child,
  html body tr#view-input-card-cvv td ul > li:last-child,
  html body div[class*="input_card_cvv"] ul > li:last-child {
    margin-bottom: 0 !important;
  }

  html body tr.input_card_cvv_ec td ul > li::marker,
  html body tr#view-input-card-cvv td ul > li::marker,
  html body div.input_card_cvv_sp_ec ul > li::marker,
  html body div[class*="input_card_cvv"] ul > li::marker {
    content: '' !important;
    font-size: 0 !important;
    color: transparent !important;
    display: none !important;
  }

  html body tr.input_card_cvv_ec td ul > li::before,
  html body tr#view-input-card-cvv td ul > li::before,
  html body div.input_card_cvv_sp_ec ul > li::before,
  html body div[class*="input_card_cvv"] ul > li::before {
    content: '・' !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    color: #888 !important;
    font-size: 11px !important;
    line-height: 1.6 !important;
  }

  html body tr.input_card_cvv_ec > td,
  html body tr#view-input-card-cvv > td {
    padding: 14px 16px !important;
    box-sizing: border-box !important;
  }

  html body tr.input_card_cvv_ec td p.caution_ec,
  html body tr#view-input-card-cvv td p.caution_ec {
    font-size: 11px !important;
    line-height: 1.6 !important;
    margin: 6px 0 !important;
    padding: 0 !important;
    color: #666 !important;
  }

  html body tr.input_card_cvv_ec td img,
  html body tr#view-input-card-cvv td img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
    display: block !important;
    margin: 10px auto 0 auto !important;
    box-sizing: border-box !important;
  }

  html body tr.input_card_cvv_ec td > p:empty,
  html body tr#view-input-card-cvv td > p:empty {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }
}

@media screen and (min-width: 751px) {
  html body .amazon_pay_box_ec,
  html body .amazon_pay_button_wrapper_ec,
  html body .amazon_pay_button_area_ec,
  html body .amazon_pay_payments_area_ec {
    text-align: center !important;
    box-sizing: border-box !important;
  }

  html body .amazon_pay_payments_area_ec {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
  }

  html body #AmazonPayButtonAll,
  html body .amazon_pay_button_all_ec,
  html body div.amazon_pay_button_all_ec {
    margin-left: auto !important;
    margin-right: auto !important;
    display: block !important;
    float: none !important;
  }
}

@media screen and (min-width: 751px) {
  html body tr[class*="input_tel"] td .form_group_ec,
  html body tr[class*="input_tel"] td .form_group_ec > p,
  html body tr.input_tel_ec td .form_group_ec,
  html body tr.input_tel_ec td .form_group_ec > p,
  html body #view-shipping-information tr[class*="tel"] .form_group_ec,
  html body #view-shipping-information tr[class*="tel"] .form_group_ec > p,
  html body #view-billing-information tr[class*="tel"] .form_group_ec,
  html body #view-billing-information tr[class*="tel"] .form_group_ec > p {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  html body tr[class*="input_tel"] input[name*="tel01"],
  html body tr[class*="input_tel"] input[name*="tel02"],
  html body tr[class*="input_tel"] input[name*="tel03"],
  html body tr[class*="input_tel"] .input_box_tel1_ec,
  html body tr[class*="input_tel"] .input_box_tel2_ec,
  html body tr[class*="input_tel"] .input_box_tel3_ec,
  html body #view-shipping-information input[name*="tel01"],
  html body #view-shipping-information input[name*="tel02"],
  html body #view-shipping-information input[name*="tel03"],
  html body #view-billing-information input[name*="tel01"]:not(.lp-tel-unified),
  html body #view-billing-information input[name*="tel02"],
  html body #view-billing-information input[name*="tel03"] {
    flex: 1 1 0 !important;
    width: auto !important;
    min-width: 80px !important;
    max-width: 140px !important;
    text-align: center !important;
    letter-spacing: 0.05em !important;
    display: inline-block !important;
    box-sizing: border-box !important;
  }

  html body tr[class*="input_tel"] .form_group_ec span,
  html body tr[class*="input_tel"] .form_group_ec > p > span,
  html body #view-shipping-information tr[class*="tel"] .form_group_ec span,
  html body #view-shipping-information tr[class*="tel"] .form_group_ec > p > span {
    flex: 0 0 auto !important;
    font-size: 14px !important;
    color: #555 !important;
    padding: 0 2px !important;
    white-space: nowrap !important;
    display: inline-block !important;
    width: auto !important;
    min-width: 0 !important;
  }

  html body tr[class*="input_tel"] .form_group_ec br,
  html body #view-shipping-information tr[class*="tel"] .form_group_ec br,
  html body #view-billing-information tr[class*="tel"] .form_group_ec br {
    display: none !important;
  }
}

@media screen and (max-width: 750px) {
  html body div.input_name_sp_ec > .form_group_sp_ec > input:only-of-type,
  html body div.input_kana_sp_ec > .form_group_sp_ec > input:only-of-type,
  html body #view-shipping-information div.input_name_sp_ec > .form_group_sp_ec > input:only-of-type,
  html body #view-shipping-information div.input_kana_sp_ec > .form_group_sp_ec > input:only-of-type,
  html body #view-billing-information div.input_name_sp_ec > .form_group_sp_ec > input:only-of-type,
  html body #view-billing-information div.input_kana_sp_ec > .form_group_sp_ec > input:only-of-type {
    flex: 1 1 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    text-align: left !important;
    padding: 0 12px !important;
  }

  html body div.input_name_sp_ec > .form_group_sp_ec > div:only-child,
  html body div.input_kana_sp_ec > .form_group_sp_ec > div:only-child {
    flex: 1 1 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
  html body div.input_name_sp_ec > .form_group_sp_ec > div:only-child > input,
  html body div.input_kana_sp_ec > .form_group_sp_ec > div:only-child > input {
    width: 100% !important;
    max-width: 100% !important;
    text-align: left !important;
    padding: 0 12px !important;
  }

  html body div.input_name_sp_ec input:not([type="checkbox"]):not([type="hidden"]):not([type="submit"]):not([type="button"]),
  html body div.input_kana_sp_ec input:not([type="checkbox"]):not([type="hidden"]):not([type="submit"]):not([type="button"]) {
    text-align: left !important;
  }
}

@media screen and (max-width: 750px) {
  html body div.input_tel_sp_ec > .form_group_sp_ec,
  html body div.input_tel_sp_ec > .form_group_sp_ec > p,
  html body #view-shipping-information div.input_tel_sp_ec > .form_group_sp_ec,
  html body #view-shipping-information div.input_tel_sp_ec > .form_group_sp_ec > p,
  html body #view-shipping-information div[class*="tel_sp_ec"] > .form_group_sp_ec,
  html body #view-shipping-information div[class*="tel_sp_ec"] > .form_group_sp_ec > p {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 4px !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  html body div.input_tel_sp_ec > .form_group_sp_ec > p,
  html body #view-shipping-information div.input_tel_sp_ec > .form_group_sp_ec > p {
    padding: 0 !important;
  }

  html body div.input_tel_sp_ec input[name*="tel01"],
  html body div.input_tel_sp_ec input[name*="tel02"],
  html body div.input_tel_sp_ec input[name*="tel03"],
  html body div.input_tel_sp_ec .input_box_tel1_sp_ec,
  html body div.input_tel_sp_ec .input_box_tel2_sp_ec,
  html body div.input_tel_sp_ec .input_box_tel3_sp_ec,
  html body #view-shipping-information input[name*="tel01"],
  html body #view-shipping-information input[name*="tel02"],
  html body #view-shipping-information input[name*="tel03"] {
    flex: 1 1 0 !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 100% !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }

  html body div.input_tel_sp_ec .form_group_sp_ec span:not(.form_required_sp_ec):not(.form_required_ec),
  html body #view-shipping-information div[class*="tel"] span:not(.form_required_sp_ec):not(.form_required_ec) {
    flex: 0 0 auto !important;
    font-size: 12px !important;
    padding: 0 1px !important;
    color: #555 !important;
    white-space: nowrap !important;
  }
}

@media screen and (max-width: 750px) {
  html body .amazon_pay_subtitle_ec,
  html body .amazon_pay_subtitle_sp_ec,
  html body #view-payment-information .amazon_pay_subtitle_ec,
  html body #view-payment-information .amazon_pay_subtitle_sp_ec,
  html body div[class*="amazon_pay_subtitle"] {
    display: block !important;
    margin: 10px 0 !important;
    padding: 0 !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: #555 !important;
    text-align: left !important;
    background: transparent !important;
    font-weight: normal !important;
  }

  html body select[name="order[payment_method_id]"] + p,
  html body select[name="order[payment_method_id]"] + div:not([id]):not([class*="amazon_pay_box"]),
  html body #payment_method_id + p,
  html body #payment_method_id + div:not([id]):not([class*="amazon_pay_box"]) {
    margin: 8px 0 0 0 !important;
    padding: 0 !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: #555 !important;
  }

  html body #view-payment-information > .form_group_sp_ec {
    padding-bottom: 16px !important;
  }
}

@media screen and (max-width: 750px) {
  html body form:has(.submit_sp_ec) .submit_ec,
  html body .form_main_container_sp_ec:has(.submit_sp_ec) .submit_ec,
  html body .form_container_sp_ec:has(.submit_sp_ec) .submit_ec,
  html body .lp-form-section-outer:has(.submit_sp_ec) .submit_ec {
    display: none !important;
  }

  html body .submit_sp_ec ~ .submit_ec,
  html body .submit_sp_ec + .submit_ec {
    display: none !important;
  }

  html body form .submit_ec:has(~ .submit_sp_ec) {
    display: none !important;
  }
}

@media screen and (max-width: 750px) {
  html body div.input_shipping_address_id_sp_ec {
    display: block !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
    border-bottom: 1px solid #e8e8e8 !important;
    box-sizing: border-box !important;
    width: 100% !important;
  }

  html body div.input_shipping_address_id_sp_ec > .form_box_label_sp_ec {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    flex: none !important;
    width: auto !important;
    max-width: 100% !important;
    padding: 18px 16px 10px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #2c2c2c !important;
    line-height: 1.4 !important;
  }

  html body div.input_shipping_address_id_sp_ec > .form_group_sp_ec {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 16px 18px 16px !important;
    margin: 0 !important;
    background: transparent !important;
    box-sizing: border-box !important;
  }

  html body div.input_shipping_address_id_sp_ec select {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    display: block !important;
    box-sizing: border-box !important;
  }
}

html body tr.input_name_ec .form_group_ec .col-12,
html body tr.input_kana_ec .form_group_ec .col-12 {
  flex: 1 1 0 !important;
  max-width: 100% !important;
  min-width: 0 !important;
  width: auto !important;
  padding: 0 !important;
  margin: 0 !important;
}

html body tr.input_name_ec .form_group_ec .col-12 input:not([type="hidden"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]),
html body tr.input_kana_ec .form_group_ec .col-12 input:not([type="hidden"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]) {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

html body tr.input_name_ec .form_group_ec .col-12:empty,
html body tr.input_kana_ec .form_group_ec .col-12:empty {
  display: none !important;
}

html body tr.input_name_ec .form_group_ec .col-12:not(:has(input)):not(:has(p)),
html body tr.input_kana_ec .form_group_ec .col-12:not(:has(input)):not(:has(p)) {
  display: none !important;
}

@media screen and (max-width: 750px) {
  html body div.input_tel_sp_ec input:not([type="checkbox"]):not([type="hidden"]):not([type="submit"]):not([type="button"]),
  html body div.input_tel_sp_ec .form_group_sp_ec input,
  html body div.input_tel_sp_ec .form_group_sp_ec > p > input,
  html body div.input_tel_sp_ec input[name*="tel"] {
    text-align: left !important;
    padding: 0 10px !important;
  }

  html body .lp-tel-unified,
  html body input.lp-tel-unified {
    text-align: left !important;
    padding: 0 10px !important;
  }

  html body #view-shipping-information input[name*="tel01"],
  html body #view-shipping-information input[name*="tel02"],
  html body #view-shipping-information input[name*="tel03"],
  html body #view-shipping-information input[name*="tel"] {
    text-align: left !important;
  }
}

html body input.input_box_name1_ec:not([type="hidden"]),
html body input#order_billing_address_attributes_name1,
html body input#order_shipping_address_attributes_name1,
html body input.input_box_name2_ec:not([type="hidden"]),
html body input#order_billing_address_attributes_name2,
html body input#order_shipping_address_attributes_name2 {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

html body .lp-tel-unified,
html body input.lp-tel-unified,
html body input.lp-tel-unified.input_box_tel_ec,
html body input.input_box_tel_ec.lp-tel-unified {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  flex: 1 1 100% !important;
}

@media screen and (min-width: 751px) {
  html body tr.input_tel_ec input.input_box_tel_ec,
  html body tr.input_tel_ec input[name*="[tel01]"]:not(.input_box_tel1_ec):not(.input_box_tel2_ec):not(.input_box_tel3_ec) {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
}

@media screen and (min-width: 751px) {
  html body tr.input_birth_ec td .form_group_ec,
  html body tr.input_birth_ec .form_group_ec,
  html body tr.input_birth_ec > td,
  html body tr[class*="input_birth"] td .form_group_ec,
  html body tr[class*="input_birth"] .form_group_ec {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 20px 20px !important;
    box-sizing: border-box !important;
  }

  html body tr.input_birth_ec select,
  html body tr.input_birth_ec .form_group_ec select,
  html body tr[class*="input_birth"] select {
    flex: 1 1 0 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    display: inline-block !important;
    box-sizing: border-box !important;
  }

  html body tr.input_birth_ec span:not(.form_required_ec):not(.form_required_sp_ec),
  html body tr[class*="input_birth"] span:not(.form_required_ec):not(.form_required_sp_ec) {
    flex: 0 0 auto !important;
    font-size: 14px !important;
    color: #555 !important;
    white-space: nowrap !important;
    padding: 0 2px !important;
    margin: 0 !important;
  }

  html body tr.input_birth_ec br,
  html body tr[class*="input_birth"] br {
    display: none !important;
  }

  html body tr.input_birth_ec .form_group_ec > p,
  html body tr[class*="input_birth"] .form_group_ec > p {
    display: contents !important;
  }
}

@media screen and (min-width: 751px) {
  html body #view-billing-information table.landing_form_ec,
  html body #view-shipping-information table.landing_form_ec,
  html body #view-payment-information table.landing_form_ec,
  html body #view-customer-account-information table.landing_form_ec,
  html body #view-customer-information table.landing_form_ec,
  html body #lp-form-section table.landing_form_ec,
  html body .form_container_ec table.landing_form_ec,
  html body .form_main_container_ec table.landing_form_ec,
  html body form#new-view table.landing_form_ec,
  html body form#login-view table.landing_form_ec {
    max-width: 700px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  html body #view-billing-information,
  html body #view-shipping-information,
  html body #view-payment-information,
  html body #view-customer-account-information,
  html body #view-customer-information {
    max-width: 100% !important;
    width: 100% !important;
  }
}

@media screen and (min-width: 751px) {
  html body table.landing_form_ec tr.input_name_ec .form_group_ec,
  html body table.landing_form_ec tr.input_kana_ec .form_group_ec {
    display: flex !important;
    flex-direction: row !important;
    gap: 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
  }

  html body table.landing_form_ec tr.input_name_ec .form_group_ec .col-12:empty,
  html body table.landing_form_ec tr.input_kana_ec .form_group_ec .col-12:empty {
    display: none !important;
  }

  html body table.landing_form_ec tr.input_name_ec .form_group_ec .col-12:not(:has(input:not([type="hidden"]))),
  html body table.landing_form_ec tr.input_kana_ec .form_group_ec .col-12:not(:has(input:not([type="hidden"]))) {
    display: none !important;
  }

  html body table.landing_form_ec tr.input_name_ec .form_group_ec .col-12,
  html body table.landing_form_ec tr.input_kana_ec .form_group_ec .col-12 {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    max-width: 100% !important;
    width: auto !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  html body table.landing_form_ec tr.input_name_ec .form_group_ec .col-12 > p,
  html body table.landing_form_ec tr.input_kana_ec .form_group_ec .col-12 > p {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
  }

  html body table.landing_form_ec tr.input_name_ec .form_group_ec .col-12 input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]),
  html body table.landing_form_ec tr.input_kana_ec .form_group_ec .col-12 input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]) {
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  html body table.landing_form_ec tr.input_tel_ec .form_group_ec,
  html body table.landing_form_ec tr.input_tel_ec .form_group_ec > p {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  html body table.landing_form_ec tr.input_tel_ec input.lp-tel-unified,
  html body table.landing_form_ec tr.input_tel_ec input.input_box_tel_ec.lp-tel-unified,
  html body table.landing_form_ec tr.input_tel_ec input.input_box_tel_ec,
  html body table.landing_form_ec tr.input_tel_ec .lp-tel-unified,
  html body table.landing_form_ec tr.input_tel_ec .form_group_ec input[name*="tel01"]:not(.input_box_tel1_ec):not(.input_box_tel2_ec):not(.input_box_tel3_ec) {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: none !important;
    display: block !important;
    box-sizing: border-box !important;
  }
}

@media screen and (min-width: 751px) {
  html body input.input_box_zip_ec[name*="[zip01]"],
  html body input[name="order[billing_address_attributes][zip01]"],
  html body input[name="order[shipping_address_attributes][zip01]"],
  html body input#order_billing_address_attributes_zip01,
  html body input#order_shipping_address_attributes_zip01,
  html body tr.input_zip_ec td input.input_box_zip_ec[name*="[zip01]"],
  html body tr.input_postal_ec td input.input_box_zip_ec[name*="[zip01]"] {
    width: 130px !important;
    max-width: 130px !important;
    min-width: 130px !important;
    flex: 0 0 130px !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    flex-basis: 130px !important;
  }
}

@media screen and (max-width: 750px) {
  html body input.input_box_zip_ec[name*="[zip01]"],
  html body input[name="order[billing_address_attributes][zip01]"],
  html body input[name="order[shipping_address_attributes][zip01]"],
  html body tr.input_zip_ec td input.input_box_zip_ec[name*="[zip01]"],
  html body tr.input_postal_ec td input.input_box_zip_ec[name*="[zip01]"] {
    width: 100px !important;
    max-width: 100px !important;
    min-width: 100px !important;
    flex: 0 0 100px !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    flex-basis: 100px !important;
  }

  html body input.input_box_zip2_ec,
  html body input.input_box_zip_ec[name*="[zip02]"],
  html body input[name="order[billing_address_attributes][zip02]"],
  html body input[name="order[shipping_address_attributes][zip02]"],
  html body tr.input_zip_ec td input.input_box_zip2_ec,
  html body tr.input_zip_ec td input[name*="[zip02]"],
  html body tr.input_postal_ec td input.input_box_zip2_ec,
  html body tr.input_postal_ec td input[name*="[zip02]"] {
    width: 100px !important;
    max-width: 100px !important;
    min-width: 100px !important;
    flex: 0 0 100px !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    flex-basis: 100px !important;
  }
}

@media screen and (max-width: 750px) {
  html body input.input_box_zip1_sp_ec,
  html body div.input_zip_sp_ec input.input_box_zip1_sp_ec,
  html body div.input_zip_sp_ec > .form_group_sp_ec input.input_box_zip1_sp_ec,
  html body div.input_zip_sp_ec > .form_group_sp_ec > p > input.input_box_zip1_sp_ec {
    flex: 0 0 80px !important;
    width: 80px !important;
    max-width: 80px !important;
    min-width: 80px !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    flex-basis: 80px !important;
  }
}

@media screen and (max-width: 750px) {

  html body .lp-form-section-outer .submit_ec {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    pointer-events: none !important;
  }

  html body .lp-form-section-outer .submit_sp_ec {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    margin: 24px auto 0 !important;
    padding: 0 !important;
    pointer-events: auto !important;
  }

  html body .lp-form-section-outer .submit_sp_ec input[type="submit"],
  html body .lp-form-section-outer .submit_sp_ec button[type="submit"] {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    max-width: 520px !important;
    margin: 0 auto !important;
    pointer-events: auto !important;
  }

  html body .lp-form-section-outer .submit_sp_ec input[type="submit"]:not(:last-of-type),
  html body .lp-form-section-outer .submit_sp_ec button[type="submit"]:not(:last-of-type) {
    display: none !important;
  }
}

html body .login_message_ec,
html body .login_message_sp_ec,
html body form#login-view .login_message_ec,
html body form.form_main_container_ec .login_message_ec,
html body .form_container_ec .login_message_ec {
  max-width: 700px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 20px 24px !important;
  box-sizing: border-box !important;
}

html body .login_message_ec > p,
html body .login_message_sp_ec > p,
html body form#login-view .login_message_ec > p {
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  color: #555 !important;
  text-align: left !important;
  word-break: break-word !important;
  overflow-wrap: break-word !important;
  box-sizing: border-box !important;
}

html body form#login-view,
html body form.form_main_container_ec#login-view {
  max-width: 700px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}

@media screen and (max-width: 750px) {
  html body .login_message_ec,
  html body .login_message_sp_ec,
  html body form#login-view .login_message_ec,
  html body form.form_main_container_ec .login_message_ec {
    max-width: calc(100% - 24px) !important;
    margin: 12px !important;
    padding: 14px 16px !important;
  }

  html body .login_message_ec > p,
  html body .login_message_sp_ec > p {
    font-size: 13px !important;
    line-height: 1.6 !important;
  }

  html body form#login-view,
  html body form.form_main_container_ec#login-view {
    max-width: 100% !important;
  }
}

html body form#login-view table.landing_form_ec,
html body form.form_main_container_ec#login-view table.landing_form_ec,
html body .login_message_ec table.landing_form_ec,
html body .login_message_sp_ec table.landing_form_ec {
  max-width: 700px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

html body form#login-view .submit_ec,
html body form.form_main_container_ec#login-view .submit_ec,
html body .login_message_ec .submit_ec,
html body .login_message_sp_ec .submit_ec {
  max-width: 700px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}

html body tr.input_password_ec td .form_group_ec::after,
html body tr[class*="password"] td .form_group_ec::after {
  content: 'マイページのログインに使用するパスワードです';
  display: block !important;
  width: 100% !important;
  margin-top: 8px !important;
  padding: 0 !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
  color: #666 !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
}

@media screen and (max-width: 750px) {
  html body div.input_password_sp_ec .form_group_sp_ec::after,
  html body div[class*="input_password"] .form_group_sp_ec::after {
    content: 'マイページのログインに使用するパスワードです';
    display: block !important;
    width: 100% !important;
    margin-top: 6px !important;
    padding: 0 !important;
    font-size: 11px !important;
    line-height: 1.5 !important;
    color: #666 !important;
    font-weight: 500 !important;
    letter-spacing: 0.02em !important;
  }
}

html body #lp-form-section .lp-login-complete-message,
html body #lp-form-section .lp-login-message-position-fix {
  display: block !important;
  width: 100% !important;
  max-width: 700px !important;
  margin: 8px auto !important;
  padding: 0 16px !important;
  box-sizing: border-box !important;
  text-align: left !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
  color: #666 !important;
  background: transparent !important;
  float: none !important;
  clear: both !important;
}

@media screen and (max-width: 750px) {
  html body #lp-form-section .lp-login-complete-message,
  html body #lp-form-section .lp-login-message-position-fix {
    max-width: 100% !important;
    padding: 0 12px !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
  }
}

html body .lp-saved-card-patch-popup {
  position: fixed !important;
  left: 50% !important;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 20px) !important;
  transform: translateX(-50%) translateY(18px) !important;
  width: calc(100% - 32px) !important;
  max-width: 520px !important;
  padding: 18px 18px 16px !important;
  box-sizing: border-box !important;
  border-radius: 14px !important;
  background: #ffffff !important;
  border: 1px solid #e0174a !important;
  box-shadow: 0 8px 28px rgba(0, 0, 0, .16) !important;
  z-index: 99999 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .25s ease, transform .25s ease !important;
}

html body .lp-saved-card-patch-popup.is-visible {
  opacity: 1 !important;
  transform: translateX(-50%) translateY(0) !important;
  pointer-events: auto !important;
}

html body .lp-saved-card-patch-popup__close {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 50% !important;
  background: #f4f4f4 !important;
  color: #555 !important;
  font-size: 18px !important;
  line-height: 28px !important;
  text-align: center !important;
  cursor: pointer !important;
  font-family: inherit !important;
}

html body .lp-saved-card-patch-popup__title {
  margin: 0 34px 8px 0 !important;
  padding: 0 !important;
  color: #e0174a !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  font-weight: 800 !important;
}

html body .lp-saved-card-patch-popup__card {
  margin: 8px 0 10px !important;
  padding: 12px 14px !important;
  box-sizing: border-box !important;
  border-radius: 8px !important;
  background: #fff5f7 !important;
  border: 1px solid #f0c8d2 !important;
  color: #222 !important;
  font-size: 16px !important;
  line-height: 1.5 !important;
  font-weight: 800 !important;
  letter-spacing: .03em !important;
  word-break: break-word !important;
}

html body .lp-saved-card-patch-popup__text {
  margin: 0 !important;
  padding: 0 !important;
  color: #333 !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
  font-weight: 500 !important;
}

@media screen and (max-width: 750px) {
  html body .lp-saved-card-patch-popup {
    bottom: calc(env(safe-area-inset-bottom, 0px) + 14px) !important;
    width: calc(100% - 24px) !important;
    max-width: none !important;
    padding: 16px 16px 14px !important;
    border-radius: 12px !important;
  }
  html body .lp-saved-card-patch-popup__title {
    font-size: 14px !important;
  }
  html body .lp-saved-card-patch-popup__card {
    font-size: 14px !important;
  }
  html body .lp-saved-card-patch-popup__text {
    font-size: 12px !important;
  }
}

html body #alert-box,
html body .alert_ec,
html body .alert-danger_ec,
html body .alert_ec.alert-danger_ec,
html body div#alert-box.alert_ec.alert-danger_ec {
  display: block !important;
  position: static !important;
  width: 100% !important;
  max-width: 700px !important;
  margin: 16px auto !important;
  padding: 14px 20px !important;
  box-sizing: border-box !important;
  background: #fff0f4 !important;
  border: 2px solid #e0174a !important;
  border-radius: 8px !important;
  color: #c4003a !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.6 !important;
  text-align: center !important;
  letter-spacing: 0.02em !important;
  box-shadow: 0 2px 8px rgba(224, 23, 74, 0.15) !important;
  float: none !important;
  clear: both !important;
}

html body #alert-box p,
html body .alert_ec p,
html body .alert-danger_ec p,
html body .alert_ec.alert-danger_ec p,
html body div#alert-box.alert_ec.alert-danger_ec p {
  margin: 0 !important;
  padding: 0 !important;
  color: #c4003a !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.6 !important;
  text-align: center !important;
  background: transparent !important;
}

html body #alert-box::before,
html body .alert_ec.alert-danger_ec::before {
  content: '⚠ ';
  display: inline-block;
  margin-right: 6px;
  color: #e0174a;
  font-size: 16px;
  font-weight: 900;
}

@media screen and (max-width: 750px) {
  html body #alert-box,
  html body .alert_ec.alert-danger_ec {
    max-width: calc(100% - 24px) !important;
    margin: 14px 12px !important;
    padding: 12px 14px !important;
    font-size: 13px !important;
  }
  html body #alert-box p,
  html body .alert_ec.alert-danger_ec p {
    font-size: 13px !important;
  }
}

@media screen and (max-width: 750px) {
  html body .lp-email-already-used-error,
  html body .lp-email-already-used-error .formErrorContent {
    z-index: 2147483647 !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    overflow: visible !important;
  }

  html body .lp-email-already-used-error .formErrorContent {
    position: relative !important;
  }
}

.popup-overlay,
.popup-overlay.active {
  pointer-events: none !important;
  z-index: 999 !important;
}

.plan-section {
  position: relative !important;
  z-index: 1001 !important;
}

.purchase-popup {
  z-index: 1002 !important;
}

/* TikTok広告審査対策：割引訴求バナーの画像差し替え版 */
.top-banner--image {
  display: block;
  width: 100%;
  max-width: 750px;
  min-height: 0;
  line-height: 0;
  margin: 0 auto;
  overflow: hidden;
}
.top-banner--image img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 750px;
  margin: 0 auto;
}