@charset "utf-8";


/*--------------------------------------------------------------------------
   html
---------------------------------------------------------------------------*/

html{
	overflow-y: scroll;
  scroll-behavior: smooth;
}


/*--------------------------------------------------------------------------
   body
---------------------------------------------------------------------------*/

/* fonts */
.bebas{
	font-family: 'Bebas Neue', sans-serif;	
}
.inter{
	font-family: 'Inter', sans-serif;
}
.serif{
	font-family: 'Shippori Antique', sans-serif;
}
.sans-serif{
	font-family: 'Zen Kaku Gothic New', sans-serif;
}


/*--------------------------------------------------------------------------
   base link
---------------------------------------------------------------------------*/
.ophover{
	transition: opacity ease .3s;	
}
.ophover:hover{
	opacity: .7;
}

.phone-link{
  pointer-events: none;  
}


/*--------------------------------------------------------------------------
   img
---------------------------------------------------------------------------*/
img{
	image-rendering: -webkit-optimize-contrast;
	image-rendering: crisp-edges;		
}

/*--------------------------------------------------------------------------
   Animation
---------------------------------------------------------------------------*/

.fade,.fade01,.fade02,.fade03,.fade04,.blur,.zoom,
.delay01,.delay02,.delay03,.delay04,.delay05 {
	transition: 1.3s;
}
.fade {
	opacity: 0;
	transform: translate(0,0); 
}
.fade01{
	opacity: 0;
	transform: translate(0,50px); 
}
 .fade02 {
	opacity: 0;
	transform: translate(0,-50px); 
}
.fade03 {
	opacity: 0;
	transform: translate(-50px,0); 
}
.fade04 {
	opacity: 0;
	transform: translate(50px,0); 
}
.blur {
  -webkit-filter: blur(14px);
	filter: blur(14px);  
}
.zoom{
  transform: scale(1.1,1.1); 
}
.delay01{
	transition-delay: 0.3s;		
}
.delay02{
	transition-delay: 0.6s;		
}
.delay03{
	transition-delay: 0.9s;		
}
.delay04{
	transition-delay: 1.2s;		
}
.delay05{
	transition-delay: 1.5s;		
}

 .mv {
	opacity: 1;
  -webkit-filter: blur(0);
	filter: blur(0);
	transform: translate(0,0) scale(1,1); 
}

@keyframes circle-rotation {
	0% {
    transform: rotate(0deg);
  }
	100% {
    transform: rotate(360deg);
  }
}

/*--------------------------------------------------------------------------
   PC
---------------------------------------------------------------------------*/
.sp{
	display: none;	
}
/* box-sizing ---*/	
header, footer, main, section, div, h1, h2, h3, h4, h5, h6, p, ul, ol, li, dl, dt, dd, th, td, a, span, small, strong, em, input, select, textarea, button {
	box-sizing: border-box;
}


/*--------------------------------------------------------------------------
   Container
---------------------------------------------------------------------------*/
#Page{
	overflow: hidden;	
}
.inner{
	max-width: 1240px;
	padding: 0 20px;
	margin: 0 auto;
}
.layout-box{
  display: flex;
  justify-content: space-between;  
}



/*--------------------------------------------------------------------------
   header
---------------------------------------------------------------------------*/
#Header{
	position: fixed;
  left: 0;
  top: 0;
  z-index: 10000;
	padding: 17px;
  background: #fff;
	font-family: 'Zen Kaku Gothic New', sans-serif;
	letter-spacing: .02em;
}
#Header .header-cont{
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: 100%;
	margin-bottom: 45px;
}
#Header .util-nav{
	display: flex;
	margin-right: 25px;
}
#Header .util-nav li{
	position: relative;
}
#Header .util-nav li:nth-child(n+2){
	margin-left: 16px;
	padding-left: 16px;	
}
#Header .util-nav li:nth-child(n+2)::before{
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	display: block;
	width: 1px;
	height: 17px;
	content: "";
	background: #000;
}
#Header .util-nav a{
	padding-left: 20px;
	font-size: 13px;
	font-weight: 500;
	background: no-repeat left center;
	background-size: 11px auto;
}
#Header .util-nav .link-map a{
	background-image: url(../../images/_rev_common/ico_marker.svg);
}
#Header .util-nav .link-outline a{
	background-image: url(../../images/_rev_common/ico_document.svg);
}
#Header .header-cv{
	display: flex;
}
#Header .header-cv a{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 98px;
	height: 42px;
	border-radius: 50px;
	font-size: 13px;
	color: #fff;
	font-weight: bold;
}
#Header .header-cv .request a{
	background: #000;
}
#Header .header-cv .reserve a{
	background: #cbfc6a;
  color: #000;
}
#Header .header-cv .request{
	margin-left: 5px;
}
.btn-trigger{
  display: none;  
}


/* ---------------------------------------------------------------------------
	 #Gnav	
	 グローバルナビゲーション
--------------------------------------------------------------------------- */
#Gnav{
	display: flex;
	align-items: center;
}
#Gnav::before,
#Gnav::after{
	display: block;
	width: 100%;
	height: 1px;
	content: "";
	background: #000;
}
#Gnav .gnav{
	display: flex;
	justify-content: center;
	flex-shrink: 0;
}
#Gnav .gnav li{
	position: relative;
	padding: 0 1.2vw;
	text-align: center;
	line-height: 1.4; 
}
#Gnav .gnav li.new::before{
  content: 'NEW';
  position: absolute;
  top: -21px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  font-family: 'Bebas Neue', sans-serif;
  font-size: 2rem;
  letter-spacing: 1px;
  line-height: 1;
  color: #fff;
  background-color: #d73649;
  padding: 3px 5px 0px;
}
@media screen and (max-width: 768px) {
  #Gnav .gnav li.new::before{
    top: -14px;
    font-size: 1.3rem;
  }
}
#Gnav .gnav a strong{
	display: inline-block;
	font-size: 16px;
	font-family: 'Inter', sans-serif;
	background:no-repeat linear-gradient(transparent 0%, #cdf283 0%);
	background-size: 0% 100%;
	transition: .3s;
}
#Gnav .gnav a small{
	display: block;
	font-size: 11px;
	font-weight: 500;
}
#Gnav .gnav .current a strong,
#Gnav .gnav a:hover strong{
	background-size: 100% 100%;
}

/*--------------------------------------------------------------------------
   Content
---------------------------------------------------------------------------*/
.contents {
	margin-top: 164px;
}

/* clearfix
-----------------------------------------------------------------*/
.cf:after{
	clear :both;
	content: "";
	display: block;
	height: 0;
}


/*--------------------------------------------------------------------------
   Footer
---------------------------------------------------------------------------*/
#Footer{
	position: relative;
	padding: 65px 4vw 115px;
	background: #f1f1f1; 
}
#Footer .pagetop{
	display: none;
	position: fixed;
	right: 20px;
	bottom: 40px;
	z-index: 500;
}
#Footer .pagetop a{
	transition: .3s;
}
#Footer .pagetop a:hover{
	opacity: .7;
}
#Footer .pagetop em{
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
	text-align: center;
}
#Footer .pagetop span img{
	animation: circle-rotation linear 12s infinite running;	
}
#Footer .layout-box{
	margin-bottom: 55px;
}
#Footer .info-area{
	margin-right: 20px;
	font-family: 'Zen Kaku Gothic New', sans-serif;
}
#Footer .info-area h3{
	font-size: 16px;
	font-weight: bold;
}
#Footer .info-area .phone a{
	padding-left: 28px;
	background: url(../../images/_rev_common/ico_freedial.svg) no-repeat left center;
	background-size: 20px auto;
	font-size: 43px;
	font-weight: bold;
	font-family: 'Inter', sans-serif;
}
#Footer .info-area .businesshour{
	font-size: 12px;
}
#Footer .co-list{
	display: flex;
}
#Footer .co-list li:nth-child(n+2){
	margin-left: 43px;
}
#Footer .co-list small{
	display: block;
	margin-bottom: 15px;
	font-size: 14px;
	font-family: 'Zen Kaku Gothic New', sans-serif;
}
#Footer .co-list li:nth-child(1) img{
	max-width: 138px;
}
#Footer .co-list li:nth-child(2) img{
	max-width: 257px;
}
#Footer .copyright{
	font-size: 11px;
	font-family: 'Inter', sans-serif;
}
















/*--------------------------------------------------------------------------
   mobile
---------------------------------------------------------------------------*/
@media screen and (max-width: 768px) {
  
  #Page {
    min-width: 320px;	
  }
  
  .pc{
    display: none;	
  }
  .sp{
    display: block;	
  }
  img.sp,
  br.sp{
    display: inline;
  }
  
  .phone-link{
    pointer-events: auto;  
  }


/*--------------------------------------------------------------------------
   Container
---------------------------------------------------------------------------*/
  .inner{
    max-width: none;	
  }

/*--------------------------------------------------------------------------
   header
---------------------------------------------------------------------------*/
  #Header{
    position: relative;
    padding: 0;
  }
  #Header .header-cont{
    display: block;
    width: 100%;
    margin-bottom: 0;
  }
  #Header .util-nav{
    display: block;
    width: 240px;
    margin: 0 auto 6px;
  }
  #Header .util-nav li{
    position: relative;
  }
  #Header .util-nav li:nth-child(n+2){
    margin-left: 0;
    padding-left: 0;	
  }
  #Header .util-nav li:nth-child(n+2)::before{
    display: none;
  }
  #Header .util-nav a{
    padding-left: 20px;
    font-size: 13px;
    font-weight: 500;
    background: no-repeat left center;
    background-size: 11px auto;
  }
  #Header .util-nav .link-map a{
    background-image: url(../../images/_rev_common/ico_marker.svg);
  }
  #Header .util-nav .link-outline a{
    background-image: url(../../images/_rev_common/ico_document.svg);
  }
  #Header .header-cv{display: flex; justify-content: space-between; padding: 0 4svw;}
  #Header .header-cv li{flex-basis: 49%;}
  #Header .header-cv li:nth-child(n+2){
    /* margin-top: 15px;   */
  }
  #Header .header-cv a{
    max-width: 300px;
    width: 100%;
    height: 50px;
    margin: 0 auto;
    font-size: 16px;
    letter-spacing: .08em;
  }
  #Header .header-cv .request{
    margin-left: 5px;
  }
  
  #Drawer{
    position: fixed;
    left: 0;
    top: 0;
    z-index: 12000;
    display: flex;
    flex-direction: column-reverse;
    justify-content: center;
    width: 100%;
    height: 100vh;
    padding: 20px auto;
    overflow: auto;
    background: #fff;
    transition: .4s;
    transform: translateX(-110%);  
  }
	#Drawer.open{
		transform: translateX(0);
	}
  .btn-trigger{
    position: fixed;
    right: 8px;
    top: 8px;
    z-index: 13000;
    display: block;
    width: 46px;
    height: 46px;
    border-radius: 6px;
    background: #fff;
    caret-color: transparent;  
  }
  .btn-trigger span{
    position: absolute;
    left: 8px;
    width: 30px;
    height: 2px;
    background: #000;
		transition: .3s;  
  }
  .btn-trigger span:nth-child(1){
    top: calc(50% - 6px);
  }
  .btn-trigger span:nth-child(2){
    top: 50%;
  }
  .btn-trigger span:nth-child(3){
     top: calc(50% + 6px);
  }
  .btn-trigger.on span:nth-child(1){
    transform: rotate(45deg) translateY(9px);
  }
  .btn-trigger.on span:nth-child(2){
    opacity: 0;
  }
  .btn-trigger.on span:nth-child(3){
     transform: rotate(-45deg) translateY(-9px);
  }



/* ---------------------------------------------------------------------------
	 #Gnav	
	 グローバルナビゲーション
--------------------------------------------------------------------------- */
  #Gnav{
    display: block;
    margin-bottom: 10px;
  }
  #Gnav::before,
  #Gnav::after{
    display: none;
  }
  #Gnav .gnav{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  #Gnav .gnav li{
    flex-basis: 50%;
    padding: 0 20px;
    margin-bottom: 5%;
  }
  /* #Gnav .gnav li:nth-child(n+2){
    margin-top: 12px;  
  } */
  #Gnav .gnav .current a strong,
  #Gnav .gnav a:hover strong{
    background: transparent;
  }


/*--------------------------------------------------------------------------
   Content
---------------------------------------------------------------------------*/
  .contents {
    margin-top: 0;
  }
    
    
/*--------------------------------------------------------------------------
   Footer
---------------------------------------------------------------------------*/
  #Footer{
    padding: 50px 10px 100px;
		text-align: center;
  }
  #Footer .pagetop{
    right: 5px;
    bottom: 80px;
		width: 70px;
  }
  #Footer .pagetop a:hover{
    opacity: 1;
  }
	#Footer .pagetop em img{
		width: 52px;
	}
	
  #Footer .layout-box{
    display: block;
    margin-bottom: 30px;
  }
  #Footer .info-area{
    margin: 0 0 30px;
  }
  #Footer .info-area h3{
    font-size: 15px;
  }
  #Footer .info-area .phone a{
    font-size: 35px;
		line-height: 1.3;
  }
  #Footer .info-area .businesshour{
    font-size: 10px;
  }
  #Footer .co-list{
    display: block;
    text-align: center;
  }
  #Footer .co-list li:nth-child(n+2){
    margin: 20px 0 0;
  }
  #Footer .co-list small{
    margin-bottom: 8px;
    font-size: 10px;
  }
  #Footer .co-list li:nth-child(1) img{
    max-width: 130px;
  }
  #Footer .co-list li:nth-child(2) img{
    max-width:192px;
  }
  #Footer .copyright{
		display: block;
    font-size: 10px;
		letter-spacing: 0;
  }

  
}

/* footer_cv */

.footer_cv_wrap{display: none;}

@media screen and (max-width: 768px) {
  .footer_cv_wrap{
    position: fixed;
    bottom: 0; left: 0;
    z-index: 101;
  }
  .footer_cv{
    display: flex;
    justify-content: space-between;
    width: 100svw;
    margin: auto;
    padding: 0;
  }
  .footer_cv li{
    width: 25%;
  }
  .footer_cv li{
    width: 100%;
    height: 100%;
    position: relative;
  }
  .footer_cv img{
    width: 20px;
    margin-right: 5px;
  }
  .footer_cv li::before{
    content: '';
    display: block;
    position: absolute;
    background-position: top center;
    background-size: 100%;
    background-repeat: no-repeat;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -75%);
    -webkit-transform: translate(-50%, -75%);
    -ms-transform: translate(-50%, -75%);
  }
  .footer_cv .reserve::before{
    background-image: url(../../images/_rev_common/sp_fotter_icon_res.svg);
    width: 25px; height: 26px;
  }
  .footer_cv .reserve a {
    background: #cbfc6a;
    color: #000;
}
.footer_cv .request::before{
  background-image: url(../../images/_rev_common/sp_fotter_icon_req.svg);
  width: 25px; height: 23px;
}
.footer_cv .request a {
  background: #1E1E1E;
  color: #fff;
}
.footer_cv .tel::before{
  background-image: url(../../images/_rev_common/sp_fotter_icon_tel.svg);
  width: 19px; height: 26px;
}
.footer_cv .tel a {
  background: #F1F1F1;
  color: #000;
}
.footer_cv .map::before{
  background-image: url(../../images/_rev_common/sp_fotter_icon_map.svg);
  width: 21px; height: 26px;
}
.footer_cv .map a {
  background: #F1F1F1;
  color: #000;
}
.footer_cv a {
  width: 100%;
  height: 65px;
  margin: 0 auto;
  padding-bottom: 5px;
  font-size: 9px;
  letter-spacing: .2em;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  font-weight: bold;
  border: 1px solid #fff;
}

}



