.bg-stripe {
  background: url("/common/img/bg_strip.png");
  background-size: 96px 96px;
}

.bg-light-pink {
  background: #FDF3F6;
}

/*============================
#main
============================*/
div#main {
  /*============================
  #sec01
  ============================*/
  /*============================
  #sec02
  ============================*/
  /*============================
  #sec03
  ============================*/
  /*============================
  .sns
  ============================*/
}
@media screen and (max-width: 767px) {
  div#main #sec01 {
    padding-top: 40px !important;
  }
}
div#main #sec01 div.w960 {
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  div#main #sec01 div.w960 {
    display: block;
  }
}
div#main #sec01 div.w960 div.news {
  width: 100%;
  border-radius: 20px 0 0 20px;
  position: relative;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  div#main #sec01 div.w960 div.news {
    padding: 20px 0 0;
    display: block;
  }
}
div#main #sec01 div.w960 div.news h2 {
  line-height: 1;
  margin: -0.5em auto 0;
  text-align: center;
  color: #DE5183;
  font-size: 30px;
  position: absolute;
  left: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  div#main #sec01 div.w960 div.news h2 {
    width: 100%;
    margin: auto;
    font-size: 20px;
    position: absolute;
    left: 0;
    top: 0;
    top: -0.5em;
  }
}
div#main #sec01 div.w960 div.news ul {
  list-style: none;
  margin: 0;
  padding: 2em;
  box-sizing: border-box;
  background: #FDF3F6;
  border-radius: 20px;
  margin-bottom: 20px;
}
div#main #sec01 div.w960 div.news ul li {
  margin: 0;
  padding: 0;
  display: flex;
}
@media screen and (max-width: 767px) {
  div#main #sec01 div.w960 div.news ul li {
    display: block;
    line-height: 1.5;
    margin-bottom: 1em;
  }
}
div#main #sec01 div.w960 div.news ul li span {
  display: block;
}
div#main #sec01 div.w960 div.news ul li span.date {
  padding-right: 1em;
}
div#main #sec01 div.w960 div.news ul li span.newsttl {
  box-sizing: border-box;
}
div#main #sec01 div.w960 div.news ul li a {
  color: #DE5183;
  text-decoration: underline;
}
div#main #sec01 div.w960 div.news ul li a:hover {
  text-decoration: none;
}
div#main #sec01 div.w960 div.news .photos {
  max-width: 600px;
  margin: auto;
}
div#main #sec01 div.w960 div.news .photos figure {
  flex: 0 0 49%;
}
div#main #sec02 {
  background-image: url("img/flag.png"), url("common/img/bg_strip.png");
  background-size: 100% auto, auto;
  background-repeat: no-repeat, repeat;
  background-position: top center, left top;
  position: relative;
}
@media screen and (max-width: 767px) {
  div#main #sec02 {
    padding: 20px 0 50px;
  }
}
div#main #sec02 figure {
  max-width: 930px;
  margin: auto;
}
div#main #sec02 .photos {
  padding-top: 20px;
}
@media screen and (max-width: 767px) {
  div#main #sec02 .photos {
    padding: 0 20px;
  }
}
div#main #sec02 .photos figure {
  flex: 0 0 24%;
}
@media screen and (max-width: 767px) {
  div#main #sec02 .photos figure {
    padding: 10px 0;
  }
}
div#main #sec02 .photos figure img {
  border-radius: 20px;
}
div#main #sec02 button {
  display: inline-block;
  background: #DE5183;
  width: 360px;
  height: 70px;
  line-height: 70px;
  border-radius: 35px;
  border: none;
  margin: auto;
  position: absolute;
  left: 50%;
  bottom: -35px;
  transform: translateX(-50%);
  font-weight: 600;
  letter-spacing: 0.1em;
  font-size: 22px;
}
@media screen and (max-width: 767px) {
  div#main #sec02 button {
    width: 80%;
    height: 50px;
    line-height: 50px;
    border-radius: 25px;
    font-size: 18px;
    padding: 0 2em;
    letter-spacing: 0.05em;
  }
}
div#main #sec02 button a {
  display: block;
  color: #fff;
  text-decoration: none;
}
div#main #sec02 button a i {
  position: absolute;
  right: 10px;
  top: 33%;
}
div#main #sec03 {
  background: #FDF3F6;
  padding: 88px 30px 60px;
}
div#main #sec03 h2 {
  margin: 0;
  padding: 0 0 60px;
  font-size: 26px;
  text-align: center;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 767px) {
  div#main #sec03 h2 {
    font-size: 5vw;
  }
}
div#main #sec03 ul {
  list-style: none;
  margin: auto;
  padding: 0;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  div#main #sec03 ul {
    flex-wrap: wrap;
  }
}
div#main #sec03 ul li {
  flex: 0 0 23.4375%;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 767px) {
  div#main #sec03 ul li {
    flex: 0 0 48%;
    margin-bottom: 4%;
  }
}
div#main .sns {
  overflow: hidden;
}
div#main .insta {
  text-align: center;
  padding: 60px 20px;
}
div#main .insta a {
  display: block;
  max-width: 350px;
  margin: auto;
}
div#main .insta a img {
  border: 1px solid #eee;
}