@charset "utf-8";
body, table, input, textarea, select, option {
	font-family: 'Noto Sans JP', sans-serif;
}

html {
	visibility: hidden;
}

html.wf-active,
html.loading-delay {
	visibility: visible;
}


.tk-brandon-grotesque {
	font-family:"brandon-grotesque",sans-serif;
	font-weight: 500;
	font-style: normal;
}

.tk-dnp-shuei-mgothic-std {
	font-family:"dnp-shuei-mgothic-std",sans-serif;
	font-weight: 400;
	font-style: normal;
}


.fax {
	cursor: default;
	pointer-events: none;
}
a:link {
    color: #484848;
    text-decoration: none;
}
a:visited {
    color: #484848;
    text-decoration: none;
}
a:hover,
a:hover img,
input[type="submit"]:hover {
    color: #484848;
}
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	min-width: 1280px;
	color: #484848;
	font-size: 16px;
	line-height: 1.5;
	font-weight: 400;
	letter-spacing: 0.05em;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #FFF;
}
.fixed {
	position: fixed;
	width: 100%;
	height: 100%;
}
#container {
	overflow: hidden;
	text-align: left;
	position: relative;
}
#main {
	margin-bottom: 111px;
	display: block;
}
a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}

.art_link_btn{
	border: 2px solid #368c9b;
	text-align: center;
	font-size: 18px;
    width: 300px;
    height: 50px;
    padding: 13px 0 0;
    margin-bottom: 40px;
}

@media only screen and (min-width: 769px) {
	.sp {
		display: none !important;
	}
	.fixed {
		overflow-y: scroll;
	}
}

/* ------------------------------------------------------------ mobile ------------------------------------------------------------ */
@media only screen and (max-width: 768px) {
	body {
		min-width: inherit;
		font-size: 14px;
	}
	a:hover,
	a:hover img {
		opacity: 1 !important;
	}
	.pc {
		display: none !important;
	}
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}
	#main {
		margin-bottom: 74px;
	}
	
	.art_link_btn{
		font-size: 15px;
	    width: 100%;
	    height: 50px;
	    padding: 15px 0 0;
	    margin-bottom: 30px;
	}
}

/*------------------------------------------------------------
	header
------------------------------------------------------------*/
#gHeader {
	min-width: 1280px;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
}
#gHeader .hInner {
	padding: 0 20px;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
#gHeader .hInner h1 {
	margin-left: 55px;
	width: 408px;
}
#gHeader .hInner h1 img {
	vertical-align: top;
}
#gHeader .hInner .rBox {
	flex: 1;
	padding: 15px 0 0 20px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
.menuBox {
	flex: 1;
}
#gNavi {
	max-width: 729px;
	padding: 18px 10px;
	box-sizing: border-box;
	width: 67.7%;
	display: flex;
	justify-content: center;
	background-color: #fff;
	border-radius: 50px;
}
#gNavi li {
	margin: 0 16px;
	font-size: 14px;
}
#gNavi li a {
	font-weight: 400;
}
#gHeader .hInner .rBox a:hover {
	opacity: 0.7;
}
#gHeader .link {
	margin-left: 27px;
	width: 206px;
}
#gHeader .link a {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 52px;
	color: #fff;
	font-weight: 500;
	text-align: center;
	padding: 5px;
	border-radius: 25px;
	box-sizing: border-box;
	background-image: -webkit-linear-gradient( 0deg, rgb(54,140,155) 0%, rgb(67,160,176) 49%, rgb(80,180,197) 100%);
}
#gHeader .link span {
	font-weight: 500;
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	min-height: 38px;
	padding: 0 0 2px 34px;
	box-sizing: border-box;
	background: url(../images/common/email.png) no-repeat left center;
	background-size: 26px auto;
}

.has-child{ position: relative; }
.has-child:after{ position: absolute; content: ""; right: -8px; top: 25%; width: 6px; height: 6px; border-bottom: 1px solid #484848; border-right: 1px solid #484848; transform: rotate(45deg); }

.drop-menu{ visibility: hidden; opacity: 0; transition: all .3s; position: absolute; bottom: -140px; width: 145px; padding: 20px 15px; border-radius: 10px; background: #fff; filter: drop-shadow(0px 0px 16px rgba(0,0,0,0.2)); }
.drop-menu li{ width: 100%; margin: 0 auto 10px!important; }
.drop-menu li:last-of-type{ margin-bottom: 0!important; }

#gNavi li.has-child:hover > .drop-menu,
#gNavi li.has-child:active > .drop-menu{
  visibility: visible;
  opacity: 1;
  transition: all .3s;
}


@media only screen and (min-width: 769px) {
	#gHeader .hInner h1 a {
		display: flex;
		align-items: center;
		justify-content: center;
		min-height: 80px;
		border-radius: 0 0 25px 25px;
		background-color: #368C9B;
	}
	.menuBox {
		display: block !important;
	}
}

/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	#gHeader {
		min-width: inherit;
	}
	#gHeader .hInner h1 {
		position: relative;
		z-index: 1000;
		margin-left: -10px;
	}
	#gHeader .hInner {
		position: relative;
	}
	.menu {
		top: 10px;
		right: 11px;
		position: absolute;
		z-index: 1000;
	}
	.menu a {
		display: block;
	}
	.menu.on a {
		display: block;
		border-radius: 100%;
		background: url(../images/common/close.png) no-repeat center;
		background-size: 45px auto;
	}
	.menu.on a img {
		visibility: hidden;
	}
	.menuBox {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		overflow-y: auto;
		z-index: 800;
		display: none;
		background-color: #fff;
	}
	#gHeader .hInner .rBox {
		display: block;
		padding: 80px 20px 40px;
	}
	#gNavi {
		padding: 0 0 30px;
		max-width: inherit;
		width: auto;
		display: block;
		background-color: transparent;
		border-radius: 0;
		border-top: 1px solid #ccc;
	}
	#gNavi li {
		margin: 0;
		display: block;
	}
	#gNavi li a {
		display: block;
		padding: 13px 0;
		font-size: 14px;
		line-height: 1.75;
		border-bottom: 1px solid #ccc;
	}
	#gHeader .link {
		margin: 0 auto;
	}
	
	.has-child:after{ display: none; }
	.drop-menu{ visibility: visible; opacity: 1; position: initial; width: 100%; padding: 0; border-radius: none; background: none; filter: none; }
	
}


/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter {
	padding-bottom: 110px;
}
#gFooter .fInner {
	padding: 85px 0 71px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#gFooter .fInner .lBox {
	width: 350px;
	margin-right: 40px;
}
#gFooter .fInner .lBox p {
	font-size: 14px;
	color: #368c9b;
	font-weight: 400;
	line-height: 1.75;
	margin-bottom: 30px;
}
#gFooter .fInner .lBox p:last-child {
	margin-bottom: 0;
}
#gFooter .fInner .rBox {
	order: 2;
	flex: 1;
	margin-top: -4px;
}
#gFooter .fInner .fLogo {
	margin-bottom: 37px;
}
#gFooter .fInner .lBox .tel .txtSpan {
	white-space: nowrap;
	display: block;
	margin-bottom: 7px;
}
#gFooter .fInner .lBox .tel a {
	font-weight: 700;
	font-size: 31.11px;
	letter-spacing: 0.05em;
	color: #368c9b;
	display: inline-block;
	padding-left: 30px;
	background: url(../images/common/icon02.png) no-repeat left center;
	background-size: 25px auto;
}
#gFooter .naviUl {
	display: flex;
	flex-wrap: wrap;
}
#gFooter .naviUl > li {
	width: 180px;
	padding-right: 10px;
}
#gFooter .naviUl > .li03 {
	width: 215px;
}
#gFooter .naviUl > .li04 {
	width: 135px;
}
#gFooter .naviUl p a {
	font-size: 16px;
	color: #368c9b;
	letter-spacing: 0.05em;
	font-weight: 500;
}
#gFooter .naviUl .jsBox {
	margin: 15px 0 0 6px;
	padding: 5px 0 7px 13px;
	border-left: 1px solid #CDE2E6;
}
#gFooter .naviUl .subUl {
	margin-bottom: 20px;
}
#gFooter .naviUl .subUl:last-child {
	margin-bottom: 0;
}
#gFooter .naviUl .subUl li {
	font-size: 14px;
	font-weight: 400;
	margin-bottom: 22px;
}
#gFooter .naviUl .subUl li a {
	font-weight: 400;
}
#gFooter .naviUl .subUl li:last-child {
	margin-bottom: 0;
}
#gFooter .naviUl a:hover {
	opacity: 0.7;
}
#gFooter .naviUl .subUl02 li {
	font-size: 12px;
	font-weight: 400;
	margin-bottom: 24px;
	display: flex;
}
#gFooter .naviUl .subUl02 li .ico {
	margin-right: 2px;
}
#gFooter .naviUl .subUl02 li:last-child {
	margin-bottom: 0;
}
address {
	text-align: center;
	font-style: normal;
	font-size: 14px;
	color: #c7c7c7;
	letter-spacing: 0.15em;
	font-weight: 300;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	#gFooter {
		padding-bottom: 32px;
	}
	#gFooter .fInner {
		padding: 11px 0 70px;
		display: block;
	}
	#gFooter .fInner .rBox {
		margin: 0 0 44px;
	}
	#gFooter .naviUl {
		display: block;
	}
	#gFooter .naviUl > li {
		padding: 0;
		width: auto !important;
		margin: 0;
		border-bottom: 1px solid #EAEAEA;
	}
	#gFooter .naviUl p {
		position: relative;
	}
	#gFooter .naviUl p a {
		padding: 24px 40px 26px 0;
		display: block;
/* 		background: url(../images/common/icon03.png) no-repeat right center; */
		position: relative;
		background-size: 21px auto;
	}
	#gFooter .naviUl .li04 p a {
		background: none;
	}
	#gFooter .naviUl .jsBox {
		display: none;
		margin: 3px 0 41px 4px;
		border: none;
	}
/*
	#gFooter .naviUl li:not(.li04) .jsBox {
		display: none !important;
	}
*/
	#gFooter .naviUl .ico {
		cursor: pointer;
		width: 40px;
		height: 40px;
		display: block;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		right: 0;
		z-index: 1;
		pointer-events: all;
		background: url(../images/common/icon03.png) no-repeat right center;
		background-size: 21px auto;
	}
	#gFooter .naviUl p.on .ico {
		background-image: url(../images/common/icon04.png);
		background-size: 21px auto;
	}
	#gFooter .fInner .lBox {
		width: auto;
		margin: 0;
	}
	#gFooter .fInner .fLogo {
		text-align: center;
		margin-bottom: 24px;
	}
	#gFooter .fInner .fLogo img {
		width: 144px;
	}
	#gFooter .fInner .lBox p {
		margin-bottom: 25px;
		text-align: center;
		font-size: 12px;
		line-height: 2.041;
	}
	#gFooter .fInner .lBox .tel {
		font-size: 14px;
	}
	#gFooter .fInner .lBox .tel > span {
		display: inline-block;
		text-align: left;
	}
	#gFooter .fInner .lBox .tel .txtSpan {
		margin-bottom: 11px;
	}
	address {
		font-size: 12px;
		letter-spacing: 0;
	}
}

/*------------------------------------------------------------
mainImg
------------------------------------------------------------*/
.mainImg {
	margin-bottom: 32px;
	height: 550px;
	display: flex;
	align-items: center;
	color: #fff;
	background: url(../images/company/main_img.jpg) no-repeat center;
	background-size: cover;
}
.mainImg .content {
	width: 100%;
}
.mainImg h2 {
	margin-bottom: -40px;
	font-size: 30px;
	letter-spacing: 0.05em;
	font-weight: 700;
}
.mainImg h2 span {
	font-style: normal;
	margin-bottom: 35px;
	display: block;
	font-size: 90px;
	line-height: 1;
	letter-spacing: 0.05em;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	.mainImg {
		margin-bottom: 20px;
		height: 261px;
	}
	.mainImg h2 {
		margin-bottom: -32px;
		font-size: 16px;
	}
	.mainImg h2 span {
		margin-bottom: 15px;
		font-size: 40px;
	}
}

/*------------------------------------------------------------
content
------------------------------------------------------------*/
.content {
	max-width: 1140px;
	margin: 0 auto;
	padding: 0 20px;
	position: relative;
	z-index: 1;
}

/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	.content {
		padding: 0 19px;
	}
}

/*------------------------------------------------------------
pagePath
------------------------------------------------------------*/
#pagePath {
	margin-bottom: 109px;
}
#pagePath li {
	margin-right: 10px;
	display: inline;
	font-size: 13px;
	color: #858585;
}
#pagePath li a {
	margin-right: 12px;
	color: #858585;
}
#pagePath li a:hover {
	opacity: 0.7;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	#pagePath {
		margin-bottom: 68px;
	}
	#pagePath li {
		font-size: 11px;
	}
}

/*------------------------------------------------------------
headLine01
------------------------------------------------------------*/
.headLine01 {
	margin-bottom: 88px;
	text-align: center;
	font-weight: 700;
	font-size: 16px;
	color: #368c9b;
	font-family:"dnp-shuei-mgothic-std",sans-serif;
}
.headLine01 .en {
	display: block;
	font-size: 60px;
	font-weight: 300;
	margin-bottom: 14px;
	margin-left: -4px;
	letter-spacing: 0.05em;
}
.headLine01.left {
	text-align: left;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	.headLine01 {
		margin-bottom: 45px;
		font-size: 14px;
	}
	.headLine01 .en {
		margin-bottom: 8px;
		font-size: 40px;
	}
}

/*------------------------------------------------------------
comLink
------------------------------------------------------------*/
.comLink {
	position: relative;
	z-index: 1;
	width: 270px;
	margin: 0 auto;
}
.comLink a {
	font-size: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	min-height: 57px;
	border-radius: 28px;
	color: #fff;
	font-weight: 500;
	position: relative;
	padding: 5px 20px;
	overflow: hidden;
}
.comLink a:hover {
	opacity: 0.7;
}
.comLink a:after {
	width: 100%;  
	height: 100%;
	background-image: -webkit-linear-gradient( 0deg, rgb(54,140,155) 0%, rgb(67,160,176) 49%, rgb(80,180,197) 100%);
	position: absolute;  
	top: 0;
	left: 0;  
	z-index: -1;
	content: ""; 
}
.comLink .subSpan {
	padding: 0 37px 2px 10px;
	font-weight: 500;
	display: inline-flex;
	align-items: center;
	min-height: 27px;
	position: relative;
	z-index: 1;
	background: url(../images/common/icon01.png) no-repeat right top 2px;
	background-size: 25px auto;
}
.comLink.wid .subSpan {
	min-width: 195px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding-left: 30px;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {

}

/*------------------------------------------------------------
contactBox
------------------------------------------------------------*/
.contactBox {
	padding: 87px 0 107px;
	color: #fff;
	background-image: -webkit-linear-gradient( 0deg, rgb(54,140,155) 0%, rgb(67,160,176) 49%, rgb(80,180,197) 100%);
}
.contactBox .headLine01 {
	margin-bottom: 64px;
	color: #fff;
}
.contactBox p {
	margin-bottom: 70px;
	text-align: center;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
.contactBox .sub {
	display: flex;
	align-items: center;
	justify-content: center;
}
.contactBox .sub .tel {
	margin: 0 85px 0 0;
	padding-right: 52px;
	position: relative;
}
.contactBox .sub .tel:after {
	width: 1px;  
	background-color: #fff;
	position: absolute;  
	top: 4px;
	right: 0; 
	bottom: 4px; 
	content: ""; 
}
.contactBox .sub .tel span {
	white-space: nowrap;
	letter-spacing: 0.05em;
	padding-left: 82px;
	min-height: 70px;
	text-align: left;
	display: inline-block;
	align-items: center;
	font-size: 14px;
	font-weight: 400;
	background: url(../images/common/tel.png) no-repeat left center;
	background-size: 61px auto;
}
.contactBox .sub .tel a {
	margin-bottom: 5px;
	display: inline-block;
	color: #fff;
	font-size: 42.72px;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.contactBox .comLink02 {
	margin-top: -1px;
}
.comLink02 {
	width: 319px;
}
.comLink02 a {
	padding: 5px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #368c9b;
	min-height: 61px;
	background-color: #fff;
	border-radius: 50px;
}
.comLink02 a:hover {
	opacity: 0.7;
}
.comLink02 .subSpan {
	font-weight: 500;
	display: inline-flex;
	align-items: center;
	padding: 4px 0 7px 35px;
	background: url(../images/common/email02.png) no-repeat left center;
	background-size: 26px auto;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	.contactBox {
		padding: 56px 0 75px;
		background: linear-gradient(90deg,#368c9b 0%, #368c9b 0.1%, #43a0b0 49.05%, #50b4c5 100%);
	}
	.contactBox .headLine01 .en {
		margin-bottom: 8px;
	}
	.contactBox .headLine01 {
		margin-bottom: 41px;
	}
	.contactBox p {
		margin-bottom: 31px;
		font-size: 18px;
		line-height: 1.66;
	}
	.contactBox .sub {
		display: block;
	}
	.contactBox .sub .tel {
		border: none;
		padding: 0;
		margin: 0 0 26px;
	}
	.contactBox .sub .tel::after {
		display: none;
	}
	.contactBox .sub .tel span {
		padding: 0 20px 5px 70px;
		font-size: 12px;
		min-height: inherit;
		background-size: 49px auto;
	}
	.contactBox .sub .tel a {
		margin-bottom: 6px;
		font-size: 33px;
	}
	.comLink02 {
		margin: 0 auto;
		width: auto;
		max-width: 319px;
	}
	.comLink02 a {
		min-height: 61px;
		font-size: 16px;
	}
}

/*------------------------------------------------------------
newsList
------------------------------------------------------------*/
#main .newsList {
	margin-bottom: 50px;
	border-top: 1px solid #D2D2D2;
}
#main .newsList li {
	border-bottom: 1px solid #D2D2D2;
}
#main .newsList dl a{
	padding: 42px 60px 33px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .newsList dt {
	width: 350px;
	padding-right: 10px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .newsList dt .date {
	width: 145px;
	word-break: break-all;
	font-weight: 400;
	padding: 2px 10px 0 0;
}
#main .newsList dt .rSpan {
	margin-top: -4px;
	flex: 1;
}
#main .newsList dt .rSpan span {
	margin: 0 5px 5px 0;
	min-width: 157px;
	text-align: center;
	display: inline-block;
	padding: 8px 5px;
	font-size: 14px;
	color: #368c9b;
	font-weight: 400;
	box-sizing: border-box;
	background-color: #EBF3F5;
}
#main .newsList dd {
	padding-top: 2px;
	flex: 1;
}
#main .newsList dd a {
	font-weight: 300;
}
#main .newsList dd a:hover {
	opacity: 0.7;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	#main .newsList {
		margin-bottom: 45px;
	}
	#main .newsList li {
		
	}
	#main .newsList dl a{
		padding: 25px 0;
		display: block;
	}
	#main .newsList dt {
		margin-bottom: 4px;
		width: auto !important;
		padding-right: 0;
		flex-wrap: nowrap;
	}
	#main .newsList dt .date {
		width: 100%;
		padding: 2px 5px 0 0; 
		font-size: 12px;
	}
	#main .newsList dt .rSpan span {
		margin: 0 5px 2px 0;
		min-width: 108px;
		font-size: 11px;
		padding: 6px 5px 8px;
	}
	#main .newsList dd {
		padding-top: 0;
		font-size: 15px;
		line-height: 1.866;
	}
}

/*------------------------------------------------------------
magazineList
------------------------------------------------------------*/
#main .magazineList {
	margin-bottom: 56px;
	display: flex;
	flex-wrap: wrap;
}
#main .magazineList li {
	width: 352px;
	margin: 0 70px 30px 0;
}
#main .magazineList li:nth-child(3n) {
	margin-right: 0;
}
#main .magazineList a {
	display: block;
}
#main .magazineList a:hover {
	opacity: 0.7;
}
#main .magazineList .photo {
	height: 228px;
	position: relative;
}
#main .magazineList .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .magazineList dl {
	margin-bottom: 14px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .magazineList dt {
	width: 50%;
	font-size: 14px;
	color: #fff;
	text-align: center;
	padding: 8px 5px;
	letter-spacing: 0.05em;
	font-weight: 400;
	background-color: #368C9B;
}
#main .magazineList dd {
	width: 50%;
	text-align: center;
	font-size: 14px;
	color: #368c9b;
	padding: 8px 5px;
	font-weight: 400;
	letter-spacing: 0.05em;
	background-color: #fff;
}
#main .magazineList p {
	padding-top: 2px;
	font-size: 14px;
	font-weight: 300;
	line-height: 2.14;
	letter-spacing: 0.02em;
}
#main .magazineList .ttl {
	padding: 0;
	line-height: 1.5;
	font-size: 20px;
	color: #368c9b;
	font-weight: 700;
	letter-spacing: 0.05em;
}
#main .magazineList .ttl02 {
	letter-spacing: -0.04em;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	#main .magazineList {
		display: block;
		margin-bottom: 55px;
	}
	#main .magazineList li {
		width: auto !important;
		margin: 0 0 36px;
	}
	#main .magazineList li:last-child {
		margin-bottom: 0;
	}
	#main .magazineList .photo {
		height: 58.015vw;
	}
	#main .magazineList dl {
		margin-bottom: 12px;
	}
	#main .magazineList .liStyle a {
		display: block;
	}
	#main .magazineList .liStyle p {
		font-size: 20px;
	}
	#main .magazineList li:not(.liStyle) a {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	#main .magazineList li:not(.liStyle) a .photo {
		width: 50%;
		height: 29.2vw;
	}
	#main .magazineList li:not(.liStyle) a .textBox {
		flex: 1;
	}
	#main .magazineList li:not(.liStyle) dl {
		margin-bottom: 8px;
		display: block;
	}
	#main .magazineList li:not(.liStyle) dt {
		width: 100%;
	}
	#main .magazineList li:not(.liStyle) dd {
		width: 100%;
	}
	#main .magazineList .ttl {
		line-height: 1.5625;
	}
	#main .magazineList li:not(.liStyle) .ttl {
		font-size: 16px;
		padding: 0 10px 0 20px;
	}
	#main .magazineList p {
		padding: 0 0 0 20px;
	}
	
}

/*------------------------------------------------------------
common
------------------------------------------------------------*/
.headLine02 {
	margin-bottom: 35px;
	text-align: center;
	font-size: 32px;
	color: #368c9b;
	letter-spacing: 0.05em;
	line-height: 1.75;
	font-weight: 300;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	.headLine02 {
		margin-bottom: 17px;
		text-align: left;
		font-size: 30px;
		line-height: 1.66;
	}
}

/*------------------------------------------------------------
common
------------------------------------------------------------*/
.headLine03 {
	line-height: 1.5;
	margin-bottom: 27px;
	font-size: 28px;
	color: #368c9b;
	font-weight: 400;
	letter-spacing: 0.05em;
}
.headLine03 .en {
	margin-bottom: 17px;
	display: block;
	letter-spacing: 0.05em;
	font-weight: 300;
	font-size: 20px;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	.headLine03 {
		margin-bottom: 25px;
		font-size: 24px;
	}
	.headLine03 .en {
		font-size: 18px;
		margin-bottom: 11px;
	}
}

/*------------------------------------------------------------
common
------------------------------------------------------------*/
.pageNavi {
	margin: 0 34px 148px 0;
	clear: both;
	text-align: center;
}
.pageNavi li {
	margin: 0 6px;
	display: inline;
	line-height: 1.2;
}
.pageNavi li span,
.pageNavi li a {
	min-width: 56px;
	padding: 18px 10px 20px;
	display: inline-block;
	color: #010101;
	letter-spacing: 0.12em;
	text-align: center;
	background-color: #fff;
	border: 1px solid #C6C6C6;
}
.pageNavi .current {
	color: #368c9b;
	border-color: transparent;
}
@media only screen and (min-width: 769px) {
	.pageNavi li a:hover {
		color: #368c9b;
	}
}

/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	.pageNavi {
		margin: 0 0 100px;
	}
	.pageNavi li span, .pageNavi li a {
		min-width: 40px;
		padding-top: 12px;
		padding-bottom: 12px;
	}
}

/*------------------------------------------------------------
comList
------------------------------------------------------------*/
#main .companyInner {
	margin: -49px 50px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .companyInner:last-child {
	margin-bottom: 0;
}
#main .companyInner .img {
	margin-right: 25px;
}
#main .companyInner .sub {
	padding-top: 70px;
	flex: 1;
}
#main .companyInner h3 {
	font-weight: 300;
	margin-bottom: 9px;
	font-size: 32px;
	color: #368c9b;
	letter-spacing: 0.05em;
}
#main .companyInner p {
	margin-right: -10px;
	font-weight: 300;
	line-height: 1.75;
}
#main .comList {
	margin-bottom: 195px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .comList a {
	display: block;
}
#main .comList a:hover {
	opacity: 0.7;
}
#main .comList li {
	width: 510px;
}
#main .comList .companyInner {
	margin: -37px 0px 0 20px;
}
#main .comList .companyInner .img {
	margin: 1px 29px 0 0;
}
#main .comList .companyInner .sub {
	padding: 67px 0 0 0;
}
#main .comBtmBox {
	margin-bottom: 111px;
	padding-bottom: 86px;
	position: relative;
}
#main .comBtmBox .comList {
	margin-bottom: 0;
}
#main .comBtmBox:after {
	width: 100%;  
	background-color: #EBF3F5;
	position: absolute;  
	top: 180px;
	right: 0; 
	bottom: 0; 
	content: ""; 
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	#main .companyInner {
		margin: 20px 0 0 10px !important;
	}
	#main .companyInner .img {
		margin: 0 10px 0 0 !important;
		width: 40px;
	}
	#main .companyInner h3 {
		font-size: 22px;
	}
	#main .companyInner .sub {
		padding-top: 5px !important;
	}
	#main .comList {
		margin-bottom: 80px;
		display: block;
	}
	#main .comList li {
		width: auto;
		margin-bottom: 40px;
	}
	#main .comList li:last-child {
		margin-bottom: 0;
	}
	#main .comList .photo img {
		width: 100%;
	}
	#main .comBtmBox::after {
		width: 102px;
		top: -40px;
		bottom: 0;
		right: auto;
		left: 0;
	}
	#main .comBtmBox {
		margin-bottom: 80px;
		padding-bottom: 70px;
	}
	
.drop-menu li{  margin-bottom: 0!important; }

}

/*------------------------------------------------------------
facilityDl
------------------------------------------------------------*/
#main .facilityDl {
	margin-top: -3px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	border-top: 1px solid #CECECE;
}
#main .facilityDl dt {
	width: 165px;
	color: #368c9b;
	letter-spacing: 0.05em;
	font-weight: 400;
	text-align: center;
	line-height: 1.75;
	padding: 32px 5px 31px 5px;
	border-bottom: 1px solid #CECECE;
}
#main .facilityDl dd {
	font-weight: 300;
	letter-spacing: 0.05em;
	padding: 32px 20px 31px 90px;
	width: calc(100% - 165px);
	line-height: 1.75;
	border-bottom: 1px solid #CECECE;
}
#main .facilityDl dd a {
	font-weight: 300;
}
/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	#main .facilityDl {
		margin-top: 0;
	}
	#main .facilityDl dt {
		padding: 26px 5px 26px 0;
		width: 118px;
		text-align: left;
		line-height: 1.71;
	}
	#main .facilityDl dd {
		padding: 26px 5px 26px 0;
		width: calc(100% - 118px);
		line-height: 1.71;
	}
}


@media only screen and (max-width: 375px) {
	.contactBox .sub .tel a {
		font-size: 30px;
	}
	.headLine01 .en {
		font-size: 33px;
	}
	.headLine02 {
		font-size: 23px;
	}
	.headLine03 {
		font-size: 21px;
	}
}


@media all and (min-width: 769px) and (max-width: 1400px) {
	#gHeader .hInner h1 {
		width: 18%;
		margin-left: min(2vw,30px);
	}
	#gNavi {
		width: 73%;
		padding: min(1.6vw,18px) min(0.5vw,10px);
	}
	#gNavi li {
		/* font-size: min(1.2vw,14px);
		margin: 0 min(0.8vw,16px); */
		font-size:  14px;
		margin: 0 min(0.8vw,16px);
	}
	#gHeader .link {
		margin-left: min(1.2vw,15px);
		width: min(17vw,180px);
	}
	#gHeader .link a {
		min-height: min(6vw,45px);
		font-size: min(1.5vw,16px);
	}
	#gHeader .link span {
		min-height: min(4vw,38px);
	}
	#gHeader .hInner .rBox {
		padding: 1vw 0 0 1vw;
	}
}

@media all and (min-width: 1401px) and (max-width: 1580px) {
	#gNavi {
		width: 73%;
	}
	#gNavi li {
		margin: 0 min(1.2vw,14px);
		font-size: min(1.0vw,16px);
	}
	#gHeader .hInner h1 {
		width: 25%;
	}
	
}


@media only screen and (max-width: 375px) {
	address {
		font-size: 11px;
	}
	#main .magazineList li:not(.liStyle) a .photo {
		width: 42%;
	}
}