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-size: 100%;
  font: inherit;
  vertical-align: baseline; }

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

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

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

input {
  outline: none; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
  letter-spacing: .075em;
  line-height: 1.65;
  font-weight: 400;
  text-rendering: optimizelegibility;
  font-synthesis: none;
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: 100%;
  color: #585858;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: .02em;
  text-align: justify;
  text-justify: inter-word;
  background-color: #F6F6F6; }

html, body {
  margin: 0;
  padding: 0; }

#wrapper {
  min-height: 100%;
  margin-bottom: -40px; }
  #wrapper:after {
    content: "";
    display: block;
    height: 40px; }

a {
  text-decoration: none; }

h2 {
  font-size: 30px;
  margin: 1rem auto 1rem 20vw;
  line-height: 2.5rem;
  color: #92726E; }
  @media screen and (max-width: 480px) {
    h2 {
      margin: 0 auto;
      font-size: 18px;
      line-height: 1.6rem; } }

h3 {
  font-size: 24px; }

.text_center {
  text-align: center; }

.pc_none {
  display: none; }

.en-font {
  font-family: 'PT Serif Caption';
  letter-spacing: 0; }

@media screen and (max-width: 768px) {
  .sp_none {
    display: none; }
  .pc_none {
    display: block; } }

.side-menu-pc {
  background: #AED7E0;
  width: 300px;
  height: 100vh;
  padding: 20px 25px 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: fixed;
  z-index: 100;
  top: 0; }
  .side-menu-pc img {
    width: 140px;
    margin: 0 auto;
    display: block; }
  .side-menu-pc .pc-menu {
    padding: 0 0 0 75px;
    margin-top: 40px;
    list-style-type: none;
    position: relative; }
    .side-menu-pc .pc-menu:after {
      width: 9px;
      height: 506px;
      background-color: #7AC7D8;
      content: "";
      display: block;
      position: absolute;
      top: 0;
      left: 45px;
      border-radius: 20px; }
    .side-menu-pc .pc-menu li {
      margin-bottom: 16px;
      position: relative;
      line-height: 1.1rem;
      cursor: pointer; }
      .side-menu-pc .pc-menu li span {
        display: block;
        font-size: 12px;
        color: #2CA9BE; }
      .side-menu-pc .pc-menu li:after {
        background-color: #fff;
        content: "";
        display: block;
        position: absolute;
        top: -5px;
        left: -38px;
        width: 10px;
        height: 10px;
        border: 8px solid #7AC7D8;
        border-radius: 20px;
        z-index: 5; }
    .side-menu-pc .pc-menu li:hover:after, .side-menu-pc .pc-menu .picked:after {
      background-color: #FFF856; }
  .side-menu-pc .sp-menu {
    display: none; }
  @media screen and (max-width: 1300px) {
    .side-menu-pc {
      display: none; } }

.sns_icon {
  position: absolute;
  bottom: 40px;
  left: 50%;
  margin-left: -75px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-around;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  width: 150px; }
  .sns_icon img {
    height: 23px;
    width: auto; }
  @media screen and (max-width: 480px) {
    .sns_icon {
      margin: 20px auto 0 -75px;
      border: none;
      bottom: 10px;
      padding: 0 !important; }
      .sns_icon li {
        border: none !important; } }

.menu_color {
  color: #c8d9e8;
  padding-left: 1.5rem !important; }

.side-menu-sp {
  background: #7ac7d8;
  width: 450px;
  height: 100vh;
  padding: 70px 25px 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: fixed;
  top: 0;
  z-index: 1000;
  text-align: center;
  display: none; }
  .side-menu-sp img {
    width: 100%;
    max-width: 350px; }
  .side-menu-sp ul {
    padding: 0 20px;
    margin-top: 5vh;
    list-style-type: none;
    text-align: left;
    color: #fff; }
    .side-menu-sp ul li {
      margin-bottom: 1rem;
      padding: 0 0 10px 0;
      border-bottom: 1px solid #fff;
      cursor: pointer; }
      .side-menu-sp ul li img {
        height: 15px;
        width: auto;
        margin-left: 20px; }
    .side-menu-sp ul a {
      color: #fff; }
  .side-menu-sp .pc-menu {
    display: none; }
  @media screen and (max-width: 480px) {
    .side-menu-sp {
      width: 85%;
      padding: 15px 10px 0; }
      .side-menu-sp ul {
        margin-top: 20px; }
        .side-menu-sp ul li {
          padding-bottom: 10px;
          margin-bottom: 10px;
          white-space: nowrap;
          border-bottom: 1px solid #ffffff63; }
      .side-menu-sp img {
        width: 140px; } }
  @media screen and (max-width: 320px) {
    .side-menu-sp ul {
      font-size: 0.9rem;
      padding: 0 5px; } }

#topmenu {
  display: none;
  position: fixed;
  min-width: 1100px;
  top: 0;
  left: 0;
  width: 100%;
  height: 80px;
  background: #AED7E0;
  z-index: 100; }
  #topmenu .menu {
    position: absolute;
    right: 5%;
    top: 15px; }
    #topmenu .menu li {
      color: #2CA9BE;
      float: left;
      font-size: 12px;
      width: 120px;
      text-align: center;
      cursor: pointer;
      position: relative; }
      #topmenu .menu li:after {
        content: "";
        display: block;
        position: absolute;
        top: 20px;
        left: 50px;
        width: 8px;
        height: 8px;
        background-color: #Fff;
        border: 5px #7AC7D8 solid;
        border-radius: 20px;
        z-index: 10; }
    #topmenu .menu li:nth-child(even) {
      margin: 35px -50px 0 -50px; }
      #topmenu .menu li:nth-child(even):after {
        top: -16px; }
    #topmenu .menu li:hover:after, #topmenu .menu .picked:after {
      background-color: #FFF856; }
    #topmenu .menu:after {
      content: "";
      display: block;
      position: absolute;
      top: 24px;
      left: -40px;
      width: 1100px;
      height: 7px;
      background-color: #7AC7D8;
      border-radius: 20px; }
  #topmenu .topmenu_img {
    position: absolute;
    top: 17px;
    right: 870px; }
    #topmenu .topmenu_img img {
      width: 40px; }
  #topmenu .sns_icon {
    left: 30px;
    margin: 0;
    top: 26px; }
  @media screen and (max-width: 1300px) {
    #topmenu {
      display: block; } }
  @media screen and (max-width: 480px) {
    #topmenu {
      display: none; } }

footer {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  min-width: 980px;
  background: #7AC7D8;
  color: #fff;
  text-align: center;
  padding: 3rem 0; }
  footer p {
    font-size: 0.8rem; }
  @media screen and (max-width: 480px) {
    footer p {
      font-size: 1rem; } }
  @media screen and (max-width: 980px) {
    footer {
      margin-left: 0;
      min-width: initial; } }
  footer:after {
    content: "";
    display: block;
    clear: both; }
  footer .sns {
    background-size: auto  100%;
    background-position: top center;
    background-repeat: no-repeat;
    width: 60px;
    height: 20px;
    margin: 10px auto 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
    justify-content: space-around; }
    footer .sns a {
      display: block;
      margin: 0 12px; }
      footer .sns a img {
        height: 20px; }

#spmenu-icon {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2000;
  cursor: pointer;
  width: 50px;
  height: 48px;
  background: #7ac7d8; }
  #spmenu-icon img {
    width: 30px; }
  #spmenu-icon div {
    width: 30px;
    height: 3px;
    position: absolute;
    left: 10px;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis;
    background-color: #fff;
    background-position: 50% 50%;
    -webkit-background-origin: padding-box;
    background-origin: padding-box;
    -webkit-background-clip: border-box;
    background-clip: border-box;
    -webkit-background-size: auto auto;
    background-size: auto auto; }
  #spmenu-icon div:nth-child(1) {
    top: 9px; }
  #spmenu-icon div:nth-child(2) {
    top: 21px; }
  #spmenu-icon div:nth-child(3) {
    top: 33px; }
  @media screen and (min-width: 481px) {
    #spmenu-icon {
      display: none; } }

.spmenu-icon-click div:nth-child(1) {
  top: 20px !important;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
  background: #fff !important; }

.spmenu-icon-click div:nth-child(2) {
  top: 20px !important;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  -webkit-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
  background: #fff !important; }

.spmenu-icon-click div:nth-child(3) {
  display: none; }

.con {
  margin: 0 auto 0 calc(300px + (100% - 1400px) / 2);
  padding: 0 auto 5rem;
  width: 1100px;
  position: relative; }
  .con:after {
    content: "";
    display: block;
    clear: both; }
  @media screen and (max-width: 1300px) {
    .con {
      margin: 0 auto; } }
  @media screen and (max-width: 480px) {
    .con {
      width: 100%;
      padding: 0 1.5rem;
      -webkit-box-sizing: border-box;
      box-sizing: border-box; } }

.con_pt50 {
  padding-top: 50px; }

.con_pt100 {
  padding-top: 100px; }

.con_pt150 {
  padding-top: 150px; }

@media screen and (max-width: 480px) {
  .con_pt100, .con_pt150 {
    padding-top: 50px; } }

.con_pb50 {
  padding-bottom: 50px; }

.con_pb100 {
  padding-bottom: 100px; }

.con_pb150 {
  padding-bottom: 150px; }

.con_mb150 {
  margin-bottom: 150px; }

@media screen and (max-width: 480px) {
  .con_pb100, .con_pb150 {
    padding-bottom: 1px; } }

#top_con {
  background-color: #F6F6F6;
  position: relative;
  z-index: 200; }

#top_v {
  height: 80vh;
  width: 88vw;
  margin-left: auto;
  min-height: 800px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  background-image: url(../img/bg.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center bottom;
  z-index: 1; }
  #top_v .parallax-inner {
    height: 125vh !important;
    background-position: center top !important;
    overflow: initial !important; }
  @media screen and (max-width: 480px) {
    #top_v {
      background-image: url(../img/bk_sp.jpg);
      background-position: top center;
      width: calc(100% - 50px);
      height: 85vh;
      min-height: initial; } }
  #top_v:before {
    content: "";
    display: block;
    position: absolute;
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-image: url(../img/bg_deco.png);
    -webkit-background-size: auto 100%;
    -moz-background-size: auto 100%;
    background-size: auto 100%;
    background-repeat: repeat-x;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 10px; }
  #top_v:after {
    content: "";
    display: block;
    position: absolute;
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-image: url(../img/seal.png);
    bottom: 10px;
    left: -40px;
    width: 80px;
    height: 80px; }

.copy {
  position: absolute;
  left: 2vw;
  top: 200px;
  z-index: 100; }
  .copy img {
    width: 580px; }
  @media screen and (max-width: 480px) {
    .copy {
      left: 0; }
      .copy img {
        width: 90%; } }

.top_logo {
  position: absolute;
  top: 17px;
  right: 20px; }
  .top_logo img {
    width: 140px; }

.top_sns {
  position: absolute;
  top: 20px;
  right: 20px;
  background-image: url(../img/snslogo_bk.png);
  background-size: auto 100%;
  background-repeat: no-repeat;
  width: 70px;
  z-index: 1000;
  display: none; }
  .top_sns a {
    width: 32px;
    height: 25px;
    display: block;
    float: left; }

#intro {
  padding: 2rem 0;
  width: 100%;
  z-index: 200;
  margin: 0 auto;
  position: relative;
  background-color: #F6F6F6; }
  @media screen and (max-width: 480px) {
    #intro {
      padding: 1rem 1.5rem 0rem;
      -webkit-box-sizing: border-box;
      box-sizing: border-box; } }

.mobile_slider {
  overflow: hidden;
  padding: 0; }
  .mobile_slider:after {
    content: "";
    display: block;
    clear: both; }
  .mobile_slider .item {
    background-color: #fff;
    margin: 10px; }
  .mobile_slider .item-title {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0 10px;
    box-sizing: border-box; }
    .mobile_slider .item-title img {
      height: 40px;
      width: auto;
      margin: 10px 0; }

.swiper-slide {
  background-color: #fff; }
  .swiper-slide > img {
    width: 100%; }

.slider_con {
  position: relative; }

.slider1 {
  width: 75%; }
  .slider1 .swiper-slide {
    background: none; }
    .slider1 .swiper-slide div {
      height: 530px;
      background-size: cover;
      background-position: center center; }
  @media screen and (max-width: 480px) {
    .slider1 {
      width: 100%; }
      .slider1 .swiper-slide div {
        height: calc(100vw - 3rem) !important; } }

.slider2 {
  width: calc( 50% - 3rem); }
  .slider2 .swiper-slide {
    background: none; }
    .slider2 .swiper-slide div {
      height: 650px;
      background-size: cover;
      background-position: center center; }
  @media screen and (max-width: 480px) {
    .slider2 {
      width: 100%; }
      .slider2 .swiper-slide div {
        height: calc(100vw - 3rem) !important; } }

.slider3 {
  width: calc( 50% - 3rem); }
  .slider3 .swiper-slide {
    background: none; }
    .slider3 .swiper-slide div {
      height: 480px;
      background-size: cover;
      background-position: center center; }
  @media screen and (max-width: 480px) {
    .slider3 {
      width: 100%; }
      .slider3 .swiper-slide div {
        height: calc(100vw - 3rem) !important; } }

@media screen and (max-width: 480px) {
  .swiper-button-prev {
    left: 10px !important; }
  .swiper-button-next {
    right: 10px !important; } }

.swiper-slide > div > p {
  position: absolute;
  bottom: 35px;
  right: 10px;
  font-size: 45px;
  font-weight: bold;
  color: #fff;
  text-align: right;
  line-height: 2.6rem; }
  @media screen and (max-width: 480px) {
    .swiper-slide > div > p {
      font-size: 35px;
      line-height: 2.2rem;
      bottom: 26px; } }

.swiper-slide > div > .p_l {
  left: 10px;
  right: initial;
  text-align: left; }

.swiper-slide > div > span {
  position: absolute;
  bottom: 0px;
  right: 0px;
  font-size: 12px;
  z-index: 10000;
  padding: 0 8px;
  color: #fff;
  background-color: #7AC7D8; }

.swiper-slide > div > .span_l {
  left: 0px;
  right: initial; }

#bg2, #bg3, #bg4, #bg5, #bg6 {
  height: 400px;
  width: calc(100% - 300px);
  margin-left: auto;
  position: relative; }
  #bg2 .parallax-inner, #bg3 .parallax-inner, #bg4 .parallax-inner, #bg5 .parallax-inner, #bg6 .parallax-inner {
    background-position: center center !important;
    background-image: url(../img/bg2.jpg) !important; }
    @media screen and (max-width: 480px) {
      #bg2 .parallax-inner, #bg3 .parallax-inner, #bg4 .parallax-inner, #bg5 .parallax-inner, #bg6 .parallax-inner {
        background-image: none !important; } }
  #bg2 h2, #bg3 h2, #bg4 h2, #bg5 h2, #bg6 h2 {
    line-height: 400px;
    text-align: center;
    color: #fff;
    font-size: 40px;
    margin-left: 0; }
  @media screen and (max-width: 1300px) {
    #bg2, #bg3, #bg4, #bg5, #bg6 {
      width: 100%; } }
  @media screen and (max-width: 480px) {
    #bg2, #bg3, #bg4, #bg5, #bg6 {
      height: 60vw;
      margin-top: 60px; }
      #bg2 .parallax-inner, #bg3 .parallax-inner, #bg4 .parallax-inner, #bg5 .parallax-inner, #bg6 .parallax-inner {
        -webkit-transform: none !important;
        -ms-transform: none !important;
        transform: none !important; } }

#bg2 {
  height: 500px; }

#bg3 .parallax-inner {
  background-image: url(../img/bg3.jpg) !important; }
  @media screen and (max-width: 480px) {
    #bg3 .parallax-inner {
      background-image: none !important; } }

#bg4 .parallax-inner {
  background-image: url(../img/bg4.jpg) !important; }
  @media screen and (max-width: 480px) {
    #bg4 .parallax-inner {
      background-image: none !important; } }

#bg5 .parallax-inner {
  background-image: url(../img/bg5.jpg) !important; }
  @media screen and (max-width: 480px) {
    #bg5 .parallax-inner {
      background-image: none !important; } }

#bg6 {
  text-align: center;
  color: #fff; }
  #bg6 .parallax-inner {
    background-image: url(../img/bg6.jpg) !important; }
    @media screen and (max-width: 480px) {
      #bg6 .parallax-inner {
        background-image: none !important; } }
  #bg6 span {
    margin-top: 120px;
    display: block;
    font-size: 18px; }
  #bg6 h2 {
    line-height: 1rem; }
  #bg6 a {
    display: block;
    background-color: #7AC7D8;
    border-radius: 7px;
    padding: 0.5rem 1.5rem;
    width: 200px;
    margin: 1rem auto 0;
    color: #fff; }
  @media screen and (max-width: 480px) {
    #bg6 {
      height: 100vw; }
      #bg6 .text_bg6 {
        padding: 0 1.5rem; }
      #bg6 span {
        margin-top: 100px;
        font-size: 14px; }
      #bg6 h2 {
        line-height: 2.8rem;
        font-size: 24px; } }

@media screen and (max-width: 480px) {
  #bg2_con, #bg3_con, #bg4_con, #bg5_con, #bg6_con {
    background-size: cover;
    background-position: center center; }
  #bg2_con {
    background-image: url(../img/bg2_sp.jpg); }
  #bg3_con {
    background-image: url(../img/bg3_sp.jpg); }
  #bg4_con {
    background-image: url(../img/bg4_sp.jpg); }
  #bg5_con {
    background-image: url(../img/bg5_sp.jpg); }
  #bg6_con {
    background-image: url(../img/bg6_sp.jpg); } }

.text_bg6:before {
  content: "";
  display: block;
  position: absolute;
  width: 150px;
  height: 120px;
  background-image: url(../img/seal2.png);
  top: 60px;
  left: 50%;
  margin-left: 150px;
  background-size: 100% auto;
  opacity: 0.4; }
  @media screen and (max-width: 480px) {
    .text_bg6:before {
      left: initial;
      margin: 0;
      right: 0; } }

#slogan {
  width: 500px;
  color: #323232;
  text-align: center;
  font-size: 22px;
  margin: 0 auto 0.5rem calc(300px + (100% - 800px) /2);
  line-height: 2.1rem;
  position: relative; }
  #slogan:before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0px;
    left: -30px;
    width: 50px;
    height: 3px;
    background-color: #7AC7D8;
    z-index: 10;
    -webkit-transform: rotate(60deg);
    -ms-transform: rotate(60deg);
    transform: rotate(60deg); }
  #slogan:after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0px;
    right: -30px;
    width: 50px;
    height: 3px;
    background-color: #7AC7D8;
    z-index: 10;
    -webkit-transform: rotate(-60deg);
    -ms-transform: rotate(-60deg);
    transform: rotate(-60deg); }
  @media screen and (max-width: 1300px) {
    #slogan {
      margin: 0 auto; } }
  @media screen and (max-width: 480px) {
    #slogan {
      width: 80%;
      font-size: 16px;
      line-height: 1.6rem;
      margin-bottom: -50px; } }

.bg_color {
  background-color: #DAECEF; }

.bg_color2 {
  background-color: #F0EDE7; }

.bg_color3 {
  background-color: #E0D8CA; }

.bg_color4 {
  background-color: #DFD0B8; }

.bg_deco:before {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-image: url(../img/bg_deco.png);
  -webkit-background-size: auto 100%;
  -moz-background-size: auto 100%;
  background-size: auto 100%;
  background-repeat: repeat-x;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px; }

.bg_deco2:before {
  background-image: url(../img/bg_deco2.png); }

.content_con {
  position: relative; }
  .content_con:after {
    content: "";
    display: block;
    clear: both; }
  @media screen and (max-width: 480px) {
    .content_con {
      margin-bottom: 1rem; } }

.text25 {
  width: calc( 25% - 3rem);
  margin-left: 1.5rem;
  position: absolute; }
  @media screen and (max-width: 480px) {
    .text25 {
      position: relative;
      width: 100%;
      margin-left: initial;
      margin-top: 3rem; } }

.text_con {
  position: absolute;
  z-index: 2; }
  @media screen and (max-width: 480px) {
    .text_con {
      position: relative;
      margin: 60px auto 3rem; } }

.text_tar {
  text-align: right; }
  @media screen and (max-width: 480px) {
    .text_tar {
      text-align: left; } }

.text35 {
  width: 35%; }
  @media screen and (max-width: 480px) {
    .text35 {
      width: 100%; } }

.text_poa {
  position: absolute;
  right: 1.5rem; }
  @media screen and (max-width: 480px) {
    .text_poa {
      position: initial; } }

.push1 {
  margin-left: 1.5rem; }
  @media screen and (max-width: 480px) {
    .push1 {
      margin-left: initial; } }

.push1_15 {
  margin-left: 11%; }
  @media screen and (max-width: 480px) {
    .push1_15 {
      margin-left: initial; } }

.push25 {
  margin-left: 25%; }
  @media screen and (max-width: 480px) {
    .push25 {
      margin-left: initial; } }

.push25_img img {
  width: calc( 50% - 3rem); }
  @media screen and (max-width: 480px) {
    .push25_img img {
      width: 85%;
      margin: 0 auto;
      display: block; } }

.push50 {
  margin-left: 50%; }
  @media screen and (max-width: 480px) {
    .push50 {
      margin-left: initial; } }

.push50_img img {
  width: calc( 100% - 3rem); }
  @media screen and (max-width: 480px) {
    .push50_img img {
      width: 85%;
      margin: 0 auto;
      display: block; } }

.push100 {
  margin-left: auto; }
  @media screen and (max-width: 480px) {
    .push100 {
      margin-left: initial; } }

.top-30 {
  top: -30px; }

.top-50 {
  top: -50px; }

.top50 {
  top: 50px; }

.top80 {
  top: 80px; }

.top100 {
  top: 100px; }

.top120 {
  top: 120px; }

.top150 {
  top: 150px; }

.top200 {
  top: 200px; }

@media screen and (max-width: 480px) {
  .top50, .top80, .top100, .top120, .top150, .top200 {
    top: initial; }
  .sp_top-0 {
    margin-top: 0px; } }

dt {
  font-weight: bold;
  font-size: 18px;
  line-height: 1.4;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 3px solid #323232;
  position: relative; }
  dt:after {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    bottom: -6px;
    left: 0;
    border-bottom: 1px solid #323232; }

.num {
  height: 60px;
  margin-right: 10px;
  margin-top: -40px;
  float: left; }

.num_bt {
  margin-top: -13px; }

.num_poa {
  height: 60px;
  position: absolute;
  top: -70px; }
  @media screen and (max-width: 480px) {
    .num_poa {
      position: relative;
      float: left;
      top: -12px;
      margin-right: 1rem; } }

.num_r {
  height: 60px;
  float: right;
  margin-left: 15px;
  margin-top: -15px; }
  @media screen and (max-width: 480px) {
    .num_r {
      float: left;
      margin: -12px 1rem 0px 0px; } }

.num_r_t40 {
  margin-top: -40px; }

#map {
  width: 80%;
  position: relative;
  margin-bottom: 3rem; }
  #map .map_bg {
    width: 100%; }
  #map .map_dot {
    position: absolute;
    width: 20px;
    left: 50%;
    cursor: pointer; }
    #map .map_dot:nth-of-type(2) {
      width: 25px;
      top: 66px;
      margin-left: 292px; }
    #map .map_dot:nth-of-type(3) {
      top: 213px;
      margin-left: 138px; }
    #map .map_dot:nth-of-type(4) {
      top: 381px;
      margin-left: -71px; }
    #map .map_dot:nth-of-type(5) {
      top: 430px;
      margin-left: -198px; }
    #map .map_dot:nth-of-type(6) {
      top: 364px;
      margin-left: -238px; }
    #map .map_dot:nth-of-type(7) {
      top: 323px;
      margin-left: -159px; }
    #map .map_dot:nth-of-type(8) {
      top: 264px;
      margin-left: -100px; }
    #map .map_dot:nth-of-type(9) {
      top: 125px;
      margin-left: -68px;
      width: 25px; }

#map_sp img {
  width: calc(100% + 3rem);
  margin-left: -1.5rem; }

.day_tit {
  position: absolute;
  text-align: center;
  left: 50%; }
  @media screen and (max-width: 480px) {
    .day_tit {
      position: initial;
      margin: 0 auto; } }

.day1_tit {
  margin-left: 130px;
  top: -190px; }
  .day1_tit img {
    height: 80px; }
  @media screen and (max-width: 480px) {
    .day1_tit {
      position: relative;
      top: initial;
      left: initial;
      margin-left: initial;
      padding-top: 50px; } }

.day2_tit {
  top: 0px; }
  .day2_tit img {
    height: 80px; }

.day4_tit img {
  height: 80px; }

.day4_tit h3 {
  position: absolute;
  top: 50px;
  left: 128px;
  width: 110px; }

@media screen and (max-width: 480px) {
  .day4_tit h3 {
    position: initial;
    margin: 0 auto; } }

.day6_tit {
  margin-left: 340px;
  top: 400px; }
  .day6_tit img {
    height: 80px; }
  @media screen and (max-width: 480px) {
    .day6_tit {
      margin-left: initial; } }

.day3_tit, .day7_tit {
  margin-left: -170px; }
  .day3_tit img, .day7_tit img {
    height: 80px; }
  @media screen and (max-width: 480px) {
    .day3_tit, .day7_tit {
      margin-left: initial; } }

.pic_deco {
  position: absolute;
  left: 50%; }
  .pic_deco:after {
    content: "";
    display: block;
    clear: both; }

.pic_deco_comment {
  position: absolute;
  color: #fff;
  background-color: #7AC7D8;
  font-size: 12px;
  padding: 8px 1rem; }

.pic_deco_comment_w {
  position: absolute;
  color: #7AC7D8;
  background-color: #fff;
  font-size: 12px;
  padding: 8px 1rem; }

.pic_deco01 {
  margin: -30px 0 0 1.5rem; }
  .pic_deco01 img {
    width: 360px; }
  .pic_deco01 p {
    top: 120px;
    left: 350px;
    width: 150px; }
  @media screen and (max-width: 480px) {
    .pic_deco01 {
      margin: 2rem auto 0; }
      .pic_deco01 img {
        width: 80%; }
      .pic_deco01 p {
        bottom: -30px;
        right: 0;
        width: 150px;
        left: initial;
        top: initial; } }

.pic_deco02 {
  margin: -200px 0 0 160px; }
  .pic_deco02 img {
    width: 450px; }
    .pic_deco02 img:nth-child(2) {
      width: 40px;
      position: absolute;
      top: 125px;
      left: 130px; }
    .pic_deco02 img:nth-child(3) {
      width: 40px;
      position: absolute;
      top: 176px;
      left: 470px; }
  .pic_deco02 p {
    top: 177px;
    left: 50px;
    width: 160px; }
  @media screen and (max-width: 480px) {
    .pic_deco02 {
      margin: 0 auto; }
      .pic_deco02 img {
        width: 90%; }
        .pic_deco02 img:nth-child(2) {
          width: 30px;
          left: initial;
          right: 15%;
          top: 90px; }
        .pic_deco02 img:nth-child(3) {
          width: 30px;
          top: 150px;
          left: initial; }
      .pic_deco02 p {
        top: initial;
        bottom: -20px;
        left: initial;
        right: 0;
        width: 50%; } }

.pic_deco03 {
  margin: -20px 0 0 160px; }
  .pic_deco03 img {
    width: 420px; }
    .pic_deco03 img:nth-child(2) {
      width: 150px;
      position: absolute;
      top: 155px;
      left: 540px; }
  .pic_deco03 p {
    top: 257px;
    left: 50px;
    width: 220px; }
  @media screen and (max-width: 480px) {
    .pic_deco03 {
      margin: -20vw 0 0 -160px; }
      .pic_deco03 img {
        width: 85%; }
        .pic_deco03 img:nth-child(2) {
          display: none; }
      .pic_deco03 p {
        top: initial;
        bottom: 0;
        left: initial;
        right: 0;
        width: 50%; } }

.pic_deco04 {
  margin: 40px 0 0 0; }
  .pic_deco04 img {
    width: 170px;
    float: right;
    margin-right: 40px; }
    .pic_deco04 img:nth-child(2) {
      width: 120px;
      position: absolute;
      top: 115px;
      right: 190px; }
    @media screen and (max-width: 480px) {
      .pic_deco04 img {
        margin-right: 0;
        width: 70%; }
        .pic_deco04 img:nth-child(2) {
          position: initial;
          float: left;
          margin-top: -40px; } }

.pic_deco05 {
  margin: -20px 0 0 90px; }
  .pic_deco05 img {
    width: 180px; }
  @media screen and (max-width: 480px) {
    .pic_deco05 {
      margin: 30px auto 0; }
      .pic_deco05 img {
        width: 50%; } }

.pic_deco06 {
  margin-left: 340px;
  top: -90px; }
  .pic_deco06 img {
    width: 200px; }
  @media screen and (max-width: 480px) {
    .pic_deco06 {
      display: none; } }

.pic_deco07 {
  margin: -70px 0 0 440px;
  position: relative;
  z-index: 10; }
  .pic_deco07 img {
    width: 180px; }
  @media screen and (max-width: 480px) {
    .pic_deco07 {
      position: initial;
      margin: initial; } }

#report_h2 {
  text-align: center;
  color: #585858;
  font-size: 28px;
  margin: 0 auto; }
  #report_h2 p {
    font-size: 18px; }
  @media screen and (max-width: 480px) {
    #report_h2 p {
      line-height: 1.8rem; } }

#report {
  margin-top: 1rem;
  padding: 2rem; }
  @media screen and (max-width: 480px) {
    #report {
      margin-top: 2rem;
      margin-bottom: 5rem;
      padding: 2rem 1rem 1px; } }
  #report:before {
    content: "";
    display: block;
    position: absolute;
    width: 150px;
    height: 120px;
    background-image: url(../img/seal2.png);
    top: -70px;
    right: 0;
    background-size: 100% auto; }
  #report:after {
    content: "";
    display: block;
    position: absolute;
    width: 80px;
    height: 80px;
    background-image: url(../img/seal.png);
    bottom: -40px;
    left: -3%;
    background-size: 100% auto;
    z-index: 201; }
  #report ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: space-between;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    background-image: url("../img/deco_line.png");
    background-position: center top;
    background-repeat: repeat-y;
    background-size: 1px auto; }
    #report ul li {
      width: 46%; }
    @media screen and (max-width: 480px) {
      #report ul {
        display: block;
        background-image: none; }
        #report ul li {
          width: 100%;
          margin-bottom: 2rem;
          padding-bottom: 2rem;
          border-bottom: 1px dotted #585858; }
        #report ul li:nth-child(2) {
          border: none; } }
  #report dt {
    font-size: 24px;
    border-bottom: none;
    padding-bottom: 0px;
    font-weight: normal;
    margin-bottom: 8px; }
    #report dt:after {
      border-bottom: none; }
  #report dd {
    border-top: none; }

#pickup {
  text-align: center;
  margin-bottom: 1rem;
  font-size: 28px; }
  #pickup img {
    height: 70px; }
  @media screen and (max-width: 480px) {
    #pickup {
      font-size: 22px;
      line-height: 1.8rem; }
      #pickup img {
        width: 100%;
        height: auto; } }

.ac_con {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-around;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  padding-left: 15px; }
  @media screen and (max-width: 480px) {
    .ac_con {
      display: block;
      padding: 0; } }
  .ac_con .ac_box {
    width: 31%;
    background: #fff; }
    .ac_con .ac_box img {
      width: 100%; }
    @media screen and (max-width: 480px) {
      .ac_con .ac_box {
        width: 100%;
        margin-bottom: 2rem; } }
  .ac_con .ac_text_con {
    background: #fff;
    padding: 10px 1rem 20px; }
    .ac_con .ac_text_con dt {
      font-weight: normal;
      text-align: center;
      border-bottom: none; }
      .ac_con .ac_text_con dt:after {
        border-bottom: 1px dotted #555; }
      .ac_con .ac_text_con dt span {
        font-size: 14px; }
  .ac_con .btn {
    background-color: #4E4E4E;
    text-align: center;
    padding: 1rem;
    width: 100%;
    color: #fff;
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-bottom-left-radius: 6px;
    border-bottom-right-radius: 6px; }
  .ac_con .point_box {
    width: 31%; }
    .ac_con .point_box img {
      width: 85%;
      display: block;
      margin: 0 auto -110px; }
    @media screen and (max-width: 480px) {
      .ac_con .point_box {
        width: 100%; }
        .ac_con .point_box img {
          width: 80%; } }
  .ac_con .point_text_con {
    background: #fff;
    padding: 140px 1rem 20px; }
    .ac_con .point_text_con dt {
      font-weight: normal;
      text-align: center;
      border-bottom: none; }
    @media screen and (max-width: 480px) {
      .ac_con .point_text_con {
        margin-bottom: 3rem;
        background: none;
        padding: 140px 0 20px; }
        .ac_con .point_text_con dt {
          font-weight: bold; } }

.pickup_con_btn {
  display: block;
  background-color: #7AC7D8;
  border-radius: 7px;
  padding: 1rem 1.5rem;
  width: 200px;
  margin: 3rem auto 0;
  color: #fff;
  text-align: center; }
  @media screen and (max-width: 480px) {
    .pickup_con_btn {
      margin-bottom: 3rem;
      width: calc(100% - 3rem); } }

#point_con {
  background-color: #fff; }
  @media screen and (max-width: 480px) {
    #point_con {
      background: none; } }
  #point_con .point_con {
    margin: -150px auto 0 calc(300px + (100% - 1400px) / 2);
    z-index: 10;
    width: 1100px;
    padding: 0; }
    @media screen and (max-width: 1300px) {
      #point_con .point_con {
        margin: -150px auto 0; } }
    @media screen and (max-width: 480px) {
      #point_con .point_con {
        width: 100%;
        padding: 0 1.5rem;
        -webkit-box-sizing: border-box;
        box-sizing: border-box; } }

#kana_con {
  height: 370px; }
  #kana_con b {
    font-weight: bold; }
  #kana_con a {
    float: left;
    margin-right: 10px; }
  @media screen and (max-width: 480px) {
    #kana_con {
      height: auto;
      padding-bottom: 4rem; } }

.kana_ig {
  display: block;
  margin-top: 10px;
  width: 32px; }

.kana_img {
  position: absolute;
  top: -10px;
  left: 50%;
  margin-left: -540px;
  width: 290px; }
  @media screen and (max-width: 480px) {
    .kana_img {
      position: initial;
      margin: -4rem auto 0 5%;
      width: 90%;
      -webkit-transform: rotate(0deg);
      -ms-transform: rotate(0deg);
      transform: rotate(0deg); } }

.day5_goal, .day6_goal {
  position: absolute;
  background-color: #777777;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  bottom: -30px;
  left: 50%;
  margin-left: 3px;
  padding: 8px 1rem;
  border-radius: 3px;
  z-index: 2; }
  @media screen and (max-width: 480px) {
    .day5_goal, .day6_goal {
      width: 100px;
      text-align: center;
      margin: 1rem auto 2rem;
      position: initial; } }

.day6_goal {
  bottom: 110px;
  margin-left: -167px; }
  @media screen and (max-width: 480px) {
    .day6_goal {
      margin-left: auto;
      width: 150px; } }

.decoline01_light:before {
  content: "";
  display: block;
  width: 15px;
  height: 100px;
  background-image: url(../img/decoline01_light.png);
  background-size: 100% auto;
  position: absolute;
  left: 20%;
  top: -100px;
  z-index: -1; }
  @media screen and (max-width: 480px) {
    .decoline01_light:before {
      display: none; } }

.decoline02_light:after {
  content: "";
  display: block;
  width: 240px;
  height: 200px;
  background-image: url(../img/decoline02_light.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  position: absolute;
  left: 42%;
  top: 310px;
  z-index: -1;
  -webkit-transform: rotate(85deg);
  -ms-transform: rotate(85deg);
  transform: rotate(85deg); }
  @media screen and (max-width: 480px) {
    .decoline02_light:after {
      display: none; } }

.decoline01_dark:before {
  content: "";
  display: block;
  width: 15px;
  height: 100px;
  background-image: url(../img/decoline01_dark.png);
  background-size: 100% auto;
  position: absolute;
  right: 20%;
  top: -100px;
  z-index: 0; }
  @media screen and (max-width: 480px) {
    .decoline01_dark:before {
      display: none; } }

.decoline02_dark:after {
  content: "";
  display: block;
  width: 240px;
  height: 200px;
  background-image: url(../img/decoline02_dark.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  position: absolute;
  left: 32%;
  top: 410px;
  z-index: 0;
  -webkit-transform: rotate(-5deg);
  -ms-transform: rotate(-5deg);
  transform: rotate(-5deg); }
  @media screen and (max-width: 480px) {
    .decoline02_dark:after {
      display: none; } }

.decoline02_light_day4:after {
  top: 410px; }

.decoline01_dark_day5:before {
  left: 20%; }

.decoline02_dark_day5:after {
  -webkit-transform: rotate(85deg);
  -ms-transform: rotate(85deg);
  transform: rotate(85deg);
  left: 44%; }

.decoline01_light_day6:before {
  left: 60%; }

.decoline02_light_day6:after {
  -webkit-transform: rotate(-5deg);
  -ms-transform: rotate(-5deg);
  transform: rotate(-5deg);
  left: 32%;
  top: 290px; }

.decoline02_dark_day7:after {
  top: 290px; }

.decoline01_light_day8:before {
  right: 20%;
  left: initial; }

#finalbanner .con {
  background-color: #f0ede7; }

#finalbanner .comment2020 {
  text-align: center;
  font-size: 12px; }
