@charset "utf-8";

/* -----------------------------------------
   mahalo_style.css
   Lastupdate: 2017/03/10
   Author: SONOBE
------------------------------------------*/


/* Suggested order:
 *
 * display
 * position
 * float
 * clear
 * width
 * height
 * margin
 * padding
 * border
 * background
 * color
 * font
 * text-decoration
 * text-align
 * vertical-align
 * z-index
 *
 */

 /* font-size: 16px
 *
 *  8px - 50% 
 *  9px - 56% 
 * 10px - 62% 
 * 11px - 68%
 * 12px - 75%
 * 13px - 82%
 * 14px - 88%
 * 15px - 94%
 * 16px - 100%
 * 17px - 107%
 * 18px - 113%
 * 19px - 118%
 * 20px - 125% 
 *
 */
 
 /* font-size: 18px
 *
 *  9px - 50% 
 * 10px - 55% 
 * 11px - 61%
 * 12px - 66%
 * 13px - 72%
 * 14px - 77%
 * 15px - 83%
 * 16px - 88%
 * 17px - 94%
 * 18px - 100%
 * 19px - 105%
 * 20px - 111% 
 *
 */



/* -----------------------------------------
   common 
------------------------------------------*/

body {
	width: 100%;
	font-family: Meiryo, arial, sans-serif;
	-webkit-text-size-adjust: none;
}
a:hover {
	opacity: 0.5;
	-moz-opacity: 0.5;
	-webkit-opacity: 0.5;
}
.cf {
	width: 100%;
}
.cf:after {
    content:".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
    font-size: 0.1em;/*added for FF*/
}
.caption {
	line-height: 1.6;
}
.caption p {
	margin: 0 0 10px 0;
}
.caption p:last-child {
	margin: 0;
}


  /* デバイスがDesktopのときに非表示 */
  
  @media screen and (min-width: 1200px){
	.sp {
		display: none;
	}
  }
  
  /* デバイスがSPのときに非表示 */
  
  @media screen and (max-width: 1200px){
	.desktop {
		display: none;
	}
  }

  /* Desktop Common */
  
  @media screen and (min-width: 1200px){
	body {
		font-size: 18px;
	}
	#news, #equipment, #roomplan, #location, #access, #outline, #contact {
		margin-top: -183px;
		padding-top: 183px;
	}  
  }
  
  /* Smartphone Common */
  
  @media screen and (max-width: 1200px){
	body {
		font-size: 16px;
	}
	#news, #equipment, #roomplan, #location, #access, #outline, #contact {
		margin-top: -60px;
		padding-top: 60px;
	}    
  }
	  
	  
/* -----------------------------------------
   #top
------------------------------------------*/

  /* Desktop top */
  
  @media screen and (min-width: 1200px){
	.desktop header h1 {
		padding: 40px 0;
		background-color: #1F1814;
		text-align: center;
	}
	#pc_nav {
		background-color: #FFFFFF;
		border-top: 1px solid #E9E0DE;
		border-bottom: 1px solid #E9E0DE;
	}
	#pc_nav .inner {
		width: 1200px;
		height: 78px;
		margin: 0 auto;
		border-right: 1px solid #E9E0DE;
	}
	#pc_nav ul li a {
		display: block;
		float: left;
		width: 198px;
		height: 78px;
		border-left: 1px solid #E9E0DE;
		text-align: center;
	}
	#pc_nav ul li a img {
		margin: 20px 0 0 0;
	}
  }

  /* Smartphone top */
  
  @media screen and (max-width: 1200px){
	#sp_header h1 {
		top: 0;
		left: 0;
		width: 100%;
		height: 60px;
		background-color: #1F1814;
		border-bottom: 1px solid #E9E0DE;	  
	}
	#sp_header h1 a {
		display: block;  
	}
	#sp_header h1 img {
		max-width: 260px;
		width: 65%;
		padding: 24px 0 20px 20px;
	}
	#navigation_btn {
		position: absolute;
		top: 0;
		right: 0;
		width: 60px;
		height: 60px;
		background-color: #FFFFFF;
		border-bottom: 1px solid #E9E0DE;	  
		text-align: center;
	}
	#navigation_btn img {
		max-width: 30px;
		width: 80%;
		margin: 14px;
	}
	#sp_nav ul {
		position: absolute;
		top: 60px;
		width: 100%;
		border-top: 1px solid #E9E0DE;
		z-index: 9999;
	}
	#sp_nav ul li a {
		display: block;
		padding: 15px 20px;
		background-color: #FFFFFF;
		border-bottom: 1px solid #E9E0DE;
	}
	#sp_nav ul li a:hover {
		opacity: 0.9;
		-moz-opacity: 0.9;
		-webkit-opacity: 0.9;
	}  
  }

/* -----------------------------------------
   #mainImg
------------------------------------------*/

#mainImg img {
	width: 100%;
	border-bottom: 1px solid #E9E0DE;	
}

  /* Desktop mainImg */
  
  @media screen and (min-width: 1200px){
	  #mainImg {
	  }	  
  }
  
  /* Smartphone mainImg */
  
  @media screen and (max-width: 1200px){
	  #mainImg {
	  }
  }  

  
/* -----------------------------------------
   #news
------------------------------------------*/

#news {
	width: 100%;
	border-bottom: 1px solid #E9E0DE;		
}
#news dd a {
	color: #1F1814;
}
	
  /* Desktop news */
  
  @media screen and (min-width: 1200px){
	#news {
		display: table;
	}
	#news dt {
		display: table-cell;
		width: 30%;
		padding: 20px 0;
		background-color: #1F1814;
		text-align: right;
	}
	#news dt img {
		margin: 0 20px 0 0;
	}
	#news dd {
		display: table-cell;
		padding: 20px;
		text-align: left;
		vertical-align: middle;
	} 
  }

  /* Smartphone News */
  
  @media screen and (max-width: 1200px){
	#news dt {
		padding: 20px;
		background-color: #1F1814;
		text-align: center;
	}
	#news dt img {
		width: 160px;
	}
	#news dd {
		padding: 20px;  
		text-align: center;
		line-height: 1.6;
	}
	#news dd time,
	#news dd span {
		display: block;
	}
  }
  

/* -----------------------------------------
   #equipment
------------------------------------------*/

#equipment .bg {
	border-bottom: 1px solid #E9E0DE;		
	background-color: #F0ECE2;
	text-align: center;
}

  /* Desktop equipment */
  
  @media screen and (min-width: 1200px){
	#equipment .inner {
		width: 1200px;
		margin: 0 auto;
		padding: 60px 0;	  
	}
	#equipment h2,
	#equipment h3 {
		margin: 0 0 40px 0;
	}  
	#equipment .imggallery {
		margin: 40px auto 0 auto;
	}
	#equipment .imggallery li {
		float: left;
		width: 218px;
		height: 218px;
		margin: 0 20px 20px 0;
		border: 1px solid #E9E0DE;	
	}
	#equipment .imggallery li:nth-child(5n) {
		margin: 0 0 20px 0;
	}
	
	/* equipment > leanModal */
	
	#lean_overlay {
		position: fixed;
		z-index:10000; 
		top: 0px;
		left: 0px;
		height: 100%;
		width: 100%;
		background: #000000;
		display: none;
	}
	#equipment .modal_gallery {
		width: 500px;
		background: none repeat scroll 0 0 #FFFFFF;
		box-shadow: 0 0 4px rgba(0, 0, 0, 0.7);
		display: none;
		padding: 30px;
		position: fixed;
		z-index:10001; 	  
	}
	#equipment .modal_gallery dl dd {
		  margin: 20px 0 0 0;
	}
	  
  }

  /* Smartphone equipment */
  
  @media screen and (max-width: 1200px){
	#equipment .bg {
		padding: 40px 20px;
	}
	#equipment h2 {
		max-width: 291px;
		margin: 0 auto 40px auto;
	}
	#equipment h2 img {
		width: 86%;
	} 
	#equipment h3 {
		max-width: 856x;
		margin: 0 auto 30px auto;
	}
	#equipment h3 img {
		width: 100%;
	}	
	#equipment .caption {
		margin: 0 0 20px 0;
		font-size: 75%;
	}
	#equipment .gallery-wrap {
		width: 100%;
		max-width: 500px;
		margin: 0 auto 20px auto;
	}
	#equipment .main-gallery img {
		width: 100%;
		height: auto;	
	}     
  }


/* -----------------------------------------
   #roomplan
------------------------------------------*/

#roomplan .bg {  	  
	border-bottom: 1px solid #E9E0DE;	  	
	text-align: center;
}
#roomplan .boshu_link_btn a {
	display: block;
	background-color: #1F1814;
}
		
  /* Desktop roomplan */
  
  @media screen and (min-width: 1200px){
	#roomplan .inner {
		width: 1200px;
		margin: 0 auto;
		padding: 60px 0;	  
	}
	#roomplan h2 {
		margin: 0 0 40px 0;
	}  
	#roomplan .boshu_link_btn a {
		width: 360px;
		margin: 40px auto 0 auto;
		padding: 20px;
	}
  }

  /* Smartphone roomplan */
  
  @media screen and (max-width: 1200px){
	#roomplan .bg {
		padding: 40px 20px;
	}
	#roomplan h2 {
		max-width: 278px;
		margin: 0 auto 40px auto;
	}
	#roomplan h2 img {
		width: 86%;
	}
	#roomplan .gallery-wrap {
		width: 100%;
		max-width: 550px;
		margin: 0 auto;
	}
	#roomplan .main-gallery img {
		width: 100%;
		height: auto;	
	} 
	#roomplan .boshu_link_btn a {
		margin: 50px auto 0 auto;
		padding: 15px 20px;
	}  
	#roomplan .boshu_link_btn a img {
		width: 86%;
		max-width: 215px;	    
	}
  }


/* -----------------------------------------
   #location
------------------------------------------*/

#location .bg {
	border-bottom: 1px solid #E9E0DE;		
	background-color: #F0ECE2;
	text-align: center;
}
#location01,
#location02 {
	border-bottom: 1px solid #E9E0DE;
}

  /* Desktop location */
  
  @media screen and (min-width: 1200px){
	#location .bg {
		padding: 60px 0 0 0;
	}	  
	#location .inner {
		width: 1200px;
		margin: 0 auto;
	}
	#location h2,
	#location h3 {
		margin: 0 0 40px 0;
	}
	#location01 {
		padding: 0 0 60px 0;
	}
	#locationMap {
		height: 400px;
	}
	#location03 {
		border-bottom: 1px solid #E9E0DE;
	}  
	#location_shopping {
		float: left;	 
		width: 519px;
		padding: 60px 40px;  
		border-right: 1px solid #E9E0DE;	 	  	  
	}
	#location_public {
		float: right;	  
		width: 520px;
		padding: 60px 40px;	  
	}  
	#location_shopping dl dt,
	#location_public dl dt {
		margin: 0 0 40px 0;
	}
	#location_shopping dl dd table,
	#location_public dl dd table {
		width: 520px;
	}
	#location_shopping dl dd table th,
	#location_public dl dd table th {
		width: 10%;
		height: 40px;
		color: #FFFFFF;
		background-color: #1F1815;
		border-bottom: 10px solid #F0ECE2;
		vertical-align: middle;
	}
	#location_shopping dl dd table td,
	#location_public dl dd table td {
		height: 40px;	  
		background-color: #FFFFFF;
		border-bottom: 10px solid #F0ECE2;
		vertical-align: middle;	  
	} 
	#location_shopping dl dd table td.spot,
	#location_public dl dd table td.spot {
		width: 55%;
		padding: 0 0 0 10px;	  
		text-align: left; 
	}
	#location_shopping dl dd table td.kyori,
	#location_public dl dd table td.kyori {
		width: 35%;
		padding: 0 10px 0 0;	  
		text-align: right; 
	}  
  }

  /* Smartphone location */
  
  @media screen and (max-width: 1200px){
	#location .bg {
		padding: 40px 0 0 0;
	}
	#location .inner {
		padding: 0 20px;
	}
	#location01 {
		padding: 0 0 40px 0;
	}  
	#location h2 {
		max-width: 250px;
		margin: 0 auto 40px auto;
	}
	#location h2 img {
		width: 86%;
	}
	#location h3 {
		max-width: 714px;
		margin: 0 auto 30px auto;
	}
	#location h3 img {
		width: 100%;
	}
	#location02 {
		padding: 20px;
	}
	#locationMap {
		height: 300px;
	}  
	#location03 {
		padding: 20px 20px 60px 20px;
	}  
	#location03 .gallery-wrap {
		width: 100%;
		max-width: 550px;
		margin: 0 auto;
	}
	#location03 .main-gallery img {
		width: 100%;
		height: auto;	
	}   
	#location_shopping,
	#location_public {
		padding: 40px 0;
	}
	#location_shopping {
		border-top: 1px solid #E9E0DE;
		border-bottom: 1px solid #E9E0DE;	  
	}
	#location_shopping dt {
		padding: 0 0 30px 0;
	}
	#location_shopping dt img {
		max-width: 168px;
		width: 90%;
	}
	#location_public dt {
		padding: 0 0 30px 0;
	}
	#location_public dt img {
		max-width: 476px;
		width: 90%;
	} 
	#location_shopping dl dd,
	#location_public dl dd {
		max-width: 600px;
		margin: 0 auto;
	}    
	#location_shopping dl dd table,
	#location_public dl dd table {
		width: 100%;
	}   
	#location_shopping dl dd table th,
	#location_public dl dd table th {
		width: 16%;
		color: #FFFFFF;
		background-color: #1F1815;
		border-bottom: 10px solid #F0ECE2;
		vertical-align: middle;
	}  
	#location_shopping dl dd table td,
	#location_public dl dd table td {
		width: 84%; 
		background-color: #FFFFFF;
		text-align: left;
		line-height: 1.3;
		vertical-align: middle;	  
	}
	#location_shopping dl dd table td.spot,
	#location_public dl dd table td.spot {
		  padding: 10px;
	}
	#location_shopping dl dd table td.kyori,
	#location_public dl dd table td.kyori {
		  padding: 0 10px 10px 10px;
		  border-bottom: 10px solid #F0ECE2;		
	}  
  }


/* -----------------------------------------
   #access
------------------------------------------*/

#access .bg {  	  
	border-bottom: 1px solid #E9E0DE;	  	
	text-align: center;
}

  /* Desktop access */
  
  @media screen and (min-width: 1200px){
	#access .bg {
		padding: 60px 0;
	}
	#access .inner {
		width: 1200px;
		margin: 0 auto;
	}
	#access h2,
	#access h3,
	#access .caption {
		margin: 0 0 40px 0;
	} 
	#access .rosenzu {
		float: left;
		margin: 0 30px 0 0;
	}
	#access .access_info {
		float: left;
	}
	#access .access_info .station_img {
		float: left;
		margin: 0 30px 30px 0;
	}
	#access .access_info .station_img img {
		width: 280px;
	}	
	#access .access_info dl {
		float: left;
		width: 410px;
	}
	#access .access_info dt {
		margin: 0 0 20px 0;
		padding: 30px 0 0 0;
		text-align: left;
	}
	#access .access_info dd table {
		width: 100%;
	}
	#access .access_info dd table th {
		padding: 10px;	  
		border-bottom: 1px dotted #E9E0DE;
		text-align: left;
	}
	#access .access_info dd table th span {
		font-size: 88%;
	}
	#access .access_info dd table td {
		padding: 10px;	  
		border-bottom: 1px dotted #E9E0DE;
		text-align: right;
	}  
		
  }

  /* Smartphone access */
  
  @media screen and (max-width: 1200px){
	#access .bg {
		padding: 40px 20px;
	}
	#access h2 {
		max-width: 177px;
		margin: 0 auto 40px auto;
	}
	#access h2 img {
		width: 86%;
	}
	#access h3 {
		max-width: 570px;
		margin: 0 auto 30px auto;
	}
	#access h3 img {
		width: 100%;
	} 
	#access .caption {
		margin: 0 0 40px 0;
	}
	#access .rosenzu {
		max-width: 550px;
		margin: 0 auto 40px auto;
	} 
	#access .rosenzu img {
		width: 100%;
	} 
	#access .access_info .station_img {
		max-width: 550px;
		margin: 0 auto 15px auto;
	}
	#access .access_info .station_img img {
		width: 100%;
	}
	#access .access_info dt {
		margin: 0 auto 20px auto;
		padding: 10px 0 0 0;
	} 
	#access .access_info .nanboku dt {
		max-width: 344px;
	}
	#access .access_info .keihin dt {
		max-width: 291px;
	}          
	#access .access_info .nanboku dt img,
	#access .access_info .keihin dt img {
		width: 100%;
	}      
	#access .access_info dd {
		max-width: 600px;
		margin: 0 auto;
	} 
	#access .access_info .nanboku dd {
		margin: 0 auto 40px auto;
	}
	#access .access_info dd table {
		width: 100%;
	}
	#access .access_info dd table th {
		width: 70%;
		padding: 10px;	  
		border-bottom: 1px dotted #E9E0DE;
		text-align: left;
		line-height: 1.6;	  
	}
	#access .access_info dd table th span {
		display: block;
		font-size: 88%;
	}
	#access .access_info dd table td {
		padding: 10px;	  
		border-bottom: 1px dotted #E9E0DE;
		text-align: right;
		vertical-align: middle;
		line-height: 1.6;	  
	}              
  }


/* -----------------------------------------
   #outline
------------------------------------------*/

#outline .bg {
	background-color: #F0ECE2;
	text-align: center;
}

  /* Desktop outline */
  
  @media screen and (min-width: 1200px){
	#outline .bg {
		padding: 60px 0 0 0;
	}
	#outline .inner {
		width: 1200px;
		margin: 0 auto;
	}
	#outline h2 {
		margin: 0 0 40px 0;
	} 
	#outline #googleMap {
		height: 300px;
	}
	#outline_gaiyou {
		float: left;	 
		width: 519px;
		padding: 60px 40px;      	  
	}
	#outline_jouken {
		float: right;	  
		width: 520px;
		padding: 60px 40px;	  
	}  
	#outline_gaiyou dl dt,
	#outline_jouken dl dt {
		margin: 0 0 40px 0;
	}
	#outline_gaiyou dl dd table,
	#outline_jouken dl dd table {
		width: 520px;
	}
	#outline_gaiyou dl dd table th,
	#outline_jouken dl dd table th {
		width: 30%;
		height: 40px;
		color: #FFFFFF;
		background-color: #1F1815;
		border-bottom: 10px solid #F0ECE2;
		vertical-align: middle;
	}
	#outline_gaiyou dl dd table td,
	#outline_jouken dl dd table td {
		padding: 10px;
		background-color: #FFFFFF;
		font-size: 88%;
		text-align: left;
		line-height: 1.6;
		border-bottom: 10px solid #F0ECE2;	  
		vertical-align: middle;	  
	}      
  }

  /* Smartphone outline */
  
  @media screen and (max-width: 1200px){
	#outline .bg {
		padding: 40px 20px;
	}
	#outline h2 {
		max-width: 210px;
		margin: 0 auto 40px auto;
	}
	#outline h2 img {
		width: 86%;
	}
	#outline #googleMap {
		height: 300px;
		margin: 0 0 40px 0;
	}  
	#outline_gaiyou dl dt,
	#outline_jouken dl dt {
		max-width:  168px;	  
		margin: 0 auto 20px auto;
	}  
	#outline_gaiyou dl dt img,
	#outline_jouken dl dt img {
		max-width:  90%;
	}
	#outline_gaiyou dl dd,
	#outline_jouken dl dd {
		max-width: 600px;
		margin: 0 auto;
	}  
	#outline_gaiyou dl dd {
		margin: 0 auto 40px auto;
	}
	#outline_gaiyou dl dd table,
	#outline_jouken dl dd table {
		width: 100%;
	}  
	#outline_gaiyou dl dd table th,
	#outline_jouken dl dd table th {
		padding: 10px;	  
		color: #FFFFFF;
		font-size: 88%;	  
		background-color: #1F1815;
		vertical-align: middle;
	}
	#outline_gaiyou dl dd table td,
	#outline_jouken dl dd table td {
		padding: 10px;
		background-color: #FFFFFF;
		font-size: 88%;
		text-align: left;
		line-height: 1.6;	  
		vertical-align: middle;	  
	}       
  }


/* -----------------------------------------
   #contact
------------------------------------------*/

#contact .bg { 	  
	border-bottom: 1px solid #E9E0DE;	  	
	text-align: center;
}
#contact table input,
#contact table textarea {
	width: 100%;
	font-size: 125%;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;	  
} 

  /* Desktop contact */
  
  @media screen and (min-width: 1200px){
	#contact .bg {
		padding: 60px 0;
	}
	#contact .inner {
		width: 1200px;
		margin: 0 auto;
	}
	#contact h2 {
		margin: 0 0 40px 0;
	}
	#contact .caption {
		margin: 0 0 40px 0;
	}
	#contact #mailform {
		width: 920px;
		margin: 40px auto 0 auto;
		padding: 60px;
		background-color: #66CCFF;	  
	}
	#contact #mailform table {
		width: 100%;
	}
	#contact #mailform th {
		padding: 10px 10px 10px 0;
		color: #1F1814;
		text-align: left;
		vertical-align: middle;
	}  
	#contact #mailform th span {
		margin: 0 0 0 10px;
	}
	#contact #mailform td {
		padding: 10px 0;
	}
	#contact #mailform #submit_btn {
		margin: 20px 0 0 0;
	} 
  }

  /* Smartphone contact */
  
  @media screen and (max-width: 1200px){
	#contact .bg {
		padding: 40px 20px;
	}
	#contact h2 {
		max-width: 229px;
		margin: 0 auto 40px auto;
	}
	#contact h2 img {
		width: 86%;
	}
	#contact .contact_tel {
		max-width: 317px;
		margin: 40px auto 0 auto;
	}
	#contact .contact_tel img {
		width: 100%;
	}
	#contact #mailform {
		margin: 40px 0 0 0;
		padding: 20px;
		background-color: #66CCFF;	  
	}  
	#contact #mailform table {
		width: 100%;
	}  
	#contact #mailform th {
		padding: 5px 0 5px 20px;
		color: #1F1814;
		line-height: 1.4;	 
		text-align: left; 
	}  
	#contact #mailform th span {
		margin: 0 0 0 10px;
	}
	#contact #mailform td {
		width: 100%;
		padding: 10px 20px 20px 20px;
	}  
	#contact #mailform #submit_btn {
		max-width: 400px;
		margin: 0 auto;
	} 
	#contact #mailform #submit_btn input {
		width: 100%;
	}
  }
  

/* -----------------------------------------
   #gotoTop
------------------------------------------*/

#gotoTop {
	background-color: #1F1814;
}
#gotoTop a {
	display: block;
	padding: 15px 0;
	text-align: center;
}


/* -----------------------------------------
   #footer
------------------------------------------*/

#footer {
	font-size: 88%;
	text-align: center;	
}
#footer p {
	margin: 0 0 15px 0;
}
#footer p:last-child {
	margin: 0 !important;
}

  /* Desktop footer */
  
  @media screen and (min-width: 1200px){
	#footer {
		padding: 40px 0;
	}

  }

  /* Smartphone footer */
  
  @media screen and (max-width: 1200px){
	#footer .bg {
		padding: 40px 20px 25px 20px;
	}
	.corp_logo {
		max-width: 353px;
		margin: 0 auto 15px auto !important;
	}
	.corp_logo img {
		width: 100%;
	}
  }
  
 
/* -----------------------------------------
   javascript
------------------------------------------*/

/* js-clingify（ヘッダー固定） */

.js-clingify-ztransform, .js-clingify-wrapper {
	-webkit-transform: translateZ(0);
	-moz-transform: translateZ(0);
	-ms-transform: translateZ(0);
	-o-transform: translateZ(0);
	transform: translateZ(0);
}
.js-clingify-wrapper {
	width: 100%;
}
.js-clingify-locked {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}
.js-clingify-locked #pc_navi,
.js-clingify-locked #sp_navi {
	opacity: 0.99;
}  

/* ImageGallery（flickity）*/

.flickity-enabled {
	position: relative;
}

.flickity-enabled:focus {
	outline: none;
}
.flickity-viewport {
	overflow: hidden;
	position: relative;
} 
.flickity-slider {
	position: absolute;
	width: 100%;
	height: 100%;
}
.flickity-enabled.is-draggable {
	-webkit-tap-highlight-color: transparent;
			tap-highlight-color: transparent;
	-webkit-user-select: none;
	   -moz-user-select: none;
		-ms-user-select: none;
			user-select: none;
}
.flickity-enabled.is-draggable .flickity-viewport {
	cursor: move;
	cursor: -webkit-grab;
	cursor: grab;
}
.flickity-enabled.is-draggable .flickity-viewport.is-pointer-down {
	cursor: -webkit-grabbing;
	cursor: grabbing;
}
.flickity-prev-next-button {
	position: absolute;
	top: 50%;
	width: 44px;
	height: 44px;
	border: none;
	border-radius: 50%;
	background: white;
	background: hsla(0, 0%, 100%, 0.75);
	cursor: pointer;
	/* vertically center */
	-webkit-transform: translateY(-50%);
			transform: translateY(-50%);
}
.flickity-prev-next-button:hover {
	background: white;
}
.flickity-prev-next-button:focus {
	outline: none;
	box-shadow: 0 0 0 5px #09F;
}
.flickity-prev-next-button:active {
	opacity: 0.6;
}
.flickity-prev-next-button.previous {
	left: 10px;
}
.flickity-prev-next-button.next {
	right: 10px;
}
.flickity-rtl .flickity-prev-next-button.previous {
	left: auto;
	right: 10px;
}
.flickity-rtl .flickity-prev-next-button.next {
	right: auto;
	left: 10px;
}
.flickity-prev-next-button:disabled {
	opacity: 0.3;
	cursor: auto;
}
.flickity-prev-next-button svg {
	position: absolute;
	left: 20%;
	top: 20%;
	width: 60%;
	height: 60%;
}
.flickity-prev-next-button .arrow {
	fill: #333;
}
.flickity-page-dots {
	position: absolute;
	width: 100%;
	bottom: -35px;
	padding: 20px 0 0 0;
	margin: 0;
	list-style: none;
	text-align: center;
	line-height: 1;
}
#equipment .flickity-page-dots {
	position: absolute;
	width: 100%;
	bottom: -55px;
	padding: 20px 0 0 0;
	margin: 0;
	list-style: none;
	text-align: center;
	line-height: 1;
}
.flickity-rtl .flickity-page-dots {
	direction: rtl;
}
.flickity-page-dots .dot {
	display: inline-block;
	width: 10px;
	height: 10px;
	margin: 0 5px;
	background: #66CCFF;
	border-radius: 50%;
	opacity: 0.25;
	cursor: pointer;
}
.flickity-page-dots .dot.is-selected {
	opacity: 1;
} 

