@import url("https://fonts.googleapis.com/css?family=Oswald:200");
@font-face {
  font-family: 'Airlines';
  src: url(../fonts/Airlines-Regular.eot);
  src: url(../fonts/Airlines-Regular.eot?#iefix) format("embedded-opentype"), url(../fonts/Airlines-Regular.woff) format("woff"), url(../fonts/Airlines-Regular.ttf) format("truetype"), url(../fonts/Airlines-Regular.otf), url(../fonts/Airlines-Regular.svg#svgFontName) format("svg");
}

p.text1 {
  font-size: 2.945vw;
  letter-spacing: 8px;
}

@media screen and (min-width: 750px) {
  p.text1 {
    font-size: 34px;
  }
}

p.text1 span {
  position: relative;
  padding: 0 3%;
}

@media screen and (min-width: 750px) {
  p.text1 span {
    padding: 0 20px;
  }
}

p.text1 span:after {
  content: '';
  position: absolute;
  width: 100%;
  height: 2.5vw;
  background-color: #ffc655;
  left: 0;
  bottom: -5px;
  z-index: -1;
}

@media screen and (min-width: 750px) {
  p.text1 span:after {
    height: 25px;
  }
}

p.text2 {
  font-size: 10.373vw;
  color: #000;
  line-height: normal;
}

@media screen and (min-width: 750px) {
  p.text2 {
    font-size: 120px;
  }
}

@media screen and (max-width: 599px) {
  p.text3 {
    font-size: 2vw;
  }
}

@media screen and (max-width: 599px) {
  #sec02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

#sec02 h2 {
  font-size: 30px;
  color: #000;
  line-height: normal;
  font-weight: bold;
}

@media screen and (min-width: 750px) {
  #sec02 h2 {
    font-size: 50px;
    letter-spacing: -2px;
  }
}

@media screen and (max-width: 599px) {
  #sec02 h2 {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin-top: 40px;
    margin-bottom: 0;
  }
}

#sec02 .title {
  position: relative;
  display: inline-block;
  padding: 0 20px;
}

#sec02 .title:after {
  content: '';
  position: absolute;
  width: 100%;
  height: 25px;
  background-color: #ffc25f;
  left: 0;
  bottom: 5px;
}

#sec02 .title span {
  font-size: 28px;
  font-weight: bold;
  color: #000;
  line-height: normal;
  position: relative;
  z-index: 1;
  font-family: 'Oswald', sans-serif;
}

@media screen and (min-width: 750px) {
  #sec02 .title span {
    font-size: 60px;
    letter-spacing: -2px;
  }
}

#sec02 .box-column {
  background-color: #fff097;
  padding: 10px;
  text-align: center;
}

@media screen and (min-width: 750px) {
  #sec02 .box-column {
    padding: 30px;
  }
}

#sec02 .box-column .box-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-left: -15px;
  margin-right: -15px;
}

#sec02 .box-column .box-item {
  width: calc(100% / 2);
  padding-left: 3%;
  padding-right: 3%;
  padding-bottom: 6%;
}

@media screen and (min-width: 750px) {
  #sec02 .box-column .box-item {
    width: calc(100% / 3);
    padding-left: 15px;
    padding-right: 15px;
    padding-bottom: 30px;
    padding-top: 30px;
  }
  #sec02 .box-column .box-item + .box-item {
    border-left: 5px solid #fff;
  }
  #sec02 .box-column .box-item.box-item:nth-child(4n) {
    border-left: none;
  }
  #sec02 .box-column .box-item.box-item:first-child, #sec02 .box-column .box-item.box-item:nth-child(2), #sec02 .box-column .box-item.box-item:nth-child(3) {
    padding-top: 0;
  }
  #sec02 .box-column .box-item.box-item:nth-child(4), #sec02 .box-column .box-item.box-item:nth-child(5), #sec02 .box-column .box-item.box-item:nth-child(6) {
    border-top: 5px solid #fff;
  }
}

#sec02 .box-column .box-item h3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  margin-bottom: 15px;
  line-height: 1.2;
}

@media screen and (min-width: 750px) {
  #sec02 .box-column .box-item h3 {
    min-height: 60px;
  }
}

#sec02 .box-column .box-item h3 div {
  line-height: normal;
  font-size: 14px;
  font-family: 'Oswald', sans-serif;
  padding-left: 30px;
  font-weight: bold;
}

@media screen and (min-width: 750px) {
  #sec02 .box-column .box-item h3 div {
    font-size: 20px;
    padding-left: 70px;
  }
}

@media screen and (max-width: 749px) {
  #sec02 .box-column .box-item h3 div {
    font-size: 3vw;
    padding-left: 40px;
  }
  #sec02 .box-column .box-item h3 div span {
    position: relative;
    display: inline-block;
    word-break: keep-all;
    z-index: 10;
  }
  #sec02 .box-column .box-item h3 div span:after {
    content: '';
    position: absolute;
    width: 100%;
    height: 5px;
    background-color: #ffc25f;
    left: 0;
    bottom: 2px;
    z-index: -1;
  }
}

#sec02 .box-column .box-item h3:before {
  content: '';
  position: absolute;
  left: 0;
  width: 30px;
  height: 30px;
  background-size: 100% auto;
  background-repeat: no-repeat;
  margin-right: 10px;
}

@media screen and (min-width: 750px) {
  #sec02 .box-column .box-item h3:before {
    width: 60px;
    height: 60px;
    background-size: 60px auto;
  }
}

#sec02 .box-column .box-item .desc {
  font-family: 'Oswald', sans-serif;
  letter-spacing: normal;
  font-size: 14px;
  line-height: 1.6;
  padding: 10px;
  background-color: #fff;
}

@media screen and (min-width: 750px) {
  #sec02 .box-column .box-item .desc {
    font-size: 20px;
    padding: 0;
    background-color: transparent;
  }
}

#sec02 .box-column .box-item.box-item:first-child h3:before {
  content: '';
  background-image: url(../img/tokusetsu/icon01.png);
}

#sec02 .box-column .box-item.box-item:nth-child(2) h3:before {
  content: '';
  background-image: url(../img/tokusetsu/icon02.png);
}

#sec02 .box-column .box-item.box-item:nth-child(3) h3:before {
  content: '';
  background-image: url(../img/tokusetsu/icon03.png);
}

#sec02 .box-column .box-item.box-item:nth-child(4) h3:before {
  content: '';
  background-image: url(../img/tokusetsu/icon04.png);
}

#sec02 .box-column .box-item.box-item:nth-child(5) h3:before {
  content: '';
  background-image: url(../img/tokusetsu/icon05.png);
}

#sec02 .box-column .box-item.box-item:nth-child(6) h3:before {
  content: '';
  background-image: url(../img/tokusetsu/icon06.png);
}

.recomm-box {
  border: 1px solid #7c7c7c;
  margin-bottom: 30px;
  padding: 30px;
}

@media screen and (min-width: 750px) {
  .recomm-box {
    padding: 40px;
    margin-bottom: 60px;
  }
}

.recomm-box a {
  -webkit-transition: all .25s linear;
  transition: all .25s linear;
}

.recomm-box a:hover {
  opacity: 0.75;
  -webkit-filter: opacity(75);
          filter: opacity(75);
}

@media screen and (min-width: 900px) {
  .recomm-box .d-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.recomm-box .d-flex .recomm-cont > * {
  text-align: center;
}

.recomm-box .d-flex .recomm-cont > * > * {
  text-align: center;
}

@media screen and (min-width: 900px) {
  .recomm-box .d-flex .recomm-cont {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: calc(100% - 40%);
    padding-right: 3%;
  }
}

.recomm-box .d-flex .recomm-cont h3 {
  border-bottom: 1px solid #000;
  padding-bottom: 20px;
  margin-bottom: 20px;
}

.recomm-box .d-flex .recomm-cont p {
  padding: 0 4%;
  margin-bottom: 30px;
}

.recomm-box .d-flex .recomm-cont .note {
  padding: 0 5%;
}

.recomm-box .d-flex .recomm-img {
  text-align: center;
}

@media screen and (min-width: 900px) {
  .recomm-box .d-flex .recomm-img {
    width: 40%;
  }
}

.recomm-box .d-flex .recomm-img a {
  padding: 0 15%;
  display: block;
  text-align: center;
}

#recomm-02 .d-flex {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

#recomm-02 .d-flex .recomm-cont {
  padding: 0 10%;
}

.box-gray {
  background-color: #9b9b9b;
  color: #fff;
  text-align: center;
  line-height: normal;
  font-family: 'Oswald', sans-serif;
  margin: 0 8% 10%;
  padding: 3%;
  font-size: 18px;
}

@media screen and (min-width: 750px) {
  .box-gray {
    padding: 30px;
    font-size: 30px;
  }
}
/*# sourceMappingURL=tokusetsu.css.map */