@charset "utf-8";


header {
  height: 60px;
  margin-bottom: 40px;
  padding-left: 20px;
  min-width: 100%;
}

footer {
  min-width: 100%;
}

.content {
  width: 100%;
}

section {
  width: 100%;
  margin: 0 auto;
  padding: 0 15px;
}

h1 {
  margin-bottom: 0px;
}

h2 {
  margin-bottom: 10px;
  font-size: 20px;
}

h3 {
  font-size: 18px;
  padding-bottom: 8px;
  margin: 40px auto 18px;
  border-bottom: 2px solid #91a8b8;
}

.visible-pc {
  display: none;
}

.visible-sp {
  display: initial;
}

.cybertrust .img {
  margin-right: 5px;
}

.cybertrust p {
  width: calc(100% - 115px);
  font-size: 12px;
}

section.form > .note {
  margin-left: 0px;
  font-size: 14px;
  margin-top: -5px;
  margin-bottom: 10px;
}

section.form > .item {
  display: flex;
  margin-bottom: 15px;
}

section.form > .item {
  display: block;
  margin-bottom: 15px;
}

section.form > .item:first-child {
  margin-top: 20px;
}

section.form > .item .label {
  height: auto;
  line-height: initial;
  padding-left: 0px;
  margin-bottom: 6px;
  font-size: 14px;
}

section.form > .item .input.flex {
  display: block;
}

section.form > .item .input .notes.asterisk {
  margin-left: 0px;
}

section.form > .item .input.flex .notes.asterisk {
  margin-top: 5px;
  margin-left: 0;
}

section.form > .item .input .error_message {
  margin: 10px 0 0 15px;
}

section.form > .item .input,
section.form > .item .value {
  padding-right: 0px;
}

section.form > .item .value {
  line-height: inherit;
  font-size: 12px;
}

select {
  padding: 15px;
  font-size: 16px;
  width: 100%;
}

section.form > .item.name input {
  width: 120px;
  margin-right: 10px;
}

section.form > .item.quantity .input {
  margin-left: 0;
  font-size: 15px;
}

section.form > .item.quantity .input input {
  width: 150px;
  margin-right: 10px;
}

section.form > .item.plan > .input > .wrapper,
section.form > .item.plan-option > .input > .wrapper {
  display: block;
  margin-left: 0;
}

section.form > .item.plan > .input .name,
section.form > .item.plan-option > .input .name {
  margin-bottom: 6px;
}

section.form > .item.plan > .input .price,
section.form > .item.plan-option > .input .price {
  margin-right: 0;
  margin-bottom: 6px;
  margin-left: 30px;
  font-size: 14px;
}


section.form > .item.plan > .input .price:first-child,
section.form > .item.plan-option > .input .price:first-child {
  margin-left: 0;
}

section.form > .item.plan > .input .price:last-child,
section.form > .item.plan-option > .input .price:last-child {
  margin-right: 0;
}

section.form > .item.plan > .input .name:last-child,
section.form > .item.plan-option > .input .name:last-child,
section.form > .item.plan > .input .price:last-child,
section.form > .item.plan-option > .input .price:last-child {
  margin-bottom: 0;
}

section.legal {
  margin-top: 40px;
}

section.legal .wrapper {
  padding: 20px;
}

section.legal .agreement {
  margin-bottom: 25px;
}

section.legal .container {
  margin: 0;
}

section.legal .container .contents {
  word-break: break-all;
}

input[type='text'] {
  font-size: 16px;
  padding: 15px;
  width: 100%;
  border: 1px solid #d0dce4;
  border-radius: 2px;
  outline: none;
  background-clip: padding-box;
}

section.control {
  margin-bottom: 18px;
}

section.control.main {
  display: block;
  width: calc(100% - 5.0vw);
  margin-bottom: 0px;
}

section.control.main .btn {
  width: 100%;
  margin: 0 auto 15px;
}

section.control.sub {
  width: calc(100% - 5.0vw);
  justify-content: space-between;
}

.btn_l {
  width: 290px;
  height: 75px;
}

.btn_l a {
  line-height: 75px;
  font-size: 6.5vw;
}

.btn_s {
  width: 210px;
  height: 50px;
}

.btn_s a {
  line-height: 50px;
  font-size: 4.5vw;
}

section.control.plural {
  flex-wrap: wrap;
  padding: 0 27px;
}

section.control.plural .btn:nth-child(1) {
  order: 2;
  width: 45%;
}

section.control.plural .btn:nth-child(2) {
  order: 1;
  width: 100%;
  margin-bottom: 20px;
}

section.control.plural .btn:nth-child(3) {
  order: 3;
  width: 50%;
}


.flow ul li {
  width: 12vw;
  height: 12vw;
  line-height: 12vw;
  font-size: 0px;
  margin-right: 2.6vw;
  position: relative;
  padding-top: 0px;
}

.flow ul li.current {
  width: 32.2vw;
  font-weight: bold;
  background-color: #d0dce4;
  font-size: 12px;
  vertical-align: middle;
}

.flow ul li:last-child {
  margin-right: 0;
}

.flow ul li::before {
  content: counter(count);
  position: static;
  display: inline-block;
  margin: auto;
  color: #91a8b8;
  font-size: 14px;
  vertical-align: middle;
}

.flow ul li.current::before {
  margin-right: 0.5vw;
  margin-bottom: 2px;
}

.flow ul li:not(:last-child)::after {
  top: 16px;
  right: -9px;
  border-width: 5px 0 5px 5px;
}


textarea {
  font-size: 16px;
  padding: 15px;
  background-clip: padding-box;
}

#modal .dialog {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  background-color: #fff;
  width: 320px;
  height: 500px;
  border-radius: 12px;
  padding: 20px;
}

#modal .dialog .content {
  display: flex;
  flex-direction: column;
  height: 100%;
}

#modal .dialog .table {
  flex: 1 1 0%;
  overflow: auto;
}

#modal .dialog .table img {
  height: 255px;
}

/* FooterSP */
footer {
  height: auto;
  background-size: 2px 100%
}
footer .footer_linkList {
  margin: 0 auto 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}
@media only screen and (max-width: 599px) {
  footer .footer_linkList {
    width: 90%;
    max-width: 386px;
    padding:0;
  }
}
footer .footer_linkList .btn_link {
  margin-bottom: 10px;
  font-size: 12px;
  text-align: center;
  display: block;
  border-right: 1px solid #333
}
/*
@media only screen and (max-width: 599px) {
  footer .footer_linkList .btn_link:nth-child(3), footer .footer_linkList .btn_link:nth-child(6), footer .footer_linkList .btn_link:nth-child(8), footer .footer_linkList .btn_link:nth-child(9) {
    border-right: 1px solid #333
  }
}
*/
footer .footer_linkList .btn_link a {
  color: inherit;
  padding: 0 20px;
  text-decoration: none
}
@media only screen and (max-width: 599px) {
  footer .footer_linkList .btn_link a {
    padding: 0 10px
  }
}
footer .content .corporate .corporate_inner {
  font-size: 0.8em
}

/*------ 無料キャンペーンユニット -------*/

.cp_title br {
  display: block;
}

.cp_title .-pc {
  display: none;
}

.cp_title .-sp {
  display: inline;
}

.cp_block {
  padding: 20px 15px;
}

.cp_block br.sp {
  display: block;
}

.cp_block .sub {
  font-size: 18px;
}

.cp_block .main_line {
  display: block;
  margin-top: 15px;
}

.cp_block .main_line .txt {
  font-size: 18px;
}

.cp_block .main_line .txt > span {
  font-size: 28px;
  padding: 0 2px;
}

.cp_block .main_line .arrow {
  line-height: 1.2;
  font-size: 32px;
}

.cp_block .main_line .red_free {
  font-size: 36px;
}

.cp_block .main_line .arrow .pc{
  display: none;
}

.cp_block .main_line .arrow .sp{
  display: block;
}

.cp_block .opt {
  font-size: 14px;
}

.cp_block .opt span {
  display: none;
}

.cp_banner {
  margin: 20px 0;
}

.cp_banner img.pc {
  display: none;
}

.cp_banner img.sp {
  display: block;
}
.d-table {
  border-collapse: collapse;
  width: 100%;
  margin: 10px;
}

.d-table th,
.d-table td {
  border: 1px solid #dddddd;
  padding: 8px;
  text-align: center;
  font-size: 14px;
}

.d-table th {
	background-color: #f2f2f2;
}
.d2-table {
  border-collapse: collapse;
  width: 100%;
  margin: 10px;
}

.d2-table th,
.d2-table td {
  border: 1px solid #dddddd;
  padding: 8px;
  text-align: center;
  font-size: 14px;
  white-space: normal;
  word-break: break-all;
}

.d2-table th {
	background-color: #f2f2f2;
}