@charset "utf-8";
/* 共通 */
body {
  margin: 0 auto;
  /*max-width: 1000px;*/
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  color: #333;
}
h2 {
  text-align: center;
  font-size: 30px;
  font-weight: 500;
}
h2 span {
  text-align: center;
  font-size: 14px;
  color: #C7000B;
  position: relative;
  top: -20px;
}
@media screen and (max-width: 345px) {
  h2 {
    font-size: 30px;
  }
}
header {
  box-shadow: 0 3px 6px #ddd;
  position: fixed;
  background-color: #fff;
  width: 100%;
  z-index: 10;
}
.header {
  margin: 20px auto;
  max-width: 1000px;
  padding: 0 15px;
  display: flex;
  justify-content: space-between;
  z-index: 10;
}
.header-logo img {
  width: 195px;
  vertical-align: top;
}
.header-login a {
  text-decoration: none;
  color: #fff;
  font-weight: 600;
  padding: 8px 30px;
  background: #C7000B;
  border-radius: 20px;
  position: relative;
  top: 8px;
}
.header-login a:hover {
  background: #fff;
  color: #C7000B;
  border: 1px solid #C7000B;
  transition: 0.5s;
}
@media screen and (max-width: 430px) {
  .header-logo img {
    width: 130px;
  }
  .header-login a {
    padding: 7px 17px;
    top: 3px;
  }
}
.main {
  width: 100%;
  margin: 0;
  padding: 100px 0 180px;
  position: relative;
  top: -100px;
}
.main::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: #F1F1F1;
  transform: skewY(-4deg);
  z-index: -1;
  height: 567px;
}
.main-flex {
  display: flex;
  margin: 0 auto;
  max-width: 1000px;
  padding: 0 15px;
  position: relative;
}
.main-text {
  margin: 190px 0 0;
  max-width: 1000px;
}
.main-img {
  position: absolute;
  max-width: 558px;
  right: 0;
  top: 332px;
  padding-right: 15px;
}
.main-img img {
  width: 100%;
  height: auto;
}
.main h1 {
  font-size: 46px;
  font-weight: 800;
  line-height: 66px;
  margin: 1em 0 0;
}
.main h1 span {
  text-decoration-color: rgba(199, 0, 11, 0.3);
  text-decoration-line: underline;
  text-decoration-thickness: 15px;
  text-underline-offset: -5px;
}
.main-text_sab {
  font-size: 18px;
  line-height: 29px;
}
.main-text_sab span {
  font-size: 28px;
}
.main-text_link {
  margin-top: 40px;
}
.main-text_link a {
  text-decoration: none;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  padding: 15px 40px;
  background: #C7000B;
  border-radius: 28px;
  position: relative;
  top: 8px;
}
.main-text_link a:hover {
  background: #fff;
  color: #C7000B;
  border: 1px solid #C7000B;
  transition: 0.5s;
}
@media screen and (max-width: 1000px) {
  .main-img img {
    width: 410px;
  }
}
@media screen and (min-width: 611px) {
  .main-text .sp {
    display: none;
  }
}
@media screen and (max-width: 854px) {
  .main-flex {
    display: block;
  }
  .main-img img {
    top: 60px;
  }
}
@media screen and (max-width: 610px) {
  .main::before {
    transform: skewY(-20deg);
    height: 579px;
  }
  .main-text {
    margin: 130px 0 0;
  }
  .main-text .pc {
    display: none;
  }
  .main-img {
    top: 476px;
    left: 0;
    margin: auto;
    text-align: right;
  }
}
@media screen and (max-width: 430px) {
  .main-img img {
    max-width: 298px;
    width: 100%;
  }
}
.about {
  margin: 100px auto;
  max-width: 1000px;
  padding: 0 15px;
  display: flex;
  justify-content: space-between;
}
.about-img img {
  width: 400px;
  margin-right: 60px;
}
.about h2 {
  text-align: left;
  margin-bottom: 20px;
}
.about h2 img {
  width: 195px;
  padding: 0 5px;
}
.about-text {
  max-width: 500px;
}
@media screen and (max-width: 845px) {
  .about {
    flex-wrap: wrap;
    margin: 140px auto 100px;
  }
  .about-text {
    order: -1;
    margin-bottom: 50px;
    width: 100%;
    max-width: 100%;
  }
  .about-img {
    width: 100%;
    text-align: center;
  }
  .about-img img {
    width: 100%;
    max-width: 500px;
    margin-right: 0;
  }
}
@media screen and (max-width: 470px) {
  .about-img {
    text-align: center;
    width: 100%;
  }
  .about-img img {
    width: 100%;
    margin-right: 0;
    max-width: 270px;
  }
}
.feature {
  margin: 0 auto;
  background-color: #F1F1F1;
  padding: 100px 0;
}
.feature ul {
  list-style: none;
  font-size: 18px;
  max-width: 1000px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-wrap: wrap;
}
.feature ul li {
  padding-right: 0;
  margin-bottom: 36px;
  display: block;
  width: 25%;
  text-align: left;
}
.feature ul li:last-child {
  width: 100%;
}
.feature ul li::before {
  margin-right: 10px;
  content: "";
  display: inline-block;
}
.feature_circle-line::before {
  width: 14px;
  height: 14px;
  border: solid 3px #C7000B;
  border-radius: 50%;
  position: relative;
  top: 3px;
}
.feature p {
  text-align: center;
}
@media screen and (max-width: 830px) {
  .feature ul li {
    width: 33.333%;
  }
}
@media screen and (max-width: 610px) {
  .feature ul li {
    width: 50%;
  }
}
@media screen and (max-width: 430px) {
  .feature {
    text-align: center;
  }
  .feature ul {
    text-align: left;
    padding-left: 0;
    display: inline-block;
  }
  .feature ul li {
    padding-right: 0;
    width: 100%;
  }
}
.price {
  margin: 100px auto;
  max-width: 1000px;
  padding: 0 15px;
}
.price h3 {
  background-color: #C7000B;
  color: #fff;
  text-align: center;
  padding: 10px 0;
  margin: 0;
}
.price-flex {
  display: flex;
  justify-content: space-between;
}
.price-flex_box {
  max-width: 490px;
  text-align: center;
}
.price-p {
  border: solid 2px #C7000B;
  padding: 40px 170px;
  margin: 0;
  font-size: 24px;
}
.price-p span {
  font-size: 16px;
}
@media screen and (max-width: 900px) {
  .price-p {
    padding: 30px 130px;
  }
}
@media screen and (max-width: 827px) {
  .price-p {
    padding: 25px 110px;
  }
}
@media screen and (max-width: 748px) {
  .price-p {
    padding: 20px 90px;
  }
}
@media screen and (max-width: 667px) {
  .price-flex {
    display: block;
  }
  .price-flex_box {
    max-width: 100%;
  }
  .price-flex_box:first-child {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 430px) {
  .price h3 {
    font-size: 18px;
  }
  .price-p p {
    font-size: 21px;
  }
}
.faq {
  margin: 200px auto;
  max-width: 1000px;
  padding: 0 15px;
}
.faq .toggle {
  display: none;
}
.faq .Label {
  padding: 25px 70px 25px 40px;
  display: block;
  background: #F1F1F1;
  font-size: 21px;
  font-weight: 600;
  cursor: pointer;
}
.faq .Label:hover {
  background: #D2D1D1;
}
.faq .Label::before {
  content: "";
  width: 14px;
  height: 14px;
  border-top: 2px solid #C7000B;
  border-right: 2px solid #C7000B;
  -webkit-transform: rotate(45deg);
  position: absolute;
  top: calc(50% - 8px);
  right: 40px;
  transform: rotate(135deg);
}
.faq .Label span {
  padding-left: 20px;
}
.faq .Label, .content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}
.faq .content {
  height: 0;
  font-size: 18px;
  margin-bottom: 10px;
  padding: 0 20px;
  overflow: hidden;
}
.faq .toggle:checked+.Label+.content {
  /*開閉時*/
  height: auto;
  padding: 0px 40px 25px;
  transition: all .3s;
}
.faq .toggle:checked+.Label::before {
  transform: rotate(-45deg) !important;
}
@media screen and (max-width: 612px) {
  .faq .Label {
    padding: 15px 70px 15px 20px;
  }
  .faq .toggle:checked+.Label+.content {
    padding: 0px 20px 15px;
  }
}
.company {
  margin: 100px auto;
  max-width: 1000px;
  padding: 0 15px;
}
.company table {
  font-size: 21px;
}
.company-th {
  text-align: left;
  border-bottom: 2px solid #C7000B;
  width: 240px;
  padding-top: 44px;
}
.company-td {
  border-bottom: 2px solid #F1F1F1;
  padding: 40px 0 0 20px;
  width: 760px;
}
.company a {
  text-decoration: none;
  color: #333;
}
.company th {
  text-align: left;
  border-bottom: 2px solid #C7000B;
  width: 240px;
}
.company td {
  border-bottom: 2px solid #F1F1F1;
  padding-left: 20px;
  width: 760px;
}
@media screen and (max-width: 600px) {
  .company-table tr, .company-table th {
    display: block;
  }
  .company-td, .company td {
    padding: 20px 0 0 20px;
  }
}
.action {
  margin: 0 auto;
  background-color: #F1F1F1;
  padding: 60px 0 80px;
  text-align: center;
}
.action p {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 40px;
  margin-top: 0;
  padding: 0 15px;
}
.action p span {
  font-size: 16px;
}
.action-link a {
  text-decoration: none;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  padding: 15px 40px;
  background: #C7000B;
  border-radius: 28px;
  position: relative;
  top: 8px;
}
.action-link a:hover {
  background: #fff;
  color: #C7000B;
  border: 1px solid #C7000B;
  transition: 0.5s;
}
footer {
  margin: 0 auto;
  padding: 0 15px;
}
footer img {
  width: 200px;
  margin: 20px 0 60px;
}
.footer-logo, .footer-copyright {
  text-align: center;
}