﻿@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Varela+Round&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display&display=swap');
.site_list{
	padding-bottom: 30px;
    list-style: none;
}
.site_list li:before{
content: "";
    position: absolute;
    width: 5px;
    height: 5px;
    border-top: 1px solid;
    border-right: 1px solid;
    transform: translateY(-50%) rotateZ(45deg);
    right: -10px;
    top: 50%;
}
.site_list li:last-child:before{
	display: none;
}
p.header__toggle {
  cursor: pointer;
  position: fixed;
  right: 60px;
  top: 18px;
  transform: translateZ(3px);
  z-index: 101;
  height: 35px;
  right: 23px;
  top: 19px;
  width: 35px;
  display: block !important;
}
.header__toggle:after, .header__toggle:before {
  background-color: #fff;
  top: 50%;
}
.header__toggle:after, .header__toggle:before {
  background-color: #fff;
  content: "";
  display: block;
  height: 2px;
  left: 50%;
  position: absolute;
  transform: translate(-50%, -50%);
  width: 35px;
}
.header__toggle:before {
  transform: translate(-50%, -50%) rotate(45deg);
  background-color: #fff;
  top: 50%;
  height: 2px;
  width: 35px;
}
.header__toggle:after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
/* ---------------------------  LOADER  ----------------------------------------*/
#loader {
  z-index: 9999;
}
.loader {
  box-sizing: border-box;
  display: flex;
  flex: 0 1 auto;
  flex-direction: column;
  flex-grow: 1;
  flex-shrink: 0;
  flex-basis: 25%;
  align-items: center;
  justify-content: center;
}
.line-scale > div:nth-child(1) {
  -webkit-animation: line-scale 1s -0.4s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
  animation: line-scale 1s -0.4s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
}
.line-scale > div:nth-child(2) {
  -webkit-animation: line-scale 1s -0.3s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
  animation: line-scale 1s -0.3s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
}
.line-scale > div:nth-child(3) {
  -webkit-animation: line-scale 1s -0.2s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
  animation: line-scale 1s -0.2s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
}
.line-scale > div:nth-child(4) {
  -webkit-animation: line-scale 1s -0.1s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
  animation: line-scale 1s -0.1s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
}
.line-scale > div:nth-child(5) {
  -webkit-animation: line-scale 1s 0s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
  animation: line-scale 1s 0s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
}
.line-scale > div {
  width: 4px;
  height: 35px;
  border-radius: 2px;
  margin: 2px;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  display: inline-block;
}
@keyframes line-scale {
  0% {
    -webkit-transform: scaley(1);
    transform: scaley(1);
  }
  50% {
    -webkit-transform: scaley(0.4);
    transform: scaley(0.4);
  }
  100% {
    -webkit-transform: scaley(1);
    transform: scaley(1);
  }
}
#pc_nav a, #pc_main_nav a, .font_en {
  font-family: 'Varela Round', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

#square_links ul li {
  width: 48%;
  box-sizing: border-box;
  background-position: center;
  background-size: cover;
}
#square_links ul li:first-child {
  margin-right: 4%;
}
#square_links ul li a {
  /*padding: 143px 10% 145px;*/
}
#square_links ul li:hover .footer_bg {
  opacity: 0.5;
}
#square_links ul li a figure img {
  transition: all 1.4s;
  left: 0;
  top: 0;
  transform: inherit;
}
#square_links ul li a:hover figure img {
  transform: scale(1.1);
  left: 0;
  top: 0;
}
#main_img .slick-track {
  position: absolute;
  top: 50%;
  left: 0%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  min-width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
#main_img .slick-dots li {
  line-height: 1;
}
#main_img .slick-dots li button {
  display: none;
}
#main_img .slick-dots li {
  height: 5px;
  width: 55px;
  box-sizing: border-box;
  border-style: solid;
  opacity: 0.3;
  cursor: pointer;
}
#main_img .slick-dots li + li {
  margin-left: 10px;
}
#main_img .slick-dots li.slick-active {
  opacity: 1;
}
.slick-slide img {
  min-width: 100%;
  min-height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;";
  position: absolute;
 top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
.slick-list {
  margin-bottom: 20px !important;
  height: 75vh;
}
.slick-dots {
  bottom: 0px;
  justify-content: flex-end;
  align-items: flex-start;
}

.nav3 li:not(:first-child):before {
  content: "";
  display: block;
  position: absolute;
  left: 7px;
  top: 18px;
  height: 13px;
  width: 1px;
  background: #fff;
}
.nav3 li + li {
  padding-left: 17px
}
/*----------------------------*/
#sp_navlogo {
  position: absolute;
  left: 0px;
  top: 19px;
}
#sp_nav {
  -webkit-animation: insetWipeOut .75s cubic-bezier(.19, 1, .22, 1) 0s 1 normal both;
  animation: insetWipeOut .75s cubic-bezier(.19, 1, .22, 1) 0s 1 normal both;
  -webkit-clip-path: inset(0 100% 0 0);
  clip-path: inset(0 100% 0 0);
  height: 0;
  overflow: hidden;
  position: fixed;
  top: 0;
  transform: translateZ(2px);
  transition: height 0s linear .75s;
  width: 100%;
  z-index: 100;
}
header.open #sp_nav {
  -webkit-animation: insetWipeIn .75s cubic-bezier(.19, 1, .22, 1) 0s 1 normal both;
  animation: insetWipeIn .75s cubic-bezier(.19, 1, .22, 1) 0s 1 normal both;
  -webkit-clip-path: inset(0 0 0 0);
  clip-path: inset(0 0 0 0);
  transition: height 0s linear 0s;
  height: 100vh;
  z-index: 5;
}
#sp_nav > div {
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  height: 100vh;
  left: 0;
  position: absolute;
  top: 0;
  transition: visibility 0s linear .75s;
  visibility: hidden;
  width: 100%;
  z-index: 4;
}
header.open #sp_nav > div {
  transition: visibility 0s linear 0s;
  visibility: visible;
}
@-webkit-keyframes insetWipeIn {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0)
  }
  to {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0)
  }
}
@keyframes insetWipeIn {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0)
  }
  to {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0)
  }
}
@-webkit-keyframes insetWipeOut {
  0% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0)
  }
  to {
    -webkit-clip-path: inset(0 0 0 100%);
    clip-path: inset(0 0 0 100%)
  }
}
@keyframes insetWipeOut {
  0% {
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0)
  }
  to {
    -webkit-clip-path: inset(0 0 0 100%);
    clip-path: inset(0 0 0 100%)
  }
}
/*----------------------------------------------------*/
/*FOOTER*/
.footer_left {
  background-position: 50% 50%;
  background-size: cover;
}
/* -------------------------------------------------- */
#top_contents2 .con_open .contents_no span {
  background-color: #fff
}
#top_contents2 .con_box {
  cursor: pointer
}
#top_contents2 .con_box .box_img {}
#top_contents2 .con_box:hover .box_img img {
  opacity: 0.7;
}
#top_contents2 .con_box:hover .con2_item {
  opacity: 0.7;
}
#top_contents2 .con_box:hover .box_img span {
  opacity: 1
}
#top_contents2 .con_open {
  top: 0;
  left: 0;
  z-index: 31;
}
#top_contents2 .open_scroll {
  overflow-y: auto
}
#top_contents2 .con_open .close_bt {
  top: 20px;
  right: 20px;
  cursor: pointer
}
#top_contents1 .num {
  font-size: 80px;
  right: -62px;
  z-index: 1;
  top: 0%;
}
#top_contents2 .num {
  font-size: 64px;
  z-index: 1;
  right: 14px;
  top: -39px;
}
/*button*/
.viewmore {
  margin-top: 3.125rem;
  position: relative;
  width: 8.5rem;
  width: auto;

  margin-left: auto;
  text-align: right;
}
.viewmore span {
  display: inline-block;
  padding-right: 4rem;
  height: 100%;
  letter-spacing: .1em;
  white-space: nowrap;
  color: inherit;
  text-decoration: none;
  transition: color .6s cubic-bezier(0, 0.55, 0.45, 1);
  position: relative;
}
.viewmore span::before {
  content: "";
  display: block;
  position: absolute;
  top: 1.0625rem;
  right: 1rem;
  width: 2.375rem;
  height: 1px;
  background-color: #000;
  -webkit-transform-origin: 0 0;
  transform-origin: 0 0;
  opacity: 0.5;
}
.viewmore span::after {
  content: "";
  display: block;
  position: absolute;
  top: .1rem;
  right: 0;
  width: 1.8875rem;
  height: 1.8875rem;
  border-radius: 50%;
  border-width: 1px;
  border-color: #000;
  border-style: solid;
  opacity: 0.5;
}
.con_box:hover .viewmore span, .cms_box .viewmore a:hover {
  color: #999999;
}
.con_box:hover span::after, .cms_box .viewmore:hover span::after {
  -webkit-animation: viewmore_hover_after .6s cubic-bezier(0, 0.55, 0.45, 1);
  animation: viewmore_hover_after .6s cubic-bezier(0, 0.55, 0.45, 1);
}
@-webkit-keyframes viewmore_hover_after {
  0% {
    -webkit-transform: scale(0);
    transform: scale(0)
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1)
  }
}
/**/
body {
  position: relative
}
.top_page:before, .under_page:before {
  background: #563142;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: 100%;
  height: 504px;
}
#top_contents1 .txt_wrap {}
.con_title {
  position: relative;
}
/* .con_title span:before {
  background: #563142;
  content: "";
  display: block;
  position: absolute;
  bottom: -13px;
  left: 0;
  width: 20px;
  height: 2px;
} */
/* 画像トリミング */
.portrait_img {
  display: block;
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 700px !important;
}
.portrait_img img {
  width: 100%;
  height: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
#intro .con1_img img {
  top: inherit;
  left: inherit;
}
#mainheader {
  height: 142px;
}
.nav_wrap {}
.main_nav_bnr {
  position: absolute;
  right: 0;
  top: 0;
}
.main_nav_bnr li a {
  height: 130px;
  background: #fff;
  width: 130px !important;
}
.catch {
  z-index: 1;
  right: 3%;
  top: 13%;
  background: #fff;
  padding: 5% 10%;
}
/* CSS Document */
.vegas-timer {
  bottom: 0px !important;
  height: 2px;
  background: #5c0000;
}
#slider {
  width: 100%;
  height: 100vh; /*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
  position: absolute;
  top: 50%;
  left: 0%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}
.nav_wrap {
  margin-right: 295px;
}
/* ----------------- Page07 -----------------------*/
#map iframe{
    width: 100%;
    height: 450px;
}

/* ----------------- Page10 -----------------------*/
.sitemap_wrap li a {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  font-weight: bold;
  padding: 20px 15px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  border: 1px solid transparent;
  outline: 1px solid;
  outline-color: #878787;
  outline-offset: 0px;
  text-shadow: none;
  transition: all 1.2s cubic-bezier(0.2, 1, 0.2, 1);
}
/* マウスオーバー時 */
.sitemap_wrap li a:hover {
  border-color: #FFF;
  box-shadow: inset 0 0 20px rgba(255, 255, 255, 0.5), 0 0 20px rgba(255, 255, 255, 0.2);
  outline-color: transparent;
  outline-offset: 12px;
  cursor: pointer;
}
/* --------------------------------------------------------- */
/*** all ***/
html {
  font-size: 16px;
}
*:focus {
  outline: none;
}
body {
  -webkit-text-size-adjust: 100%;
}
body, .font_sans-serif {
  font-family: 'Noto Sans JP', 'Comfortaa', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.font_pl {
  font-family: 'Playfair Display', "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
}
.font_bold {
  font-weight: 700
}
input[type="submit"], input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration, input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus, input[type="button"]::focus {
  outline-offset: -2px;
}
textarea {
  overflow: auto;
}
#page_top {}
.hvr_trans:hover {
  transform: translateY(-5px);
}
.fadein .fade_box {
  opacity: 0;
  transform: translateY(15px);
  transition: 0.8s;
  transition-property: opacity, transform
}
.fadein .fade_box.active {
  opacity: 1;
  transform: none;
}
/*** header ***/
#header {
  position: fixed;
  top: -60px;
  transition: all 0.3s
}
#header.active {
  top: 0;
  left: 0;
  z-index: 5;
  background-color: #fff;
  top: 0;
}
#header.active .logo_wrap {
  width: 170px
}
#pc_nav {
  /* min-width: 583px;*/
  margin-left: auto;
}
#header #pc_nav {
  min-width: inherit;
  width: inherit;
}
#pc_nav li a, #footer_nav li a, #sp_nav .nav1 a {
  position: relative;
  padding-left: 35px;
}
#pc_nav li a:before, #footer_nav li a:before, #sp_nav .nav1 a:before {
  display: block;
  content: "";
  width: 10px;
  height: 1px;
  background-color: currentColor;
  position: absolute;
  left: 0;
  top: 50%;
}
#sp_nav {
  top: 0;
  left: 0;
  z-index: 5
}
#header_sns li {
width: 30px!important;
padding: 10px;
box-sizing: content-box;
margin-left: 7px;
margin-right: 7px;
}
#header_sns .sns_title {
    display: none;
}
.menu_stick {
  top: 17px;
  right: 20px;
  width: 40px;
  height: 40px;
  z-index: 30;
cursor: pointer;
}
.menu_stick::before, .menu_stick::after {
  position: absolute;
  content: "";
  width: 40px;
  height: 2px;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  background-color: currentColor;
  transition: 0.3s
}
.menu_stick::before {
  bottom: 10px
}
.menu_stick::after {
  top: 10px
}
.menu_stick.trans::before {
  transform: rotate(135deg);
  bottom: 0;
  color: #fff;
  display: none
}
.menu_stick.trans::after {
  transform: rotate(-135deg);
  top: 0;
  color: #fff;
  display: none
}
/*** footer ***/
#footer #sns_link li {
    margin-bottom: 15px;
}
#footer_info .footer_bg {
  bottom: 0;
  right: 0;
}
#footer_info #map iframe {
  display: block;
  width: 100% !important;
  height: 100% !important
}
#footer_info .info_title {
  top: 0;
  left: 10%
}
#page_top {
  width: 83px;
  height: 83px;
  right: 0;
  bottom: 0;
  z-index: 2;
  cursor: pointer
}
#page_top::before {
  position: absolute;
  content: "";
  width: 15px;
  height: 15px;
  border-left: solid 2px #fff;
  border-top: solid 2px #fff;
  transform: rotate(45deg);
  top: 10px;
  right: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}
#bottom_tel {
  right: 92px;
  bottom: 0;
  z-index: 4;
}
#bottom_tel a {
  height: 92px;
  background-color: #f9f9f9
}
/*** top ***/
#main_img {
  width: 81%;
  margin: 0 auto;
  margin-top: 35px;
  margin-left: 0;
  overflow: hidden;
  /*height: 75vh;*/
}
#intro .con1_box {
  right: 0;
}
#intro .info_title {
  top: 50px;
  font-size: 82px;
  opacity: 0.2;
}
#top_contents3 .con3_bg {
  top: 150px;
  bottom: 0;
}
#top_contents3 .con3_no {
  font-size: 100px;
  left: 20px;
  bottom: -40px
}
#top_contents3 .con_before {
  width: 40px;
  height: 1px;
  left: 0;
  bottom: 0;
}
#top_cms {
  z-index: 0
}
#top_cms .cms_before {
  width: 100px;
  height: 1px;
  left: 0;
  right: 0;
  bottom: -1px;
  margin: auto
}
#top_cms .cms_box:last-of-type {
  margin-bottom: 0;
  border-bottom: none
}
#top_cms .cms_box:last-of-type .cms_before {
  display: none
}
.cms_title h3 {
  margin-bottom: -10px;
}
.more a {
  padding-right: 60px
}
.more a::before {
  position: absolute;
  content: "";
  width: 40px;
  height: 40px;
  border: solid 1px currentColor;
  border-radius: 50%;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  transition: 0.3s
}
.more a::after {
  position: absolute;
  content: "";
  width: 8px;
  height: 8px;
  border-top: solid 1px currentColor;
  border-right: solid 1px currentColor;
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
  transform: rotate(45deg)
}
.more a:hover::before {
  transform: scale(1.3);
  background-color: currentColor
}
.more a:hover::after {
  border-color: #fff
}
/*** under_page ***/
.under_page {
  top: 20px
}
.under_page.active {
  opacity: 1;
  top: 0
}
#page_title .title_img {
  height: 400px;
  width: 81%;
  margin-top: 35px;
}
#page_title .title_wrap {
  background: #fff;
  position: absolute;
  right: 5%;
  top: 18%;
}
#page_title .title_before {
  width: 100px;
  height: 3px;
  left: 0;
  right: 0;
  bottom: 0;
}
.cate_list li {
  box-sizing: border-box;
  max-width: 100%;
}
.cate_list li a::before {
  position: absolute;
  content: "";
  width: 1px;
  height: 10px;
  border-right: solid 1px currentColor;
  top: 0;
  bottom: 0;
  right: 10px;
  margin: auto;
}
.cate_list li:last-child a::before {
  display: none;
}
.pager li a {
  height: 60px;
  line-height: 60px;
}
.pager li.prev a, .pager li.next a {
  padding: 0 20px
}
.pager li:not(.prev) a, .pager li:not(.next) a {
  width: 60px;
}

/*表示を切り替えるウィンドウサイズの指定*/
@media (min-width: 668px) {
  .footer_item {
    position: absolute;
    right: 30px;
    font-size: 1.0rem;
    text-align: left;
    color: #fff;
    opacity: 0.5
  }
  .cate_list li a {
    background: transparent;
  }
}
@media screen and (max-width: 1414px) {
  #sc_pc_nav ul li:nth-child(7), #sc_pc_nav ul li:nth-child(8) {
    display: none;
  }
  #header {
    display: block;
  }
  #header .logo_wrap {
    margin: 10px auto;
  }
  #sc_pc_nav ul li a {}
  #header {
    top: -110px;
  }
  #mainheader {
    padding-top: 20px;
    height: inherit;
    padding-bottom: 20px;
  }
}
@media screen and (max-width: 1000px) {
  #main_img, #page_title .title_img {
    margin-top: 0;
  }
  #sc_pc_nav ul {
    justify-content: space-between;
  }
  #sc_pc_nav ul li a {
    padding-right: 10px;
    padding-left: 10px;
  }
  .nav_wrap {
    margin-right: 14%;
  }
  .main_nav_bnr li a {
    height: 43px;
  }
  #top_contents1 .txt_wrap, #top_contents1 .grid_7 {
    width: 100% !important;
  }
  #top_contents1 .num {
    right: 31px;
    top: -74px;
  }
  #top_contents1 .txt_wrap {
    padding: 0 5%;
  }
}
@media screen and (min-width:769px) and (max-width:1200px) {
    #footer_nav {
        padding-top: 60px;
        padding-bottom: 70px;
    }
    #footer_nav li {
        width: 100%!important;
        padding-top: 5px;
    }
}
@media(min-width: 769px) {
  #intro .con1_img img {
    left: -10%;
  }
    .footer_item {
    bottom: 20px;
  }
}
@media screen and (max-width: 768px) {
  header {
    background-color: #fff;
  }
  #header.active {
    padding: 17px 0;
  }
  .top_page:before, .under_page:before {
    top: 0px;
  }
  #page_title {
    padding-top: 135px;
  }
  #page_title .title_wrap {
    right: 0%;
    top: 0;
  }
  #page_title .title_img {
    margin-top: 0;
    height: 45vw;
    width: 88%;
  }
  #intro .info_title {
    font-size: 68px;
    top: 33px;
  }
  #intro .con1_box {
    margin-right: 0;
    margin-left: auto;
  }
  .under_page main {
    margin-top: 0px;
  }
  .top_page main {
    margin-top: 10vh;
  }
  #main_img {}
  .slick-list {
    /*  height: 95vw;    */
  }
  .catch {
    right: 0;
    top: -10vh;
    padding: 9% 10%;
  }
  #footer_info .footer_bg {
    height: calc(100% - 100px)
  }
  #footer_info #map {
    height: 400px
  }
  #page_top {
    width: 50px;
    height: 50px;
  }
  #bottom_tel {
    right: 50px;
  }
  #bottom_tel a {
    height: 50px;
  }
  .pager li:not(.prev):not(.next) {
    display: none;
  }
  .hvr_trans:hover {
    transform: none
  }
  .float_right_tb {
    float: right
  }
  .float_left_tb {
    float: left
  }
  .float_clear_tb {
    float: none
  }
  .clearfix_tb::after {
    clear: both;
    content: ".";
    visibility: hidden;
    display: block;
    height: 0;
  }
}
@media screen and (max-width: 667px) {
.site_list{
    padding-top: 0;
	padding-bottom: 20px;
}
  .cate_list li a::before {
    width: 5px;
    height: 5px;
    border-top: solid 1px currentColor;
    border-right: solid 1px currentColor;
    right: 20px;
    transform: rotate(45deg);
  }
  .cate_list li:last-child a::before {
    display: block;
  }

#footer_nav li:nth-child(even) {
    padding-left: 20px;
}
  .under_page main {
    margin-top: 0px;
  }
  .top_page main {
    margin-top: 80px;
  }
  #page_title {
    padding-top: 75px;
  }
  #page_title .title_img {
    height: 54vw;
  }
  .catch {
    top: -80px
  }
  .top_page:before, .under_page:before {
    height: 240px;
  }
  #main_img .slick-dots li {
    height: 2px;
    width: 34px;
    border: 2px solid;
  }
  #intro .info_title {
    font-size: 7vw;
  }
  #top_contents1 .num {
    font-size: 64px;
    right: 7px;
    top: -22px;
  }
  #top_contents2 .num {
    font-size: 54px;
    right: 14px;
    top: -29px;
  }
  #sp_navlogo {
    top: 10px;
  }
  #sns_link li a p {
    font-size: 1vw;
  }
  #main_img {
    width: 93%;
    height: 71vh;
  }
  .slick-list {
    height: 67vh;
    margin-bottom: 14px !important;
  }
  #header.active .logo_wrap {
    width: 130px
  }
  #top_contents3 .con3_no {
    left: 0;
  }
  #top_contents3 .con_before {
    right: 0;
    margin: auto;
  }
  #square_links ul li:first-child {
    margin: 0;
    margin-bottom: 25px;
  }
#intro .con1_img.normal_img {
    height: auto!important;
}
#intro .con1_img img {
    position: static;
    width: 100%!important;
    height: auto!important;
}
}

/*** IE ***/
@media all and (-ms-high-contrast:none) {
  #intro .con1_img img {
    top: 50%;
    left: 50% !important
  }
    #cms_2-a .cate .cate_title {
        padding-top: 9px;
    }
}

/*** firefox ***/
@-moz-document url-prefix() {
#top_contents2 .con_open img {
  vertical-align: bottom;
  width: 100% !important;
  height: auto !important;
}
}