/* SMBC Web Form - Custom Styles */

.logo_wrap {
  width: 100%;
  margin: 0 0 10px;
}
.logo_wrap .logo {
  max-width: 1008px;
  margin: 0 auto;
}
.logo_wrap .logo a,
.logo_wrap .logo img {
  display: block;
}
.main-content-wrap {
  max-width: 1008px;
  margin: 0 auto;
}
.hero-image {
  display: block;
  width: calc(100% - 20px);
  margin: 0 10px;
  height: auto;
}
.a24-block p.exp {
  margin: 14px 0 12px;
  padding: 0 0 10px;
  border-bottom: 1px dotted #ccc;
}
.a24-inline {
  margin-bottom: 10px;
}
.a24-inline label {
  margin-right: 10px;
}
.a24-grid {
  max-width: 200px;
}
.a24-grid label {
  display: block;
  margin-bottom: 12px;
}
.a24-grid select {
  width: 100%;
  box-sizing: border-box;
  margin-top: 0;
}
.privacy-box {
  margin: 24px 0;
  line-height: 1.75;
}
td.detail.input02.privacy-box {
  padding: 0;
}
.privacy-box .privacy-emphasis {
  font-weight: 700;
}
tr.privacy-row {
  border-right: none;
  border-left: none;
}
.confirm-note {
  text-align: center;
  margin: 14px;
  font-weight: 400;
}
.confirm-submit-wrap {
  text-align: center;
  margin-bottom: 24px;
}
.confirm-submit-btn {
  background: #9a9a9a;
  color: #ffffff;
  border: 1px solid #9a9a9a;
  border-radius: 3px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  width: 168px;
  height: 48px;
  padding: 10px;
  cursor: pointer;
}
.confirm-submit-btn.is-enabled {
  background: #f58220;
  border-color: #f58220;
}
.confirm-submit-btn:disabled {
  opacity: 1;
  cursor: default;
}
#accA01 {
  overflow: hidden;
  transition: height 0.55s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.3s ease;
  height: 0;
  opacity: 1;
  will-change: height;
}
#accA01.is-collapsed {
  opacity: 0;
  height: 0;
}
.optionalIcon,
.optionalIcon--highlight {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  line-height: 19px;
  font-family: メイリオ, Meiryo, Arial, Helvetica, sans-serif;
  color: rgb(255, 255, 255);
  background-color: rgb(127, 127, 127);
  padding: 1px 5px 0 5px;
  margin: 0 3px 0 8px;
  border-radius: 2px;
}
td.detail.input02.a24-block.radio-container {
  padding: 20px;
}
.input-date-width {
  width: 70px;
  max-width: 70px;
  box-sizing: border-box;
}
.input-zip-width {
  width: 188px;
  max-width: 188px;
  box-sizing: border-box;
}
.detail .custom-controls .custom .sc-formfield-input {
  margin-bottom: 4px;
}
.detail .custom-controls .custom .sc-formfield-input:last-child {
  margin-bottom: 0;
}
.detail .checkbox-two-col .col .sc-formfield-input {
  margin-bottom: 4px;
}
.detail .checkbox-two-col .col .sc-formfield-input:last-child {
  margin-bottom: 0;
}
.detail .checkbox-two-col {
  display: flex;
  width: 520px;
  max-width: 100%;
  justify-content: space-between;
  gap: 0;
}
.detail .checkbox-two-col .col {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.a23-textarea {
  width: 100%;
  min-height: 74px;
  box-sizing: border-box;
}
#form input[name="text100"].a23-like-input {
  width: 100% !important;
  height: 34px;
  border: 1px solid #999;
  box-sizing: border-box;
}
/* 推奨度ラジオボタンのクリック可能にする修正（external.cssのz-index: -1を上書き） */
[class^="radioList"] .input input[class^="customRadio"] {
  left: -9999px !important;
  z-index: 1 !important;
}

/* 性別・A17専用コンテナスタイル（radioListを持たない） */
td.detail.input02.radio-container:not(:has([class^="radioList"])) {
  padding: 12px 20px 12px 15px;
  font-size: 14px;
  font-family: メイリオ, Meiryo, Arial, Helvetica, sans-serif;
  color: #333333;
  background: #fff;
}

/* 性別・A17のラジオボタンinput要素（推奨度を除外） */
td.detail.input02.radio-container:not(:has([class^="radioList"])) .radio-label input[type="radio"],
td.detail.input02.radio-container:not(:has([class^="radioList"])) input[type="radio"].customRadio01 {
  width: 18px;
  height: 18px;
  min-width: 18px;
  min-height: 18px;
  margin: 0 6px 0 0;
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid #999;
  border-radius: 50%;
  background: #fff;
  box-shadow: none;
  box-sizing: border-box;
  vertical-align: middle;
}

/* 性別・A17のラジオボタン選択時（推奨度を除外） */
td.detail.input02.radio-container:not(:has([class^="radioList"])) .radio-label input[type="radio"]:checked,
td.detail.input02.radio-container:not(:has([class^="radioList"])) input[type="radio"].customRadio01:checked {
  background: radial-gradient(circle at center, #333 0, #333 5px, #fff 5px);
}

/* 性別・A17のラベルスタイル（推奨度を除外） */
td.detail.input02.radio-container:not(:has([class^="radioList"])) .radio-label {
  font-size: 14px;
  font-family: メイリオ, Meiryo, Arial, Helvetica, sans-serif;
  color: #333333;
  margin: 0 14px 0 0;
  padding: 5px 30px 5px 8px;
  background: transparent;
}
.error {
  border-color: #f00 !important;
}
.error-message,
.maildel {
  color: #f00;
  font-size: 14px;
  margin-top: 0;
  margin-bottom: 8px;
  line-height: 1.75;
}
.maildel {
  white-space: normal;
  word-wrap: break-word;
}
