@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:900");
/* -------------------------
  form
------------------------- */
html:not(.is-jsEnable) .formContent {
  display: none;
}
html:not(.is-jsEnable) .noJsText {
  padding: 40px 0;
  text-align: center;
}

body {
  padding-top: 0;
}

.header {
  position: relative;
}
.header__logo {
  margin: auto;
}

.gnav,
.footer {
  display: none;
}

@media (max-width: 768px) {
  .header {
    height: 50px;
    min-height: auto;
  }
}
/* -------------------------
  formContent
------------------------- */
.formContent {
  padding: 100px 0;
  background: url(../img/form/content_bg_form.png);
}
.formContent__lead {
  margin: 0 0 20px;
  color: #004ea2;
  font-size: 2.2rem;
  font-weight: 600;
  text-align: center;
}
.formContent__attn {
  max-width: 800px;
  margin: 0 auto 20px;
  padding: 23px 15px;
  border: 1px solid;
  color: #004ea2;
  font-size: 1.6rem;
  font-weight: 400;
  text-align: center;
}
.formContent__sublead {
  margin: 0 0 20px;
  font-size: 1.7rem;
  text-align: center;
}
form[name="formset"] {
  margin-top: 100px;
}
.formContent__box,
.formContent__box--electrical,
.formContent__box--gas {
  padding: 40px;
  background: #fff;
  border-radius: 15px;
  text-align: center;
}
.formContent__box a,
.formContent__box--electrical a,
.formContent__box--gas a {
  text-decoration: underline;
}
.formContent__box a:hover,
.formContent__box--electrical a:hover,
.formContent__box--gas a:hover {
  text-decoration: none;
}
.formContent__box a[target="_blank"]::after,
.formContent__box--electrical a[target="_blank"]::after,
.formContent__box--gas a[target="_blank"]::after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 0.8em;
  width: 0.8em;
  margin: -0.25em 10px 0 5px;
  background: url(../img/icon_blank.png) no-repeat 50% 50% / contain;
}
.formContent__box--electrical .formContent__box__title {
  background-color: #f57a00;
}
.formContent__box--electrical .formBox > dt {
  background-color: rgba(245, 122, 0, 0.15);
}
.formContent__box--electrical input[type="radio"]:checked + label::before {
  background-image: url(../img/form/icon_radio_on_electrical.svg);
}
.formContent__box--electrical input[type="checkbox"]:checked + label::before {
  background-image: url(../img/form/icon_checkbox_on_electrical.svg);
}
.formContent__box--gas .formBox__small,
.formContent__box--gas .formBox__planName,
.formContent__box--gas .formSimpleBox > dt {
  color: #009dd8;
}
.formContent__box--gas .formContent__box__title,
.formContent__box--gas .formBox__planName__main {
  background-color: #009dd8;
}
.formContent__box--gas .formBox > dt {
  background-color: #e5f8ff;
}
.formContent__box--gas input[type="radio"]:checked + label::before {
  background-image: url(../img/form/icon_radio_on_gas.svg);
}
.formContent__box--gas input[type="checkbox"]:checked + label::before {
  background-image: url(../img/form/icon_checkbox_on_gas.svg);
}
.formContent__box:not(:last-child),
.formContent__box--electrical:not(:last-child),
.formContent__box--gas:not(:last-child) {
  margin-bottom: 110px;
}
.formContent__box__item:not(:last-child) {
  margin-bottom: 30px;
}
.formContent__box__title {
  display: block;
  width: 570px;
  margin: -40px auto 20px;
  padding: 12px 25px;
  background: #004ea2;
  border-radius: 50px;
  color: #fff;
  font-size: 2.2rem;
  font-weight: 700;
  text-align: center;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}
.formContent__box__subtitle {
  margin: 0 0 20px;
  color: #004ea2;
  font-size: 1.8rem;
  font-weight: 600;
  text-align: left;
}
.formContent__box__lead {
  margin: 0 0 50px;
  font-size: 1.6rem;
  font-weight: 600;
  text-align: center;
}
.formContent__note {
  margin: 10px 0 0;
  padding: 0 0 0 1.2em;
  font-size: 1.2rem;
  letter-spacing: normal;
  text-align: left;
}
.formContent__note::before {
  content: "※";
  margin: 0 0 0 -1.2em;
}
.formContent__note:not(:last-child) {
  margin-bottom: 5px;
}
.formContent__note + .formContent__note {
  margin-top: 5px;
}
.formContent__attention {
  margin-bottom: 10px;
  color: #da2135;
}
.formContent__strong {
  color: #da2135;
}
.formContent__agree {
  list-style: none;
}
.formContent__agree:not(:last-child) {
  margin-bottom: 30px;
}
.formContent__agree > li:not(:last-child) {
  margin-bottom: 10px;
}
.formContent__submitArea {
  text-align: center;
}
.formContent__submitArea__text {
  margin: 30px 0 0;
  font-size: 1.6rem;
  font-weight: 600;
  text-align: center;
}
.formContent__submitBtn,
.formContent__submitBtn--back,
.formContent__submitBtn--go {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  width: 400px;
  padding: 27px 35px;
  background: #004ea2;
  border: none;
  border-radius: 15px;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.15em;
  -webkit-box-shadow: 0 6px 0 #003e80;
  box-shadow: 0 6px 0 #003e80;
  outline: none;
}
.formContent__submitBtn::after,
.formContent__submitBtn--back::after,
.formContent__submitBtn--go::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 23px;
  width: 12px;
  height: 12px;
  border-right: 3px solid;
  border-bottom: 3px solid;
  margin-top: -8px;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.formContent__submitBtn:hover,
.formContent__submitBtn--back:hover,
.formContent__submitBtn--go:hover {
  background: #0067d5;
}
.formContent__submitBtn.is-disabled,
.is-disabled.formContent__submitBtn--back,
.is-disabled.formContent__submitBtn--go {
  background: #666;
  -webkit-box-shadow: none;
  box-shadow: none;
  color: #eee;
  opacity: 0.6;
  cursor: default;
}
.formContent__submitBtn--back {
  width: 200px;
  background: #666;
  -webkit-box-shadow: 0 6px 0 #444;
  box-shadow: 0 6px 0 #444;
}
.formContent__submitBtn--back::after {
  right: auto;
  left: 23px;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}
.formContent__submitBtn--back:hover {
  background: gray;
}
.formContent__submitBtn--go {
  background: #da2135;
  -webkit-box-shadow: 0 6px 0 #b31b2a;
  box-shadow: 0 6px 0 #b31b2a;
}
.formContent__submitBtn--go:hover {
  background: #e44a5b;
}

@media (max-width: 768px) {
  .formContent {
    padding: 65px 0;
    background-size: 100px;
  }
  .formContent__lead {
    font-size: 1.6rem;
  }
  .formContent__attn {
    margin: 0 auto 80px;
    padding: 10px 15px;
    font-size: 1.4rem;
  }
  .formContent__box,
  .formContent__box--electrical,
  .formContent__box--gas {
    padding: 25px 10px;
  }
  .formContent__box:not(:last-child),
  .formContent__box--electrical:not(:last-child),
  .formContent__box--gas:not(:last-child) {
    margin-bottom: 60px;
  }
  .formContent__box__item:not(:last-child) {
    margin-bottom: 20px;
  }
  .formContent__box__title {
    display: block;
    width: auto;
    margin: -25px 0 -10px;
    padding: 15px 8px;
    border-radius: 15px;
    font-size: 1.6rem;
  }
  .formContent__box__subtitle {
    margin: 0 0 15px;
    font-size: 1.5rem;
  }
  .formContent__box__lead {
    margin: 0 0 15px;
    font-size: 1.4rem;
  }
  .formContent__note {
    font-size: 1.1rem;
  }
  .formContent__submitArea__text {
    margin: 15px 0 0;
    font-size: 1.4rem;
  }
  .formContent__submitBtn,
  .formContent__submitBtn--back,
  .formContent__submitBtn--go {
    display: block;
    width: 100%;
    margin: 0 0 15px;
    padding: 15px 25px 15px 15px;
    border-radius: 10px;
    font-size: 1.6rem;
  }
  .formContent__submitBtn::after,
  .formContent__submitBtn--back::after,
  .formContent__submitBtn--go::after {
    right: 15px;
    width: 10px;
    height: 10px;
    border-right: 2px solid;
    border-bottom: 2px solid;
    margin-top: -6px;
  }
  .formContent__submitBtn--back::after {
    left: 15px;
  }
}
/* -------------------------
  formBox
------------------------- */
.formBox {
  display: table;
  width: 100%;
  margin: 0 0 -1px;
  border: 1px solid #dedede;
  text-align: left;
}
.formBox > dt {
  position: relative;
  display: table-cell;
  vertical-align: top;
  width: 340px;
  padding: 30px;
  background: #edf3fa;
  font-size: 1.6rem;
  font-weight: bold;
}
.formBox > dt .small {
  display: inline-block;
  font-size: 1.4rem;
}
.formBox > dt strong {
  display: none;
}
.formBox > dd {
  display: table-cell;
  vertical-align: top;
  padding: 25px 30px;
  background: #fff;
  font-size: 1.5rem;
}
.formBox > dd div {
  padding-top: 5px;
  padding-bottom: 5px;
}
.formBox > dd div.formContent__note {
  margin: 0;
}
.formBox > dd div.formBox__powList {
  padding: 15px;
}
.formBox > dd .formBox:not(:first-child) {
  margin-top: 15px;
}
.formBox > dd .formBox > dt {
  width: 200px;
  padding: 15px 60px 15px 15px;
}
.formBox > dd .formBox > dt::after {
  top: 15px;
  right: 15px;
}
.formBox > dd .formBox > dd {
  padding: 15px;
}
.formBox__small {
  display: block;
  margin: 0 0 12px;
  padding: 6px;
  border: 1px solid;
  border-radius: 5px;
  color: #f57a00;
  font-size: 1.2rem;
  font-weight: 600;
  text-align: center;
}
.formBox__inputText {
  display: inline-block;
}
.formBox__confirmText:not(:last-child) {
  margin-right: 10px;
}
.formBox__helpBtn {
  position: absolute;
  right: 87px;
  top: 30px;
}
.formBox__powList {
  padding: 30px;
  border: 1px solid #dedede;
}
.formBox__planName {
  color: #f57a00;
  font-size: 1.4rem;
  font-weight: 600;
  text-align: right;
}
.formBox__planName__main {
  display: block;
  margin: 0 0 10px;
  padding: 10px;
  background: #f57a00;
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
}
.formBox__planName:not([style*="none"]) + *:not([style*="none"]) {
  margin-top: 20px;
}
.formBox__noPlan__lead {
  font-size: 1.6rem;
  font-weight: bold;
}
.formBox__noPlan__text {
  font-size: 1.5rem;
}
.formBox__noPlan a {
  text-decoration: underline;
}
.formBox__noPlan a:hover {
  text-decoration: none;
}
.formBox__error {
  color: #e60012;
  margin-top: 0.5em;
}
.formBox.iconRequired > dt {
  padding-right: 110px;
}
.formBox.iconRequired > dt::after {
  content: "必須";
  position: absolute;
  right: 35px;
  top: 30px;
  padding: 6px 10px;
  background: #da2135;
  border-radius: 50px;
  color: #fff;
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1;
}
.formBox.l-agree:not(:first-child) {
  margin-top: 40px;
}
.formBox.l-agree > dt {
  width: 240px;
}

.formSimpleBox {
  display: table;
  width: 100%;
  text-align: left;
}
.formSimpleBox > dt {
  position: relative;
  display: table-cell;
  vertical-align: middle;
  width: 110px;
  padding: 15px;
  border: 1px solid;
  color: #f57a00;
  font-size: 1.3rem;
  font-weight: bold;
  text-align: center;
}
.formSimpleBox > dd {
  display: table-cell;
  vertical-align: middle;
  padding: 0 0 0 25px;
  font-size: 1.5rem;
}

@media (max-width: 768px) {
  .formBox {
    display: block;
  }
  .formBox > dt {
    display: block;
    width: auto;
    padding: 18px 15px;
    font-size: 1.4rem;
  }
  .formBox > dt .small {
    font-size: 1.1rem;
  }
  .formBox > dd {
    display: block;
    padding: 13px 15px;
    font-size: 1.4rem;
  }
  .formBox > dd div.formBox__powList {
    padding: 10px;
  }
  .formBox > dd .formBox > dt {
    width: auto;
    padding: 15px 60px 15px 15px;
  }
  .formBox > dd .formBox > dt::after {
    right: 10px;
  }
  .formBox > dd .formBox > dd {
    padding: 13px;
  }
  .formBox__helpBtn {
    right: 60px;
    top: 15px;
  }
  .formBox__powList {
    padding: 10px;
  }
  .formBox__planName__main {
    padding: 15px 10px;
    font-size: 1.4rem;
  }
  .formBox__noPlan__lead {
    font-size: 1.5rem;
  }
  .formBox__noPlan__text {
    font-size: 1.4rem;
  }
  .formBox.iconRequired > dt {
    padding-right: 85px;
  }
  .formBox.iconRequired > dt::after {
    right: 10px;
    top: 15px;
  }
  .formBox.l-agree:not(:first-child) {
    margin-top: 20px;
  }
  .formBox.l-agree > dt {
    width: auto;
  }

  .formSimpleBox {
    display: block;
  }
  .formSimpleBox > dt {
    display: block;
    width: auto;
    padding: 10px;
    font-size: 1.4rem;
  }
  .formSimpleBox > dd {
    display: block;
    padding: 10px 0 0;
    font-size: 1.4rem;
  }
}
/* -------------------------
  input
------------------------- */
input[type="text"] {
  width: 100%;
  padding: 8px;
  background: #fafafa;
  border: 1px solid #e6e6e6;
}
input[type="text"].is-error {
  color: #e60012;
}

input[type="text"]::-webkit-input-placeholder {
  color: #999;
}

input[type="text"]::-moz-placeholder {
  color: #999;
}

input[type="text"]:-ms-input-placeholder {
  color: #999;
}

select {
  width: 100%;
  padding: 8px;
  background: #fafafa;
  border: 1px solid #e6e6e6;
}
select.is-error {
  color: #e60012;
}

select::-ms-expand {
  display: none;
}

input[type="checkbox"],
input[type="radio"] {
  position: absolute;
  opacity: 0;
}
input[type="checkbox"] + label,
input[type="radio"] + label {
  position: relative;
  display: inline-block;
  min-height: 29px;
  padding: 5px 0 0 35px;
  cursor: pointer;
}
input[type="checkbox"] + label::before,
input[type="radio"] + label::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 2em;
  height: 2em;
  background: url(../img/form/icon_checkbox.svg) no-repeat 50% 50%/98%;
}
input[type="checkbox"]:checked + label::before,
input[type="radio"]:checked + label::before {
  background-image: url(../img/form/icon_checkbox_on.svg);
}
input[type="checkbox"].is-hidden,
input[type="radio"].is-hidden {
  pointer-events: none;
}
input[type="checkbox"].is-hidden + label,
input[type="radio"].is-hidden + label {
  pointer-events: none;
}
input[type="checkbox"].is-hidden + label a,
input[type="radio"].is-hidden + label a {
  pointer-events: auto;
}
input[type="checkbox"].is-hidden + label::before,
input[type="radio"].is-hidden + label::before {
  opacity: 0.5;
}
input[type="checkbox"]:not(:checked):disabled + label,
input[type="radio"]:not(:checked):disabled + label {
  cursor: default;
}
input[type="checkbox"]:not(:checked):disabled + label::before,
input[type="radio"]:not(:checked):disabled + label::before {
  background: #eee;
}

input[type="radio"] + label::before {
  background-image: url(../img/form/icon_radio.svg);
}
input[type="radio"]:checked + label::before {
  background-image: url(../img/form/icon_radio_on.svg);
}

.radioBtn,
.checkBtn {
  display: inline-block;
  padding: 5px 0;
}
.radioBtn:not(:last-child),
.checkBtn:not(:last-child) {
  margin-right: 5px;
}

@media (max-width: 768px) {
  .radioBtn,
  .checkBtn {
    padding: 2px 0;
  }
}
/* -------------------------
  layout
------------------------- */
.l-inputName .formBox__inputText {
  width: calc(70% - 3em);
}

.l-inputAddress .formBox__inputText {
  width: 6em;
}

.l-inputAddress2 .formBox__inputText {
  display: block;
}

.l-inputFree .formBox__inputText {
  width: calc(70% - 12em);
}

.l-inputCustomerNum .formBox__inputText {
  width: 50%;
}

.l-inputMail .formBox__inputText {
  width: 70%;
}

.l-inputTel .formBox__inputText {
  display: block;
  margin: 15px 0 0;
}

.l-inputPower .selectBox {
  display: inline-block;
  width: 12em;
}

.l-gasNowMenu {
  display: block;
  margin: 0 0 -5px -5px;
}
.l-gasNowMenu .radioBtn {
  margin: 0 0 5px 5px;
}

.l-supportSet .formBox__text {
  display: block;
}
.l-supportSet .radioBtn {
  margin-left: 1em;
}

.l-inputBirth [name*="irthYear"] {
  width: 6em;
}
.l-inputBirth [name*="irthMonth"],
.l-inputBirth [name*="irthDay"] {
  width: 4em;
}

.l-housemate:not(:last-child) {
  border-bottom: 1px dotted #dedede;
  padding: 0 0 15px;
  margin: 0 0 15px;
}

.l-inputFull {
  display: block;
}
.l-inputFull .formBox__inputText {
  display: block;
}

@media (max-width: 768px) {
  .l-inputName .formBox__inputText {
    width: calc(90% - 3em);
  }

  .l-inputFree .formBox__inputText {
    width: 7em;
  }

  .l-inputCustomerNum .formBox__inputText {
    width: 100%;
    margin: 0 0 3px;
  }

  .l-inputMail .formBox__inputText {
    width: 100%;
    margin: 0 0 3px;
  }

  .l-inputBirth [name*="irthYear"] {
    margin-bottom: 10px;
  }
}
/* -------------------------
  確認画面（is-confirmView）
------------------------- */
.js-submitGo,
.js-confirmBackBtn {
  display: none;
}

.js-confirmShow,
.js-confirmText {
  display: none;
}

.is-confirmView .js-confirmHide,
.is-confirmView .js-confirmBtn {
  display: none;
}
.is-confirmView .js-confirmShow,
.is-confirmView .js-confirmText {
  display: inline-block;
}
.is-confirmView .js-submitGo,
.is-confirmView .js-confirmBackBtn {
  display: inline-block;
}
.is-confirmView .l-containerPower div {
  display: inline-block;
}
.is-confirmView .l-supportSet .span,
.is-confirmView .l-supportSet .formBox__text {
  display: inline-block;
}

/* -------------------------
  formPopup
------------------------- */
.formPopup {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  min-width: 1000px;
  background: rgba(0, 0, 0, 0.6);
}
.formPopup__inner {
  display: none;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background: #fff;
  border-radius: 15px;
  width: 1000px;
  text-align: center;
  overflow: hidden;
}
.formPopup__inner .formPopup__box {
  display: none;
  max-height: calc(95vh - 180px);
  padding: 50px 50px 0;
  margin-bottom: 50px;
  overflow: auto;
}
.formPopup__text {
  margin: -0.5em 0 10px;
  color: #fff;
  text-align: center;
}
.formPopup__closeBtn {
  position: relative;
  display: inline-block;
  min-width: 120px;
  margin: 0 auto 50px;
  padding: 10px 10px 10px 45px;
  background: #f0f0f0;
  border-radius: 50px;
  color: inherit;
  font-size: 1.5rem;
  font-weight: 500;
  text-align: left;
}
.formPopup__closeBtn::before,
.formPopup__closeBtn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 20px;
  width: 17px;
  height: 2px;
  margin-top: -2px;
  background: currentColor;
}
.formPopup__closeBtn::before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.formPopup__closeBtn::after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.formPopup__closeBtn:hover {
  background: #e0e0e0;
}

@media (max-width: 768px) {
  .formPopup {
    min-width: 90%;
  }
  .formPopup__inner {
    left: 15px;
    right: 15px;
    width: auto;
    -webkit-transform: translate(0%, -50%);
    transform: translate(0%, -50%);
  }
  .formPopup__inner .formPopup__box {
    margin-bottom: 20px;
    padding: 25px 15px 0;
  }
  .formPopup__closeBtn {
    margin: 0 auto 20px;
  }
}
/* -------------------------
  confirmErrPop
------------------------- */
.confirmErrPop {
  display: none;
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 20;
  background: rgba(0, 0, 0, 0.6);
}
.confirmErrPop__bg {
  position: absolute;
  width: 900px;
  left: 50%;
  top: 50%;
  margin-left: -450px;
}
.confirmErrPop__inner {
  position: relative;
  width: 100%;
  padding: 40px 100px;
  background: #fff;
  border: 2px solid #e60012;
  border-radius: 8px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-box-shadow: 0 2px 2px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 2px 2px 1px rgba(0, 0, 0, 0.2);
}
.confirmErrPop__inner .js-confirmErrPopText {
  max-height: 75vh;
  overflow: auto;
}
.confirmErrPop__closeBtn {
  display: block;
  position: absolute;
  width: 30px;
  height: 30px;
  right: -15px;
  top: -15px;
  border-radius: 50%;
  background: #000;
}
.confirmErrPop__closeBtn::after,
.confirmErrPop__closeBtn::before {
  content: "";
  width: 18px;
  height: 2px;
  display: block;
  background: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: 0 0 0 -9px;
}
.confirmErrPop__closeBtn::after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  margin-top: -1px;
}
.confirmErrPop__closeBtn::before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.confirmErrPop__closeBtn:hover {
  background: #555;
}
.confirmErrPop__errorLead {
  display: block;
  color: #e60012;
  font-size: 1.5rem;
  font-weight: bold;
}
.confirmErrPop__errorLead::before {
  content: "●";
}
.confirmErrPop__errorLead:not(:last-child) {
  margin-bottom: 5px;
}
.confirmErrPop__errorText {
  font-size: 1.3rem;
}
.confirmErrPop__errorText::before {
  content: "・";
}

@media (max-width: 768px) {
  .confirmErrPop__bg {
    width: auto;
    margin-left: 0;
    left: 15px;
    right: 15px;
  }
  .confirmErrPop__inner {
    padding: 20px 15px;
  }
}
/* -------------------------
  display
------------------------- */
.is-formHide {
  display: none !important;
}

.is-formShow {
  display: inline-block !important;
}

/* -------------------------
  サンクスページ
------------------------- */
.con_thankspage {
  width: 540px;
  margin: 0 auto;
  padding: 40px 0 0;
  text-align: left;
}
.con_thankspage .thanks_st {
  padding-bottom: 20px;
}
.con_thankspage .thanks_st p {
  display: inline-block;
}
.con_thankspage .thanks_st p.st {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.1ex;
}
.con_thankspage .thanks_st p.txt {
  margin-left: 1ex;
  font-size: 1.5rem;
  font-weight: bold;
}
.con_thankspage .box_thankspage {
  padding: 0 0 20px;
  background: #fafafa;
}
.con_thankspage .box_thankspage .st_id {
  font-size: 1.6rem;
  font-weight: bold;
  padding: 8px 20px;
  background: #edf3fa;
}
.con_thankspage .box_thankspage .txt_id {
  padding: 10px 20px 15px;
  text-align: justify;
}
.con_thankspage .box_thankspage .txt_id span {
  display: block;
  padding-top: 8px;
}
.con_thankspage .box_thankspage .wrap_thankspage {
  padding: 0 20px;
}
.con_thankspage .box_thankspage .wrap_thankspage .thankspage {
  padding: 15px 25px;
  border: 1px solid #e6e6e6;
  background: #fff;
  border-radius: 10px;
}
.con_thankspage .box_thankspage .wrap_thankspage .thankspage .sst {
  font-size: 1.5rem;
  font-weight: bold;
}
.con_thankspage .box_thankspage .wrap_thankspage .thankspage ul {
  padding-top: 7px;
  list-style: none;
}
.con_thankspage .box_thankspage .wrap_thankspage .thankspage ul li:before {
  content: "■";
}
.con_thankspage .box_thankspage .wrap_thankspage .thankspage .notice {
  padding-top: 5px;
  color: #e60012;
  font-weight: bold;
}
.con_thankspage .box_thankspage .note {
  font-size: 1.2rem;
  padding: 12px 20px 0;
}
.con_thankspage .con_thanks_tel {
  padding-top: 25px;
}
.con_thankspage .con_thanks_tel .st {
  font-weight: bold;
  font-size: 1.6rem;
  padding-bottom: 2px;
  border-bottom: 1px solid #e6e6e6;
}
.con_thankspage .con_thanks_tel .box_thanks_tel {
  width: 100%;
  overflow: hidden;
  padding-top: 8px;
}
.con_thankspage .con_thanks_tel .box_thanks_tel .box_l {
  font-size: 3.6rem;
  width: 16ex;
  float: left;
}
.con_thankspage .con_thanks_tel .box_thanks_tel .box_l .st_tel {
  font-size: 1.5rem;
  font-weight: bold;
}
.con_thankspage .con_thanks_tel .box_thanks_tel .box_l .txt_tel {
  font-size: 3.6rem;
  font-weight: bold;
  line-height: 1;
}
.con_thankspage .con_thanks_tel .box_thanks_tel .box_r {
  padding-top: 24px;
}
.con_thankspage .con_thanks_tel .box_thanks_tel .box_r .close {
  font-size: 1.3rem;
  line-height: 1.3;
}
.con_thankspage .note {
  padding-top: 10px;
  font-size: 1.2rem;
}

@media (max-width: 768px) {
  .con_thankspage {
    width: auto;
    padding: 25px 10px 0;
  }
  .con_thankspage .thanks_st p.txt {
    font-size: 1.4rem;
  }
  .con_thankspage .box_thankspage .st_id {
    font-size: 1.5rem;
  }
  .con_thankspage .box_thankspage .note {
    font-size: 1.1rem;
  }
  .con_thankspage .con_thanks_tel .st {
    font-size: 1.5rem;
  }
  .con_thankspage .con_thanks_tel .box_thanks_tel .box_l {
    width: auto;
    float: none;
  }
  .con_thankspage .con_thanks_tel .box_thanks_tel .box_l .st_tel {
    font-size: 1.4rem;
  }
  .con_thankspage .con_thanks_tel .box_thanks_tel .box_l .txt_tel {
    font-size: 3rem;
  }
  .con_thankspage .con_thanks_tel .box_thanks_tel .box_r {
    padding-top: 7px;
  }
  .con_thankspage .note {
    font-size: 1.1rem;
  }
}
/* -------------------------
  規約ポップアップ
------------------------- */
.formPopup__inner .formPopup__box[id^="popupTerms"] {
  max-height: none;
  margin: 0;
  padding: 0;
}
.formPopup__inner .formPopup__box[id^="popupTerms"] .termsWrap {
  max-height: calc(95vh - 260px);
  padding: 50px 50px 0;
  margin-bottom: 50px;
  overflow: auto;
}

.termsWrap {
  counter-reset: titleNum;
  font-size: 1.4rem;
  text-align: left;
}
.termsWrap a {
  text-decoration: underline;
}
.termsWrap a[target="_blank"]::after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 0.8em;
  width: 0.8em;
  margin: -0.25em 10px 0 5px;
  background: url(../img/icon_blank.png) no-repeat 50% 50% / contain;
}
.termsWrap__head {
  text-align: center;
}
.termsTitle {
  position: relative;
  margin-bottom: 10px;
  padding: 10px;
  background: #004ea2;
  border-radius: 5px;
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
}
.termsTitle small {
  font-size: 1.2rem;
}
.termsTitle__tag {
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 6px 10px;
  border: 1px solid currentColor;
  border-radius: 2px;
  font-size: 1.1rem;
  line-height: 1;
}
.termsLead {
  margin: 0 0 35px;
  padding: 15px;
  border: 1px solid;
  color: #da2135;
  font-size: 1.4rem;
  text-align: center;
}
.termsNoticeBox {
  margin: 0 0 35px;
  padding: 25px;
  border: 1px solid #dedede;
  font-size: 1.4rem;
  text-align: left;
}
.termsNoticeTitle {
  margin-bottom: 1em;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
}
.termsAuthor {
  margin-bottom: 15px;
  font-size: 1.3rem;
  text-align: right;
}
.termsSection {
  padding: 20px;
}
.termsSection:not(:last-child) {
  margin-bottom: 30px;
}
.termsSubTitle {
  margin-bottom: 1em;
  padding-bottom: 0.5em;
  border-bottom: 1px solid #dedede;
  color: #004ea2;
  font-size: 1.6rem;
  font-weight: bold;
}
.termsSubTitle::before {
  counter-increment: titleNum;
  content: counter(titleNum) ".";
}
.others .termsSubTitle::before {
  display: none;
}
.termsNoteBox {
  margin: 15px 0;
  padding: 15px;
  border: 1px solid #dedede;
}
.termsNoteTitle {
  font-size: 1.3rem;
}
.termsNoteTitle:not(:first-child) {
  margin-top: 1em;
}
.termsText:not(:last-child) {
  margin-bottom: 1em;
}
.termsNote {
  margin-top: 0.5em;
  font-size: 1.1rem;
  line-height: 1.5;
}
.termsList,
.termsList--katakana,
.termsList--note {
  list-style: none;
  counter-reset: listNum;
  padding-left: 2.5em;
}
.termsList > li,
.termsList--katakana > li,
.termsList--note > li {
  margin-bottom: 0.8em;
}
.termsList > li::before,
.termsList--katakana > li::before,
.termsList--note > li::before {
  counter-increment: listNum;
  content: "(" counter(listNum) ")";
  display: inline-block;
  width: 2.5em;
  margin-left: -2.5em;
}
.termsList--katakana {
  margin-top: 10px;
}
.termsList--katakana > li {
  margin-bottom: 0.5em;
  font-size: 1.3rem;
}
.termsList--katakana > li:nth-child(1)::before {
  content: "ア.";
}
.termsList--katakana > li:nth-child(2)::before {
  content: "イ.";
}
.termsList--katakana > li:nth-child(3)::before {
  content: "ウ.";
}
.termsList--katakana > li:nth-child(4)::before {
  content: "エ.";
}
.termsList--katakana > li:nth-child(5)::before {
  content: "オ.";
}
.termsList--katakana > li:nth-child(6)::before {
  content: "カ.";
}
.termsList--katakana > li:nth-child(7)::before {
  content: "キ.";
}
.termsList--katakana > li:nth-child(8)::before {
  content: "ク.";
}
.termsList--katakana > li:nth-child(9)::before {
  content: "ケ.";
}
.termsList--katakana > li:nth-child(10)::before {
  content: "コ.";
}
.termsList--text {
  list-style-type: disc;
  margin: 10px 0 0 1.5em;
}
.termsList--text > li {
  font-size: 1.3rem;
  margin-bottom: 0.8em;
}
.termsList--note {
  font-size: 1.2rem;
}
.termsList--note > li {
  margin-bottom: 0.5em;
}
.termsList--note > li::before {
  content: "※" counter(listNum);
}
.termsList--dot {
  margin-top: 10px;
  padding-left: 0;
}
.termsList--dot > li {
  list-style-type: disc;
  margin-left: 1.5em;
}
.termsList--dot > li::before {
  display: none;
}
.termsTable {
  margin: 10px 0 15px;
  border: 1px solid #dedede;
  font-size: 1.3rem;
}
.termsTable thead th {
  background: #f4f4f4;
  text-align: center;
}
.termsTable th,
.termsTable td {
  padding: 10px;
  vertical-align: middle;
  border: 1px solid #dedede;
}
.termsTable th {
  font-weight: bold;
}
.termsTable sup {
  vertical-align: super;
  font-size: 0.8em;
}
.termsTable__num {
  text-align: right;
}
.termsTable__center {
  text-align: center;
}
.termsContact {
  margin-top: 20px;
  background: #f4f4f4;
  font-size: 1.3rem;
}
.termsContact:last-child {
  margin-bottom: 10px;
}
.termsContact__box {
  padding: 15px;
}
.termsContact__title {
  margin-bottom: 10px;
  padding-left: 10px;
  border-left: 5px solid;
  color: #004ea2;
  font-size: 1.4rem;
}
.termsContact__subTitle {
  margin-bottom: 5px;
  font-weight: bold;
}
.termsContact__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.termsContact__info > dt {
  -webkit-box-flex: 0;
  -ms-flex: none;
  flex: none;
  position: relative;
  width: 14em;
  margin-bottom: 5px;
}
.termsContact__info > dt::after {
  content: "：";
  position: absolute;
  top: 0;
  right: 0;
}
.termsContact__info > dd {
  width: calc(100% - 14em);
  margin-bottom: 5px;
  padding-left: 10px;
}
.termsContact__info__note {
  font-size: 1rem;
}
.termsAttn {
  display: inline-block;
  margin: 0 0 35px;
  border-bottom: 1px solid;
  color: #da2135;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
}
.termsPopBtn {
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: 20px;
  padding: 0 15px;
}
.is-confirmView .termsPopBtn {
  display: none;
}
.termsPopBtn__item,
.termsPopBtn__item--agree {
  width: 50%;
  max-width: 250px;
}
.termsPopBtn__item:not(:last-child),
.termsPopBtn__item--agree:not(:last-child) {
  margin-right: 15px;
}
.termsPopBtn__item > a,
.termsPopBtn__item--agree > a {
  display: block;
  padding: 15px 10px;
  border: 1px solid #004ea2;
  border-radius: 5px;
  text-align: center;
}
.termsPopBtn__item--agree > a {
  background: #004ea2;
  color: #fff;
}
.termsPopBtn__item--agree > a:hover {
  background: #0067d5;
}
.termsPopBtn__item--agree > a.is-disabled {
  background: #666;
  border-color: #666;
  color: #eee;
  opacity: 0.6;
  pointer-events: none;
}
.termsNormalTitle {
  margin-top: 20px;
}
.termsSmallTitle {
  margin-top: 15px;
}
.preContractDocument p {
  text-align: right;
}
.termsLogo {
  display: flex;
  justify-content: end;
  margin: 15px 0;
}
.termsLogo > img {
  width: auto;
  height: 1.3rem;
}

.red_12 {
  font-size: 12px;
  color: #da2135;
  border: 1px solid #da2135;
  padding: 20px;
}
.red_12 .termsSubTitle {
  color: #da2135;
}

.num_2_start ol {
  list-style: none;
  counter-reset: custom-counter 1;
  margin-left: 20px;
}

.num_2_start ol li {
  position: relative;
  margin-bottom: 10px; /* リストアイテム間のスペースを調整 */
}

.num_2_start ol li:before {
  content: " (" counter(custom-counter) ")"; /* カスタムカウンターの値を表示 */
  position: absolute;
  left: -25px; /* 数字の位置を調整 */
  counter-increment: custom-counter;
}

@media (max-width: 768px) {
  .formPopup__inner .formPopup__box[id^="popupTerms"] .termsWrap {
    margin-bottom: 20px;
    padding: 25px 15px 0;
  }

  .termsWrap {
    font-size: 1.3rem;
  }
  .termsTitle {
    font-size: 1.8rem;
  }
  .termsTitle small {
    display: block;
    font-size: 1.1rem;
  }
  .termsLead {
    font-size: 1.3rem;
  }
  .termsNoticeBox {
    padding: 15px;
    font-size: 1.3rem;
  }
  .termsNoticeTitle {
    font-size: 1.5rem;
  }
  .termsAuthor {
    font-size: 1.2rem;
  }
  .termsSection:not(:last-child) {
    margin-bottom: 30px;
  }
  .termsSubTitle {
    font-size: 1.5rem;
  }
  .termsNoteTitle {
    font-size: 1.2rem;
  }
  .termsNote {
    font-size: 1rem;
  }
  .termsList--katakana > li {
    font-size: 1.2rem;
  }
  .termsList--text > li {
    font-size: 1.2rem;
  }
  .termsList--note > li {
    font-size: 1.1rem;
  }
  .termsTable {
    font-size: 1.2rem;
  }
  .termsContact {
    font-size: 1.2rem;
  }
  .termsContact__title {
    font-size: 1.3rem;
  }
  .termsContact__info {
    display: block;
  }
  .termsContact__info > dt {
    width: auto;
  }
  .termsContact__info > dt::after {
    position: static;
    display: inline-block;
  }
  .termsContact__info > dd {
    width: auto;
    margin-bottom: 20px;
  }

  .termsTable th, .termsTable td {
    padding: 5px;
  }
}


/* 追加 */
.red_12,
.red_12 .termsNote,
.red_12 .termsNoteTitle,
.red_12 .termsTable th ,
.red_12 .termsTable td {
  font-size: 16px !important;
}
.termsWrap a {
  word-wrap: break-word;
}

@media (max-width: 768px) {
.red_12 .termsTable th ,
.red_12 .termsTable td {
  font-size: 100% !important;
}
}

.updatedDate {
  text-align: right;
  margin-top: 10px;
}

.pricingHeader {
  text-align: center;
}