@charset "UTF-8";
/*リセット
--------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline; }

html {
  line-height: 1; }

ol, ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle; }

q, blockquote {
  quotes: none; }
q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none; }

a img {
  border: none; }

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block; }

@font-face {
  font-family: 'CaslonGraD';
  font-style: normal;
  src: url("../font/CaslonGraD.eot");
  src: url("../font/CaslonGraD.eot?#iefix") format("embedded-opentype"), url("../font/CaslonGraD.woff") format("woff"), url("../font/CaslonGraD.ttf") format("truetype");
  /* Safari, Android, iOS */ }
/*変数
---------------------------------------------*/
/*全体
---------------------------------------------*/
body {
  font-feature-settings: "palt";
  letter-spacing: 1px;
  font-family: 'Montserrat', sans-serif; }

a {
  -webkit-transition: all 0.7s;
  -moz-transition: all 0.7s;
  -ms-transition: all 0.7s;
  -o-transition: all 0.7s;
  transition: all 0.7s;
  opacity: 1;
  text-decoration: none; }

a:hover {
  opacity: 0.6;
  filter: alpha(opacity=60);
  -ms-filter: "alpha(opacity=60)"; }

.fixedsticky {
  top: 0;
  z-index: 10; }

.inviewfadeInUp {
  opacity: 0;
  transform: translate(0, 7px);
  -webkit-transform: translate(0, 7px);
  transition: 0.8s; }

.fadeInUp {
  opacity: 1.0;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0); }

.inviewfadeInUp2 {
  opacity: 0;
  transform: translate(0, 7px);
  -webkit-transform: translate(0, 7px);
  transition: 0.8s;
  transition-delay: .6s; }

.fadeInUp2 {
  opacity: 1.0;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0); }

#pageTop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 999; }

#pageTop a {
  display: block;
  padding: 8px 0 0 8px;
  border-radius: 30px;
  color: #000;
  border: 1px solid #000;
  text-decoration: none;
  text-align: center; }

#pageTop a:hover {
  text-decoration: none; }

/*head -------------------------*/
#head {
  background-color: #d83568;
  width: 100%; }
#head img {
  -webkit-animation: main_img 1.0s linear 1 forwards;
  animation: main_img 1.0s linear 1 forwards; }

#contents {
  margin: 0 auto; }

.box li span {
  border: 1px solid #5e5e5e; }
.box li a {
  color: #000; }

.category {
  font-size: 11px;
  padding-bottom: 10px; }
.category span {
  font-weight: bold; }

.category_r {
  text-align: right; }

.category_l {
  text-align: left; }

.credit {
  display: flex;
  justify-content: space-between;
  width: 100%; }
.credit p {
  font-family: 'CaslonGraD';
  border-bottom: 5px solid #000; }

.sub_title_1 {
  margin: 0 auto; }

/*box1 -------------------------*/
.end_img {
  margin: 0 auto; }

#allitems {
  text-align: center; }
#allitems a {
  border: 1px solid #000;
  color: #000; }

.sub_title_2 {
  background-color: #d4b684; }
.sub_title_2 img {
  display: block;
  margin: 0 auto; }

#box_sns {
  text-align: center;
  font-weight: bold; }
#box_sns a {
  color: #000;
  border-bottom: 1px solid #000; }

footer {
  background-color: #d83568; }
footer ul {
  text-align: center;
  color: #fff; }
footer ul li span {
  font-size: 10px; }

#logo {
  margin: 0 auto; }

#copyright p {
  text-align: center;
  color: #fff;
  font-size: 10px; }

/* PC
--------------------------------------*/
@media screen and (min-width: 668px) {
  body {
    font-feature-settings: "palt";
    letter-spacing: 1px;
    font-family: 'Montserrat', sans-serif; }

  .pc_none {
    display: none; }

  .fixedsticky {
    top: 0;
    z-index: 10; }

  .inviewfadeInUp {
    opacity: 0;
    transform: translate(0, 7px);
    -webkit-transform: translate(0, 7px);
    transition: 0.8s; }

  .fadeInUp {
    opacity: 1.0;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0); }

  .inviewfadeInUp2 {
    opacity: 0;
    transform: translate(0, 7px);
    -webkit-transform: translate(0, 7px);
    transition: 0.8s;
    transition-delay: .6s; }

  .fadeInUp2 {
    opacity: 1.0;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0); }

  #pageTop a {
    width: 35px;
    height: 35px; }

  i {
    padding: 4px 5px 0 0; }

  /*head -------------------------*/
  #head {
    height: 100vh;
    position: relative; }
  #head #main_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 80%;
    margin: 0 auto;
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%); }
  #head #main_img {
    width: 50%; }
  #head h1 {
    width: 40%; }

  #contents {
    max-width: 1100px; }

  .box {
    margin: 200px auto 0 auto; }
  .box ul {
    text-align: left;
    padding-top: 15px; }
  .box li {
    line-height: 280%;
    font-size: 10px; }
  .box li span {
    padding: 3px 30px; }

  .category {
    font-size: 11px; }

  .credit p {
    font-size: 65px;
    padding-top: 10px;
    height: 70px; }

  .first_box {
    width: 50%;
    margin: 0 auto 50px; }

  .sub_title_1 {
    width: 40%;
    padding-top: 100px; }

  .box07_1 {
    width: 50%;
    margin: 100px auto 0 auto; }

  .end_box {
    width: 50%;
    padding-bottom: 200px; }

  .flex {
    display: flex;
    justify-content: space-between;
    width: 100%; }

  /*box1 -------------------------*/
  .flex_left {
    width: 45%; }

  .flex_right {
    width: 45%; }

  .end_img {
    width: 50%; }

  #allitems {
    margin-bottom: 200px;
    font-size: 16px; }
  #allitems a {
    padding: 20px 200px; }

  .sub_title_2 {
    width: 100%;
    padding: 200px 0; }
  .sub_title_2 img {
    width: 25%; }

  #box_sns {
    padding-top: 50px; }
  #box_sns p {
    line-height: 25px;
    font-size: 15px; }

  footer ul {
    padding: 50px; }
  footer ul li {
    font-size: 11px;
    padding-bottom: 20px;
    line-height: 14px; }

  #logo {
    width: 10%; }

  #copyright p {
    padding: 20px 0 50px 0; } }
/* SP
--------------------------------------*/
@media screen and (max-width: 667px) {
  body {
    font-feature-settings: "palt";
    letter-spacing: 1px;
    font-family: 'Montserrat', sans-serif; }

  .sp_none {
    display: none; }

  .fixedsticky {
    top: 0;
    z-index: 10; }

  .inviewfadeInUp {
    opacity: 0;
    transform: translate(0, 7px);
    -webkit-transform: translate(0, 7px);
    transition: 0.8s; }

  .fadeInUp {
    opacity: 1.0;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0); }

  .inviewfadeInUp2 {
    opacity: 0;
    transform: translate(0, 7px);
    -webkit-transform: translate(0, 7px);
    transition: 0.8s;
    transition-delay: .6s; }

  .fadeInUp2 {
    opacity: 1.0;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0); }

  #pageTop a {
    width: 30px;
    height: 30px; }

  i {
    padding: 2px 6px 0 0; }

  /*head -------------------------*/
  #head {
    margin: 0 auto;
    height: 90vh; }
  #head #main_img {
    width: 70%;
    margin: 20px auto; }
  #head h1 {
    width: 80%;
    margin: 0px auto; }
  #head .title_sp_2 {
    width: 80%;
    margin: 0 auto; }

  #main_sp {
    display: table;
    height: 90vh; }

  .description {
    display: table-cell;
    vertical-align: middle; }

  #contents {
    width: 90%; }

  .box {
    margin: 70px auto 0 auto; }
  .box ul {
    padding-top: 15px; }
  .box li {
    line-height: 280%;
    font-size: 11px;
    text-align: left; }
  .box li span {
    padding: 3px 20px; }

  .category {
    font-size: 10px; }

  .credit p {
    font-size: 40px;
    padding-top: 15px;
    height: 43px; }

  .first_box {
    margin: 0 auto 30px; }

  .sub_title_1 {
    width: 80%;
    padding-top: 70px; }

  .end_box {
    padding-bottom: 70px; }

  /*box1 -------------------------*/
  .sp_imgtop {
    padding-top: 70px; }

  .sp_imgtopS {
    padding-top: 30px; }

  #allitems {
    margin-bottom: 70px;
    font-size: 13px; }
  #allitems a {
    padding: 15px 100px; }

  .sub_title_2 {
    width: 100%;
    padding: 70px 0; }
  .sub_title_2 img {
    width: 50%; }

  #box_sns {
    padding-top: 30px; }
  #box_sns p {
    line-height: 18px;
    font-size: 13px; }

  footer ul {
    padding: 30px; }
  footer ul li {
    font-size: 11px;
    padding-bottom: 10px;
    line-height: 13px; }

  #logo {
    width: 25%; }

  #copyright p {
    padding: 10px 0 30px 0; } }
