@charset "UTF-8";
html {
  font-size: 10px;
}
@media screen and (max-width: 1400px) {
  html {
    font-size: .71428vw;
  }
}
@media screen and (max-width: 768px) {
  html {
    font-size: 1.333vw;
  }
}
body {
  font-size: 1.6rem;
}
.pc {
  display: block;
}
.sp {
  display: none;
}
#Wrapper img {
  max-width: 100%;
}
#Wrapper a {
  word-break: break-all;
}
a img {
  transition: opacity .4s;
}
a img:hover,
a img:active {
  opacity: .6;
}
.NotoSan900 {
  font-family: 'Noto Sans JP', sans-serif;
}
.pagetop {
  bottom: 5rem;
  right: 3rem;
  width: 9.6rem;
  height: 10.6rem;
}
.wrapper {
  width: 95rem;
  margin: 0 auto;
}
.inner {
  width: 85rem;
  margin: 0 auto;
}
.mv {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 3rem 0;
  background: #f2eabb url('../img/mv_bg.jpg') center top / cover;
}
.mv picture img {
  width: 75.3rem;
  margin: 0 auto;
}
.mv .popup {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding-top: 2.4rem;
  display: flex;
  justify-content: center;
}
.mv .popup > div {
  display: flex;
  flex-direction: column;
}
.mv .popup > div.l {
  align-items: flex-end;
}
.mv .popup > div.r {
  margin-left: 65rem;
  align-items: flex-start;
}
.mv .popup img {
  width: 17rem;
}
.mv .popup > div > div {
  position: relative;
  width: 19.2rem;
  height: 18.8rem;
}
.mv .popup > div > div:nth-child(2) {
  width: 23rem;
  height: 22.6rem;
}
.mv .popup > div.l > div:nth-child(2) {
  margin-right: 3.2rem;
}
.mv .popup > div.r > div:nth-child(2) {
  margin-left: 3.2rem;
}
.mv .popup > div > div > img {
  position: absolute;
  animation: slideAnime 12s ease infinite;
  animation-fill-mode: both;
  animation-play-state: paused;
}
.mv .popup > div > div:nth-child(2) > img {
  width: 23rem;
}
.mv .popup > div > div:nth-child(3) > img {
  margin-top: 15px;
}
.mv .popup > div > div > img:nth-of-type(1) { animation-delay: 0s }
.mv .popup > div > div > img:nth-of-type(2) { animation-delay: 4s }
.mv .popup > div > div > img:nth-of-type(3) { animation-delay: 8s }

@keyframes slideAnime{
  0% { opacity: 0; transform: scale(.1, .1)}
  8% { opacity: 1; transform: scale(1, 1)  }
  25% { opacity: 1; transform: scale(1, 1)  }
  33% { opacity: 0; transform: scale(1.1, 1.1)  }
  100% { opacity: 0; transform: scale(1.1, 1.1)  }
}
section.present {
  padding: 4.5rem 0 5.4rem;
  background: #fff url('../img/red_bg.jpg') center top / cover;
  text-align: center;
}
.label {
  position: relative;
}
.label::after {
  position: absolute;
  content: "";
  top: 99%;
  left: 0;
  right: 0;
  margin: auto;
  display: block;
  width: 13.3rem;
  height: 3.6rem;
  background: url('../img/label_present.png') center top / contain no-repeat;
  z-index: 50;
}
section.details {
  position: relative;
  padding: 14rem 0 10rem;
  background: url('../img/bg_stripe.jpg') center top / 100% 1px repeat-y;
}
section.details::after {
  content: "";
  position: absolute;
  top: 4.8rem;
  left: 0;
  width: 100%;
  height: calc(100% - 4.8rem);
  pointer-events: none;
  background: url('../img/bg_blow.png') center top / 150rem auto repeat-y;
}
section.details .content {
  background: #fff;
  padding-bottom: 6rem;
}
section.details .content.label::after {
  position: static;
  width: 13.3rem;
  height: 3.6rem;
  margin-top: 2rem;
  background: url('../img/label_present.png') center top / contain no-repeat;
}
section.details .content:first-child {
  padding-bottom: 1.6rem;
}
section.details * + .content {
  margin-top: 15rem;
}
section.details .content .inner > .title {
  text-align: center;
  margin-bottom: 3.6rem;
}
section.details .content .inner > .title > img {
  transform: translateY(-4.2rem);
  height: 8.4rem;
}
ul.cards {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}
ul.cards li {
  width: calc((100% - 3rem) / 2);
  background: #fff;
  padding: 0 2rem 2.4rem;
}
ul.cards li h3 {
    margin-bottom: -1rem;
}
ul.steps li {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
}
.blueBorder {
  border: .3rem solid #000;
}
ul.steps li h3 img {
  width: 13.2rem;
  height: 10.4rem;
  transform: translateY(-5.2rem);
}
ul.steps li p.actiton {
  font-size: 2.9rem;
  text-align: center;
  margin-top: -.8em;
  margin-bottom: .5em;
  line-height: 1.3;
}
span.ul {
  background: linear-gradient(to bottom,
    transparent 0%,
    transparent 65%,
    #fff20d 65%,
    #fff20d 90%,
    transparent 90%
  );
}
p.btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
p.btn a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 6.4rem;
  background: linear-gradient(to bottom,
    #ff746d 0%,
    #e60c02 15%,
    #e60c02 50%,
    #c50a02 50%,
    #c50a02 100%
  );
  font-size: 2.6rem;
  color: #fff;
  border-radius: .8rem;
  box-shadow: 0 .6rem 0 0 #651000;
}
p.btn a:hover,
p.btn a:active {
  opacity: .6;
  transition: .3s;
  text-decoration: none;
}
p.btn a::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: auto;
  right: 2.2rem;
  margin: auto;
  width: 1.4rem;
  height: 2.4rem;
  background: url('../img/button_arrow.png') center center / contain no-repeat;
}
ul.steps li p.after {
  margin-top: 1em;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
}
span.orange {
  color: #c5130a;
}
span.blue {
  color: #014099;
}
span.ticon::before {
  content: "";
  display: inline-block;
  width: 2em;
  height: 1.5em;
  line-height: 1.5em;
  vertical-align: middle;
  background: url('../img/t_icon.png') center center / contain no-repeat;
}
span.small {
  font-size: .75em;
}
section.details .content .notice {
  text-align: center;
  margin-top: 1em;
}
section.details .banner {
  padding: 4.2rem 0;
  background: url('../img/red_bg.jpg') center center / cover;
}
ul.hints {
  flex-wrap: wrap;
}
ul.hints li {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  margin-bottom: 8rem;
  padding-bottom: 0;
}
ul.hints li .title {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: column;
  font-size: 2.5rem;
  margin: 1em 0 0;
  text-align: center;
  margin-top: -4.5rem;
}
ul.hints li .title .img {
  flex-shrink: 0;
  margin-bottom: .8em;
}
ul.hints li .title .img img {
  width: 10.8rem;
  height: 8.6rem;
}
section.details h2.best {
  font-size: 2.9rem;
  color: #222;
  margin: 10px auto 20px auto;
  text-align: center;
}
section.details h2.best::before,
section.details h2.best::after {
  content: "";
  display: inline-block;
  width: 3.6rem;
  height: .3rem;
  background: #222;
  vertical-align: middle;
  margin: 0 -.8rem;
  transform: rotate(45deg);
}
section.details h2.best::after {
  transform: rotate(-45deg);
}
section.details h2.best .small {
  font-size: 2.7rem;
}
section.details .invalidExamples ul {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
}
section.details .invalidExamples ul li {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: calc((100% - 3rem) / 2);
  background: #e6e6e6;
  padding: 0 2rem 2.4rem;
  margin-bottom: 7.2rem;
  border-radius: 1rem;
}
section.details .invalidExamples ul li.wide {
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
  margin-bottom: 0;
}
section.details .invalidExamples ul li .bubble {
  width: 10.8rem;
  height: 8.6rem;
  flex-shrink: 0;
}
section.details .invalidExamples ul li .bubble img {
  width: 100%;
  height: 100%;
  transform: translateY(-4.2rem);
}
section.details .invalidExamples ul li .text {
  margin: -1.4em auto .8em;
  font-size: 2.2rem;
}
section.details .invalidExamples ul li .pic img {
  height: 8.1rem;
}
section.details .invalidExamples ul li.wide .bubble {
  width: 100%;
  text-align: center;
}
section.details .invalidExamples ul li .bubble img {
    width: 10.8rem;
    height: 8.6rem;
}
section.details .invalidExamples ul li.wide .text {
  margin: auto 2.8rem auto auto;
}
section.details .invalidExamples ul li.wide .pic {
  margin-right: auto;
}
section.details .invalidExamples ul li .pic img {
  height: 8.1rem;
}
section.details .invalidExamples ul li .prohibited {
  margin: 1em auto 0;
}
.arrowLink {
  display: inline-block;
  margin-top: .5em;
}
.arrowLink::before {
  content: "";
  display: inline-block;
  width: .8em;
  height: 1em;
  background: url('../img/arrowlink.png') center center / contain no-repeat;
  vertical-align: middle;
}
.arrowLink a {
  color: #014099;
  text-decoration: underline;
}
section.after {
  padding: 6rem 0 4.2rem;
  background: url('../img/red_bg.jpg') center center / cover;
  text-align: center;
}
section.after .wrapper > h2 {
  width: 100%;
  font-size: 3.4rem;
  color: #fff;
  margin-bottom: 2.4em;
}
section.after p.notice {
  color: #fff;
  font-weight: bold;
  margin-top: 2em;
}
section.notice {
  padding: 8rem 0 0;
  background: #fff;
}
section.notice h2 {
  font-size: 2.4rem;
  color: #222;
  border: 1px solid #222;
  border-width: 5px 0 2px;
  padding: .8em 0;
  font-weight: bold;
  margin: 0;
}
section.notice h3 {
  font-size: 1.6rem;
  line-height: 1.5;
  border-left: .5rem solid #c99105;
  padding-left: .8em;
  font-weight: bold;
  margin-top: 2em;
}
section.notice p,
section.notice ul {
  margin-top: 1em;
  line-height: 2;
  font-size: 1.4rem;
  padding-left: .8em;
}
section.notice p .bold{
  font-weight: bold;
}
section.notice p .bold{
  font-weight: bold;
}
section.notice a {
  color: #003384;
  text-decoration: underline;
}
section.notice ul li {
  padding-left: 1em;
  text-indent: -1em;
  font-size: 1.4rem;
  line-height: 2;
}
#gfooter .inner ul li {
  font-size: 12px;
}
#toTop {
  position: fixed;
  bottom: 6rem;
  right: 3rem;
  margin: auto;
  display: block;
  width: 9.6rem;
  height: 10.6rem;
  background: url('../img/totop.png') center center / contain no-repeat;
  z-index: 101;
}
@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  .wrapper {
    width: 100%;
    padding: 0 3rem;
  }
  .inner {
    width: 100%;
    padding: 0 3rem;
  }
  .mv .popup > div.r {
    margin-left: 42rem;
  }
  .mv .popup img {
    width: 14.8rem;
  }
  .mv .popup > div > div {
    width: 14.8rem;
  }
  .mv .popup > div > div:nth-child(2) > img {
    width: 16rem;
  }
  .mv .popup > div > div:nth-child(2) {
    width: 16rem;
  }
  .mv .popup > div.l > div:nth-child(2) {
    margin-right: 0rem;
  }
  .mv .popup > div.r > div:nth-child(2) {
    margin-left: 0rem;
  }
  .mv .popup > div > div:nth-child(3) > img {
    margin-top: 0;
  }
  ul.cards {
    flex-direction: column;
  }
  ul.cards li {
    width: 100%;
    padding-bottom: 4rem;
  }
  ul.cards li + li {
    margin-top: 8rem;
  }
  ul.cards li h3 {
    margin-bottom: -3rem;
  }
  ul.steps li h3 img {
    width: 15.8rem;
    height: 12.6rem;
    transform: translateY(-6.6rem);
  }
  ul.steps li p.actiton {
    font-size: 3.6rem;
    margin-top: -.4em;
  }
  p.btn a {
    width: 47rem;
    height: 8rem;
    font-size: 3.3rem;
  }
  ul.steps li p.after {
    font-size: 3rem;
  }
  span.small {
    font-size: .8em;
  }
  ul.hints {
    flex-direction: row;
  }
  ul.hints li {
    width: calc((100% - 3rem) / 2);
    margin: 0 0 9rem;
    padding: 0;
  }
  ul.hints li + li {
    margin: 0 0 9rem;
  }
  ul.hints li .title {
    flex-direction: column;
    margin-top: 0;
    text-align: center;
    font-size: 3rem;
    margin-bottom: 2.0rem;
    padding: 0;
  }
  ul.hints li .title .img {
    margin: 0;
    margin-bottom: -3.6rem;
  }
  ul.hints li .title .img img {
    width: 12.2rem;
    height: 9.8rem;
    transform: translate(0, -5.2rem);
  }
  section.details::after {
    top: 0;
    height: calc(100% - 9rem);
  }
  section.details .content {
    position: relative;
  }
  section.details .content::before {
    content: "";
    position: absolute;
    left: -3rem;
    right: -3rem;
    margin: auto;
    bottom: calc(100% + 3rem);
    width: calc(100% + 6rem);
    height: 10rem;
    background: url('../img/bg_blow_top.png') center center / contain no-repeat;
  }
  section.details h2.best {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 3.8rem;
    margin-top: -3rem;
  }
  section.details h2.best span {
    margin: 0 0.4rem;
  }
  section.details h2.best::before,
  section.details h2.best::after {
    width: 4.5rem;
    height: .5rem;
  }
  section.details .invalidExamples ul {
    flex-direction: column;
  }
  section.details .invalidExamples ul li,
  section.details .invalidExamples ul li.wide {
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: center;
    padding: 2rem 3rem;
    width: 100%;
  }
  section.details .invalidExamples ul li .bubble {
    width: 100%;
    height: 9.8rem;
    text-align: center;
  }
  section.details .invalidExamples ul li .bubble img,
  section.details .invalidExamples ul li.wide .bubble img {
    transform: translate(0, -6.4rem);
  }
  section.details .invalidExamples ul li .text,
  section.details .invalidExamples ul li.wide .text {
    width: calc(100% - 12.2rem);
    font-size: 2.7rem;
    margin: -3rem 0 1em;
    text-align: center;
  }
  section.details .invalidExamples ul li .pic,
  section.details .invalidExamples ul li.wide .pic {
    margin: 0 auto;
  }
  section.details .invalidExamples ul li .pic img,
  section.details .invalidExamples ul li.wide .pic img {
    height: 9rem;
  }
  section.details .invalidExamples ul li .prohibited {
    font-size: 2.4rem;
  }
  section.after .wrapper > h2 {
    margin-left: 0;
    margin-right: 0;
    font-size: 3.8rem;
    letter-spacing: -1px;
  }
  section.notice {
    padding: 7rem 0;
  }
  section.notice h2 {
    font-size: 3.2rem;
  }
  section.notice h3 {
    font-size: 2.6rem;
  }
  section.notice p {
    font-size: 2.4rem;
  }
  section.notice ul li {
    font-size: 2.4rem;
  }
  .pagetop {
    position: fixed;
    bottom: 3.2rem;
    right: 2rem;
    width: 12.0rem;
    height: 12.8rem;
  }
}