﻿@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@500&display=swap');
.font1,.catch span,.nav a,
.t_cms_txt2,.t_cms_txt3,.t_cms_txt5,.t_cms_txt6,.t_cms_txt8,.t_cms_txt9,
.cms_title,.other_link .box_title,.other_link .box_title2,.page_title_box{
    font-family: 'Shippori Mincho', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", serif;
    
}


/*--------------20210915------------------------------------------------------*/

/*loading*/
#loading_bg{
	height: 100vh;
	width: 100vw;
	z-index: 200;
	top: 0;
}
#loading{
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
}
#loading img{
	z-index: 1
}
#loading .gauge{
	width: 0;
	background-image:url(./Dup/img/cats.png);
	background-repeat:no-repeat;
	background-position:top right;
}

#wrap {
    width: 100%; 
    margin: auto; 
    margin-top: 0; 
}
.top_page header{
    width:100%;
}
.main_img_wrap{
    width:100%;
}
#video::before{
    content: '';
    position: absolute;
    display: block;
    width: 30vw;
    height: 46vh; 
    background-image: url(./Dup/img/frame.png);
    top: 0;
    left: 0;    
    background-repeat: no-repeat;
    background-size: contain;    
    z-index: 2;
    pointer-events: none;
}

.frame2{
    bottom: 0;
    right: 0;
    z-index: 3;
    width: 25vw;
}


/*下からフェードイン*/
 .fadein {
  opacity: 0;
  transform : translate(0, 50px);
  transition : all 1500ms;
}
.fadein.scrollin{
  opacity: 1;
  transform: translate(0, 0);
}
.neko1{
    bottom: -150px;
    right: -150px;
    z-index: 2;
}
.neko2{
    bottom: -150px;
    left: -150px;
    z-index: 2;    
}
.neko3{
    bottom: -150px;
    right: -110px;
    z-index: 2;
}
.neko4{margin-top:100px;}
.neko1 img,.neko2 img,.neko3 img,.neko4 img{width:auto;}
.youtube_box{
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube_box iframe{
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

.slide_img .thumbnail .swiper-wrapper {
    margin-left: 0!important;
    transform: none!important;
}
.cat_img{
    position: relative;
    overflow: hidden;
    
}
.cat_img img {
    position: relative;
    top: 50%!important;
    left: 50%!important;
    -ms-transform: translate(-50%,-50%)!important;
    -webkit-transform: translate(-50%,-50%)!important;
    transform: translate(-50%,-50%)!important;
}

.swiper-wrapper{transform: translate3d(0, 0px, 0px);}


/* slide_img */
.slide_img .main {
  margin-bottom: 10px;
}
.slide_img .thumbnail .swiper-slide {
  cursor: pointer;
  opacity: .7;
}
.slide_img .thumbnail .swiper-slide-active {
  opacity: 1;
}
.slide_img .thumbnail .swiper-wrapper {
  margin-left: calc(-37.5% - 5px);
}
.slide_img .thumbnail .swiper-wrapper{margin-left: 0!important;transform: none!important;}


/*-----all page-----------------------
------------------------------------*/
/*.is-fixed{border-radius:0 0 100% 100%;}*/
.is-fixed .logo {width: 6%!important;}
.linkStyle{
    color:#bf9d74;
    text-decoration:underline;
}
.linkStyle:hover{
    transition:all 0.3s;
    opacity:0.7;
}

.sns_links li {
    max-width: 30px;
}


/*-----top page-----------------------
------------------------------------*/
.top_nav{display:none;}
.img-container:before{
    display:none;
}
.main_img_wrap{max-height:initial;min-height:auto;}
.main_img_wrap .catch{
    top:70%;
    left:50%;
    transform: translate(-50%,-50%);
    font-size:3rem;
    letter-spacing: 10px;    
}
.main_img_wrap .navi{display:none;}
.t_cms_txt3,.t_cms_txt6,.t_cms_txt9{
    font-size:1.8rem;
}
.t_cms_txt3 span,.t_cms_txt6 span,.t_cms_txt9 span{
    color: #fff;
}
#contents .box figure:after{display:none;}
#contents{
    /*
    background-image:url(./Dup/img/con_bg.jpg);
    background-size:contain;
    background-attachment:fixed;
    */
    background-color:#333;
    color:#fff;
}
#contents .t_cms_img1 img,
#contents .t_cms_img2 img,
#contents .t_cms_img3 img{
    border-radius: 50% 65% 63% 56%/57% 57% 61% 66%;
}
.neko{padding-top:80px;}
.neko_txt{
    font-size:2rem;
    font-weight: bold;
}
.neko_txt::before{
    content:'';
    position:absolute;
    display:block;
    width:60px;
    height:3px;
    background-color:#f3bdbd;
    bottom:-20px;
    left:0;
    right:0;
    margin:auto;
    
}
#top_cms .line{
    display:none;
}
.cms_title{position:relative;}
.cms_title::before{
    content:'';
    position:absolute;
    display:block;
    width:5vw;
    height:9vh;
    background-image:url(./Dup/img/item1.png);
    background-repeat:no-repeat;
    background-size:contain;
    top:0;
    left:0;
    z-index:0;
}
.cms_1-e .date{border-radius:5px;}
.cms_1-e figure,.cms_2-a figure img{border-radius:10px;}
.cms_6-c figure{border-radius:5px;}
.cms_6-c h3{
    font-size: 1.2rem;
    letter-spacing: -1px;
}
.cms_4-a .box_img1{border-radius:50%;}
.cms_4-a .cate_box{margin:10px;}
.top_cms_box .more_box .more{border-radius:5px;}
.other .box:hover p, .other .box:hover h2 span{text-shadow: 0 1px 2px rgba(0,0,0,0.5);}
#dec1, #dec3, #dec5, #dec7,#dec2, #dec4, #dec6, #dec8{color:#eb6d87;}



/*--top page animation----------------------*/
/* 拡大 */
.zoomInTrigger,
.zoomOutTrigger{
    opacity: 0;
}
.zoomIn{
  animation-name:zoomInAnime;
  animation-duration:0.5s;
  animation-fill-mode:forwards;
}

@keyframes zoomInAnime{
  from {
  transform: scale(0.6);
  opacity: 0;
  }

  to {
    transform: scale(1);
  opacity: 1;
  }
}




/*---- under page-----------------------
------------------------------------*/
#title_img span::after{
    content:'';
    position:absolute;
    display:block;
    width:100%;
    height:100%;
    background-color:rgba(255,255,255,0.2);
    top:0;
    left:0;
    z-index:1;
}



/* ---------- responsive ---------- */
@media screen and (max-width: 1437px){
.main_img_wrap .catch{font-size:2.5rem;}

}

@media screen and (max-width: 1285px){
.neko1, .neko3 {
    bottom: -70px;
}
.neko2 {
    bottom: -100px;
}
}

@media screen and (max-width: 1210px){
.main_img_wrap .catch {
    font-size: 2rem;
}
}

@media screen and (max-width: 1010px){
.main_img_wrap .catch {
    font-size: 1.5rem;
}
}

/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){
#header{padding-top:15px;}
.main_wrap{margin-top: 55vh;}
.main_img{padding-top:100px;}
.main_img_wrap .catch {
    top:50%;
    font-size: 2rem;
    width: 100%;
    text-align: center;
}
.frame2 {bottom: 44%;}
#contents .box .txt_wrap {
    width: 90%;
    padding-right: 0;
}
#contents .box figure {width: 65%;}
.t_cms_txt4,.t_cms_txt10{margin-bottom:30px;}
.cms_title::before{width:10vw;}
.cate_list li{width:45%;}
.neko1, .neko3 {
    bottom: -400px;
    right: 10px;
}
.neko2 {
    bottom: auto;
    top: -250px;
    left: auto;
    right: 20px;
}    
}

/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){

#header {padding-top: 10px;}
.main_wrap{margin-top: 45vh;}
.main_img{padding-top:70px;}
.main_img_wrap .catch{
    font-size:1.2rem;
    letter-spacing:6px;
    top:40%;
}
.video{
    width:100%!important;
    height:auto!important;
}
.frame2 {
    bottom: 57.5%;
}
.t_cms_txt3, .t_cms_txt6, .t_cms_txt9 {font-size: 1.5rem;}
#contents{padding-top:30px;}
#contents .box figure {width: 85%;}
.t_cms_txt4, .t_cms_txt10 {margin-bottom: 0;}
#top_cms .top_cms_wrap{padding-bottom:100px;}
.cms_4-a .cate_box{width:80%!important;}

.other .box {
    transition: unset;
}
.other .box_title {
    font-size:7vw;
}

    
#page_title .img-container::after {background-color: rgba(216,216,216,0.1);}
.page_title_box .txt_shadow-l{text-shadow:1px 1px 2px rgba(0,0,0,0.3);}
.cate_list li {width: 100%;}
.neko1 img, .neko2 img, .neko3 img {
    width: 60%;
}
 .neko4 img{width:40%;}
.neko1, .neko3 {
    bottom: -300px;
    right: -60px;
}
.neko2 {
    bottom: auto;
    top: -150px;
    left: auto;
    right: -75px;
}
}

@media screen and (max-width: 375px){
.main_wrap {
    margin-top: 35vh;
}
.frame2 {
    bottom: 64.5%;
}
}

/* ---------- IEの処理 ---------- */
@media all and (-ms-high-contrast: none){
#contact_tel a{padding-top:35px;}
}








