.u-checkbox {
  display: flex;
  align-items: baseline;
  margin-bottom: 5px;
}
.u-checkbox input {
  display: none;
}
.u-checkbox::before {
  content: "";
  display: inline-block;
  min-width: 1.08em;
  height: 1.08em;
  border: 1px solid #111;
  border-radius: 5px;
  margin-right: 0.75em;
  vertical-align: middle;
  transition: .5s;
  background: url("../image/common/ico_check_02.svg") no-repeat center #FFF;
  background-size: 0.6666666667em;
  transform: translateY(0.2em);
}
.u-checkbox.checked::before {
  background-color: #111;
}

.u-input {
  border-radius: 5px;
  padding: 5px 10px;
  border: 1px solid #666;
  font-size: 1.6rem;
  max-width: 100%;
}
.u-input-comment {
  height: 200px;
}

.u-btn {
  display: block;
  border: none;
  cursor: pointer;
  font-weight: bold;
  border: 2px solid #111;
  width: 100%;
  text-align: center;
  color: #111;
}
.u-btn-confirm, .u-btn-send {
  background: #111;
  color: #FFF;
}
.u-btn-confirm {
  font-size: 2.16rem;
  padding: 25px 20px;
}
.u-btn-send, .u-btn-back {
  font-size: 1.8rem;
  padding: 20px;
}
.u-btn-send {
  margin-bottom: 15px;
}
.u-btn-back {
  background: #F4F4F4;
}
.u-btn[disabled=disabled] {
  opacity: 0.4;
  cursor: default;
}

.u-error {
  display: block;
  margin-bottom: 15px;
  color: #C00;
  background: rgba(204, 0, 0, 0.05);
  padding: 10px 15px;
}

@media print, screen and (min-width: 737px) {
  .u-other {
    display: flex;
    align-items: center;
  }

  .u-input-other {
    width: 300px;
    margin-left: 1.0em;
  }
  .u-input-name {
    width: 275px;
  }
  .u-input-company, .u-input-address, .u-input-mail {
    width: 550px;
  }
  .u-input-zip, .u-input-tel {
    width: 180px;
  }
  .u-input-comment {
    width: 100%;
  }

  .u-center {
    align-items: center !important;
  }

  .u-btn-confirm {
    padding: 50px 30px;
    font-size: 2.4rem;
    max-width: 550px;
    margin: 0 auto;
  }
  .u-btn-send, .u-btn-back {
    font-size: 2rem;
    padding: 40px 30px;
    flex-basis: 48.5%;
    max-width: 48.5%;
  }
  .u-btn-send {
    margin-bottom: 0;
  }
}
.c-inner {
  padding: 0 20px;
}
.c-tit {
  font-size: 2.4rem;
  text-align: center;
  margin-bottom: 20px;
}
.c-tit p {
  font-size: 1.5rem;
  letter-spacing: normal;
}

.p-form__lead {
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 15px;
}
.p-form__lead-txt {
  margin-bottom: 25px;
}
.p-form__lead-txt strong {
  display: block;
  text-align: center;
  font-size: 130%;
  margin-bottom: 10px;
}
.p-form__lead-txt .error {
  color: #C00;
}
.p-form__num {
  background: #F4F4F4;
  margin-bottom: 40px;
}
.p-form__num dl {
  display: flex;
  align-items: center;
}
.p-form__num dl:last-child dt::before {
  background: url("../image/common/ico_fax_01.svg") no-repeat center/contain;
}
.p-form__num dt {
  width: 62.4px;
  height: 62.4px;
  background: #AC9147;
  border-radius: 50%;
  color: #FFF;
  font-size: 1.3rem;
  display: flex;
  align-content: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  line-height: 1.1;
}
.p-form__num dt::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  margin: 0 auto 5px;
}
.p-form__num dd {
  font-size: 1rem;
}
.p-form__num dd span {
  display: block;
  font-weight: bold;
  font-size: 3rem;
  line-height: 1.1;
}
.p-form__flow {
  margin-bottom: 25px;
}
.p-form__flow li {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
  position: relative;
  color: #999;
  line-height: 1.1;
}
.p-form__flow li::before, .p-form__flow li::after {
  content: "";
  display: block;
}
.p-form__flow li::before {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #999;
  margin-right: 20px;
  border: 5px solid #FFF;
  box-sizing: content-box;
  position: relative;
  z-index: 2;
}
.p-form__flow li::after {
  width: 1px;
  height: 20px;
  background: #999;
  position: absolute;
  left: 14px;
  top: 100%;
  z-index: 1;
}
.p-form__flow li:last-child {
  margin-bottom: 0;
}
.p-form__flow li:last-child::after {
  display: none;
}
.p-form__flow li.current, .p-form__flow li.end {
  font-weight: bold;
}
.p-form__flow li.current {
  color: #111;
}
.p-form__flow li.current::before {
  background: url("../image/common/ico_check_01.svg") no-repeat center #295682;
  background-size: 50%;
  transform: scale(1.5);
  transform-origin: center;
  border-top-width: 3.3333333333px;
  border-bottom-width: 3.3333333333px;
}
.p-form__flow li.end {
  color: #777;
}
.p-form__flow li.end::before, .p-form__flow li.end::after {
  background: #295682;
}
.p-form__flow li.end::after {
  border: 1px solid #295682;
}
.p-form__flow li.after {
  color: #333;
}
.p-form__body {
  border-top: 1px solid #DDD;
  margin-bottom: 30px;
}
.p-form__body dt {
  font-weight: bold;
  padding-top: 15px;
  margin-bottom: 5px;
}
.p-form__body dd {
  border-bottom: 1px solid #DDD;
  padding-bottom: 15px;
}
.p-form__body dd dt:first-child {
  padding-top: 0;
}
.p-form__body dd dd {
  border-bottom: none;
  padding-bottom: 0;
}
.p-form__req {
  display: inline-block;
  background: #AC9147;
  font-weight: normal;
  color: #FFF;
  font-size: 1.2rem;
  padding: 0 3px;
  margin-left: 0.75em;
}
.p-form__privacy {
  background: #F4F4F4;
  padding: 20px;
  text-align: center;
  margin-bottom: 30px;
}
.p-form__privacy dt {
  font-weight: bold;
  margin-bottom: 5px;
}
.p-form__privacy a {
  color: #111;
  text-decoration: underline;
  margin-right: 0.25em;
}
.p-form__privacy a:hover {
  text-decoration: none;
  color: #333;
}
.p-form__privacy a::after {
  margin-left: 0.25em;
}
.p-form__privacy .u-checkbox {
  justify-content: center;
}
.p-form__confirm {
  margin-bottom: 20px;
  text-align: center;
}

@media print, screen and (min-width: 737px) {
  .c-inner {
    padding: 0;
  }
  .c-tit {
    font-size: 3rem;
    margin-bottom: 40px;
    letter-spacing: 0.125em;
  }

  .p-form__lead {
    font-size: 2.4rem;
    margin-bottom: 20px;
  }
  .p-form__lead-txt {
    margin-bottom: 50px;
    text-align: center;
  }
  .p-form__num {
    display: flex;
  }
  .p-form__num dt {
    width: 78px;
    height: 78px;
    margin-right: 16px;
  }
  .p-form__num dt::before {
    width: 25px;
    height: 25px;
  }
  .p-form__num dd {
    font-size: 1.3rem;
  }
  .p-form__num dd span {
    font-size: 4rem;
  }
  .p-form__flow {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .p-form__flow li {
    display: block;
    width: 40px;
  }
  .p-form__flow li::before {
    margin: 0 auto;
    border-width: 10px;
  }
  .p-form__flow li::after {
    height: 1px;
    position: absolute;
    left: 100%;
    top: 19px;
  }
  .p-form__flow li:last-child {
    margin-right: 0;
  }
  .p-form__flow li span {
    position: absolute;
    top: 100%;
    left: 50%;
    display: block;
    text-align: center;
    margin-top: 25px;
  }
  .p-form__flow li span.u-hidden-pc {
    display: none;
  }
  .p-form__flow li.current::before {
    background-size: 40%;
    transform: scale(2.4);
    border-top-width: 10px;
    border-bottom-width: 10px;
    border-left-width: 4.1666666667px;
    border-right-width: 4.1666666667px;
  }
  .p-form__body {
    display: flex;
    flex-wrap: wrap;
  }
  .p-form__body dt {
    padding: 30px 20px;
    flex-basis: 25%;
    max-width: 25%;
    margin-bottom: 0;
    border-bottom: 1px solid #DDD;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
  }
  .p-form__body dd {
    padding: 30px 20px 30px 0;
    flex-basis: 75%;
    max-width: 75%;
  }
  .p-form__body dd dl {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  .p-form__body dd dt, .p-form__body dd dd {
    padding: 0;
    margin-bottom: 20px;
  }
  .p-form__body dd dt:last-of-type, .p-form__body dd dd:last-of-type {
    margin-bottom: 0;
  }
  .p-form__body dd dt {
    flex-basis: 10.5em;
    max-width: 10.5em;
    border: none;
    display: block;
  }
  .p-form__body dd dd {
    flex-basis: calc(100% - 10.5em);
    max-width: calc(100% - 10.5em);
  }
  .p-form__req {
    line-height: 1.1;
    padding: 3px 8px;
    margin-left: 0;
  }
  .p-form__contents, .p-form__contact, .p-form__known, .p-form__future {
    display: flex;
    flex-wrap: wrap;
  }
  .p-form__contents > * {
    flex-basis: 50%;
    max-width: 50%;
  }
  .p-form__contact > *, .p-form__known > * {
    flex-basis: 33.3333%;
    max-width: 33.3333%;
  }
  .p-form__contact > *:nth-child(2n) {
    margin-right: 33.3333%;
  }
  .p-form__contact > *:nth-last-of-type(2), .p-form__contact > *:last-of-type {
    margin-bottom: 0;
  }
  .p-form__known > *:last-of-type {
    margin-bottom: 0;
  }
  .p-form__future > *:nth-child(2n-1) {
    flex-basis: 55%;
    max-width: 55%;
  }
  .p-form__future > *:nth-child(2n) {
    flex-basis: 45%;
    max-width: 45%;
  }
  .p-form__privacy {
    padding: 40px;
    margin-bottom: 50px;
  }
  .p-form__privacy dt {
    margin-bottom: 10px;
  }
  .p-form__confirm {
    margin-bottom: 30px;
  }
  .p-form__btns, .p-form__back {
    display: flex;
    justify-content: space-between;
  }
  .p-form__btns {
    padding: 0 50px;
  }
  .p-form__back * {
    flex-basis: 31.5%;
    max-width: 31.5%;
    margin-bottom: 0;
  }
}
.c-tit__page {
  background: url("../image/catalog/bg_tit_01_sp.jpg") no-repeat center/cover;
}

.p-form__block {
  background: #F4F4F4;
  padding: 40px 15px 15px;
}
.p-form__block-inner {
  background: #FFF;
  padding: 1px 15px 15px;
}
.p-form__block-copy, .p-form__block img, .p-form__block-box {
  display: block;
}
.p-form__block-copy {
  background: #AE5E3A;
  color: #FFF;
  font-size: 1.7rem;
  text-align: center;
  line-height: 1.1;
  padding: 0.5em;
  border-radius: 1.5em;
  margin: -1.125em 0 15px;
}
.p-form__block-tit {
  text-align: center;
  margin-bottom: 15px;
  font-weight: bold;
  font-size: 1.7rem;
}
.p-form__block-tit h3 {
  font-size: 140%;
  line-height: 1.6;
  margin-top: 10px;
}
.p-form__block-tit strong {
  color: #AE5E3A;
}
.p-form__block img {
  margin: 0 auto 15px;
}
.p-form__block-box {
  text-align: center;
  color: #AE5E3A;
  background: #F7F4EC;
  font-size: 1.95rem;
  padding: 15px;
  line-height: 1.6;
  margin-top: 20px;
}
.p-form__plus {
  display: block;
  margin: 20px auto;
  width: 50px;
  height: 50px;
  position: relative;
}
.p-form__plus::before, .p-form__plus::after {
  content: "";
  display: block;
  background: #111;
}
.p-form__plus::before {
  width: 10px;
  height: 50px;
  margin: 0 auto;
}
.p-form__plus::after {
  width: 50px;
  height: 10px;
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -5px;
}
.p-form__tit {
  font-size: 1.8rem;
  margin-bottom: 15px;
}
.p-form__catalog {
  border-top: 1px solid #CCC;
  border-left: 1px solid #CCC;
  margin-bottom: 30px;
}
.p-form__catalog li {
  border-bottom: 1px solid #CCC;
  border-right: 1px solid #CCC;
  padding: 30px 20px;
}
.p-form__catalog-img {
  flex-basis: 32.0212765957%;
  max-width: 32.0212765957%;
}
.p-form__catalog-img img {
  display: block;
}
.p-form__catalog-txt {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.p-form__catalog-sample {
  display: block;
  font-weight: bold;
  background: #AC9147;
  color: #FFF;
  text-align: center;
  padding: 0.25em;
  border-radius: 1.25em;
  margin-bottom: 15px;
  flex-basis: 100%;
  max-width: 100%;
}
.p-form__catalog dl {
  flex-basis: 65%;
  max-width: 65%;
}
.p-form__catalog dt {
  font-weight: bold;
  font-size: 101.25%;
}
.p-form__catalog dd {
  font-size: 90%;
}
.p-form__catalog .u-checkbox {
  flex-basis: 100%;
  max-width: 100%;
  margin: 15px 0 0;
  border: 1px solid #111;
  background: #111;
  color: #FFF;
  justify-content: center;
  padding: 15px;
  transition: .5s;
}
.p-form__catalog .u-checkbox::before {
  border-color: #FFF;
  background: #111;
  overflow: hidden;
}
.p-form__catalog .u-checkbox.checked {
  background: #FFF;
  color: #111;
}
.p-form__catalog .u-checkbox.checked::before {
  background: url("../image/common/ico_check_02.svg") no-repeat center #111;
  background-size: 0.6666666667em;
}
.p-form__back * {
  margin-bottom: 15px;
}
.p-form__back *:last-child {
  margin-bottom: 0;
}
.p-form__body.course {
  border-top: none;
}
.p-form__body.course dt {
  padding: 15px 20px 5px;
  margin-bottom: 0;
}
.p-form__body.course dt span {
  font-size: 120%;
}
.p-form__body.course dd {
  padding: 0 20px 15px;
  border-bottom: none;
  margin-bottom: 10px;
}
.p-form__body.course dd label:last-child {
  margin-bottom: 0;
}
.p-form__body.course ul {
  list-style: disc;
  margin-left: 1.0em;
  line-height: 1.5;
}
.p-form__body .course01 {
  background: rgba(157, 53, 166, 0.03);
}
.p-form__body .course01 strong {
  color: #9D35A6;
}
.p-form__body .course01 ul {
  display: flex;
  flex-wrap: wrap;
}
.p-form__body .course01 li:first-child {
  flex-basis: 5.0em;
}
.p-form__body .course02 {
  background: rgba(0, 159, 232, 0.03);
}
.p-form__body .course02 strong {
  color: #009FE8;
}
.p-form__body .course03 {
  background: rgba(128, 186, 60, 0.03);
}
.p-form__body .course03 strong {
  color: #80BA3C;
}

@media print, screen and (min-width: 737px) {
  .c-tit__page {
    background: url("../image/catalog/bg_tit_01_pc.jpg") no-repeat center/cover;
  }

  .p-form__flow {
    margin-bottom: 100px;
  }
  .p-form__flow li {
    margin: 0 250px 0 0;
  }
  .p-form__flow li::after {
    width: 250px;
  }
  .p-form__flow li span {
    width: 160px;
    margin-left: -80px;
  }
  .p-form__block {
    padding: 50px;
  }
  .p-form__block-inner {
    padding: 1px 50px 50px;
  }
  .p-form__block-copy {
    font-size: 2rem;
    padding: 0.75em;
    border-radius: 1.5em;
    margin: -1.3125em auto 30px;
    max-width: 400px;
  }
  .p-form__block-hidden {
    overflow: hidden;
  }
  .p-form__block-tit, .p-form__block p {
    float: right;
    width: 69.3333333333%;
  }
  .p-form__block-tit {
    text-align: left;
    font-size: 2rem;
    margin-top: 10px;
  }
  .p-form__block-tit h3 {
    margin-top: 5px;
  }
  .p-form__block img {
    margin: 0;
    float: left;
  }
  .p-form__block-box {
    font-size: 3rem;
  }
  .p-form__plus {
    margin: 40px auto;
  }
  .p-form__tit {
    font-size: 2rem;
  }
  .p-form__catalog {
    margin-bottom: 100px;
    display: flex;
    flex-wrap: wrap;
  }
  .p-form__catalog li {
    padding: 40px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-basis: 50%;
    max-width: 50%;
  }
  .p-form__catalog li > div {
    flex-basis: 50.1600853789%;
    max-width: 50.1600853789%;
  }
  .p-form__catalog-img {
    flex-basis: 45.8911419424%;
    max-width: 45.8911419424%;
  }
  .p-form__catalog-txt {
    display: block;
    margin-bottom: 0;
  }
  .p-form__catalog-sample {
    line-height: 1.5;
    margin: 0 0 15px;
  }
  .p-form__catalog-sample.u-hidden-sp {
    background: #FFF;
  }
  .p-form__catalog dl {
    flex-basis: 100%;
    max-width: 100%;
    font-size: 1.6rem;
    line-height: 1.75;
  }
  .p-form__catalog dt {
    margin-bottom: 10px;
    font-size: 112.5%;
  }
  .p-form__catalog .u-checkbox {
    margin-top: 30px;
  }
  .p-form__back * {
    margin-bottom: 0;
  }
  .p-form__body.course dt {
    padding: 30px 20px;
    margin-bottom: 10px;
    border-bottom: none;
  }
  .p-form__body.course dd {
    padding: 30px 20px 30px 0;
  }
}
@media screen and (min-width: 737px) and (-webkit-min-device-pixel-ratio: 2) {
  .c-tit__page {
    background: url("../image/catalog/bg_tit_01_pc@2x.jpg") no-repeat center/cover;
  }
}
@media print, screen and (min-width: 1281px) {
  .c-tit__page {
    background: url("../image/catalog/bg_tit_01_pc@2x.jpg") no-repeat center/cover;
  }
}
