@charset "UTF-8";

body {
	text-align: center;
	font-family: var(--ff_got);
	font-weight: normal;
	font-style: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	color: var(--color_base);
	font-size: 16px;
	letter-spacing: .15em;
	line-height: 1.9em;
	padding: 0;
	margin: 0;
	background: #fff;
	-webkit-text-size-adjust: 100%;
}
div,
dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
pre,form,fildset,p,blockquote,
header,footer,nav,main{
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	font-style:normal;
	box-sizing: border-box;
}
img{
    max-width:100%;
    height:auto;
    width:auto\9; /* ie8 */
	border-top-style:none;
	border-right-style:none;
	border-bottom-style:none;
	border-left-style:none;
	vertical-align:top;
	display:block;
	margin:auto;
}
table {
    font-size:inherit;
	width:100%;
	border-collapse:separate;
	border-spacing:0;
}
address{font-style:normal;}
ul,ol{list-style:none;}
iframe{display:block;}
i{
	font-weight:normal !important;
	display: inline-block;
	vertical-align: middle;
}

a {
	color: inherit;
	text-decoration: none;
	outline: 0;
	transition: color 0.8s, background-color 0.8s;
}
a:hover {
	transition: color 0.4s, background-color 0.4s;
}

#wrapper{overflow:hidden;}
#pagebody{max-height:100%;}

.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}
.clearfix {
  min-height: 1px;
}
* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}
/*<group=style>*/
.fw_bold{font-weight:bold;}
.fw_normal{font-weight:normal;}	
/*<group=text_align>*/
.txt_al_l{text-align:left;}
.txt_al_r{text-align:right;}
.txt_al_c{text-align:center;}
.sp_txt_l{text-align:center;}
/*<group=float>*/
.flt_l{float:left;}
.flt_r{float:right;}

.blocklink,
.blocklink_out,
.blocklink_anc {
	cursor: pointer;
}
.img_max {
	width: 100% !important;
	max-width: initial !important;
}

.ank_adjust {
    /*padding-top: 150px;
    margin-top: -150px;*/
}

/* 電話番号 */
@media(min-width: 768px) {
	a[href^="tel:"] {pointer-events: none;}	/* PC時はaタグ無効 */
	.tel_border a {text-decoration: underline;}	/* テキスト電話番号は下線をつける */
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
body {
	font-size: 15px;
	letter-spacing: .1em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
/* スマホのときはビューポートを基準にサイズ調節する */
/* スマホ時：emまたは%で指定する */
/* スマホ以外でビューポート基準にするときは、その都度「vw」で指定する */
body {
	font-size: 3.5vw;
	letter-spacing: .05em;
	line-height: 1.8em;
}
img {
	width: 100% !important;
	max-width: initial !important;
}
/*<group=text_align>*/
.sp_txt_l{text-align:left;}	
}



/*共通
---------------------------------------------------------*/
.max_1500 {
	max-width: 1500px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
.max_width {
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
}
.w1500 {
	max-width: 1500px;
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
.w1400 {
	max-width: 1400px;
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
.w1360 {
	max-width: 1360px;
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
.w1300 {
	max-width: 1300px;
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
.w1220 {
	max-width: 1220px;
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
.w1200 {
	max-width: 1200px;
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
.w1100 {
	max-width: 1100px;
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
.w1075 {
	max-width: 1075px;
	width: var(--content_width);
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}

/*隙間*/
.com_btm_170 {margin-bottom: var(--gap_170);}
.com_btm_150 {margin-bottom: var(--gap_150);}
.com_btm_120 {margin-bottom: var(--gap_120);}
.com_btm_100 {margin-bottom: var(--gap_100);}
.com_btm_90 {margin-bottom: var(--gap_90);}
.com_btm_80 {margin-bottom: var(--gap_80);}
.com_btm_70 {margin-bottom: var(--gap_70);}
.com_btm_60 {margin-bottom: var(--gap_60);}
.com_btm_50 {margin-bottom: var(--gap_50);}
.com_btm_40 {margin-bottom: var(--gap_40);}

.com_p_top_170 {padding-top: var(--gap_170);}
.com_p_top_150 {padding-top: var(--gap_150);}
.com_p_top_120 {padding-top: var(--gap_120);}
.com_p_top_100 {padding-top: var(--gap_100);}
.com_p_top_90 {padding-top: var(--gap_90);}
.com_p_top_80 {padding-top: var(--gap_80);}
.com_p_top_90 {padding-top: var(--gap_90);}
.com_p_top_80 {padding-top: var(--gap_80);}
.com_p_top_70 {padding-top: var(--gap_70);}
.com_p_top_60 {padding-top: var(--gap_60);}
.com_p_top_50 {padding-top: var(--gap_50);}
.com_p_top_40 {padding-top: var(--gap_40);}

.com_p_btm_170 {padding-bottom: var(--gap_170);}
.com_p_btm_150 {padding-bottom: var(--gap_150);}
.com_p_btm_120 {padding-bottom: var(--gap_120);}
.com_p_btm_100 {padding-bottom: var(--gap_100);}
.com_p_btm_90 {padding-bottom: var(--gap_90);}
.com_p_btm_80 {padding-bottom: var(--gap_80);}
.com_p_btm_70 {padding-bottom: var(--gap_70);}
.com_p_btm_60 {padding-bottom: var(--gap_60);}
.com_p_btm_50 {padding-bottom: var(--gap_50);}
.com_p_btm_40 {padding-bottom: var(--gap_40);}

/*色*/
.com_tel {background-color: var(--color_brown);}
.com_info {background-color: var(--color_turquoise);}
.com_rec {background-color: var(--color_pink);}
.com_blog {background-color: var(--color_violet);}
.com_txt_link {
	text-decoration: underline;
}
.com_txt_link:hover {
	text-decoration: none;
	color: var(--color_turquoise);
}

/*フォント*/
.ft_got {font-family: var(--ff_got);}
.ft_min {
	font: var(--font_min);
	letter-spacing: .12em;
}
.ft_eng1 {
	font: var(--font_eng1);
	letter-spacing: .1em;
}

/*フォントサイズ*/
.fs14 {
	font-size: 90%;
	letter-spacing: .05em;
	line-height: 1.8em;
}
.fs15 {
	font-size: 95%;
	letter-spacing: .1em;
	line-height: 1.8em;
}
.fs45 {
	font-size: min(280%,3.7vw);
}
.fs23 {
	font-size: min(145%,2.0vw);
}
.tit_en80 {
	font-size: min(500%,6.8vw);
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
/*フォント*/
.ft_min {
	letter-spacing: .06em;
}
.ft_eng1 {
	letter-spacing: .05em;
}
/*フォントサイズ*/
.fs14 {
	font-size: 90%;
	letter-spacing: normal;
	line-height: 1.6em;
}
.fs15 {
	font-size: 95%;
	letter-spacing: .05em;
	line-height: 1.8em;
}
.fs45 {
	font-size: 4.0vw;
}
.fs23 {
	font-size: 2.4vw;
}
.tit_en80 {
	font-size: 6.8vw;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
}



/*header
---------------------------------------------------------*/
header {
	width: 100%;
	box-sizing: border-box;
	position: relative;
	padding: 30px 5%;
}
header .h_logo {
	width: 40%;
}
/* 共通ボタン */
header .com_menu {
	position: absolute;
	z-index: 999;
	right: 0;
	top: 0;
	width: 50%;
	max-width: 540px;
	background: #fff;
	display: flex;
}
header .com_menu li {
	width: 16.667%;
}
header .com_menu li.com_tel {
	width: 50%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
header {
	padding: 4% 2%;
}
header .h_logo {
	width: 41%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
header {
	padding: 3% 5% 4%;
}
header .h_logo {
	width: 68%;
	margin: 0 auto;
}
/* 共通ボタン */
header .com_menu{
	position: fixed;
	background-color: #fff;
	top: auto;
	bottom: 0;
	right: 0;
	width: 100%;
	max-width: 100%;max-width: none;
}
header .com_menu li {
	text-align: center;
}	
header .com_menu li,
header .com_menu li.com_tel {
	width: 25%;
}	
header .com_menu img {
	margin: auto;
}
}



/* PC
------------------------------------------*/
@media only screen and (min-width: 960px)  {
.tb_only{display:none !important;}
.sp_only{display:none !important;}
.sp_tb{display:none !important;}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.pc_only{display:none !important;}
.sp_only{display:none !important;}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.pc_only{display:none !important;}
.tb_only{display:none !important;}
.tb_pc{display:none !important;}
}