@charset "UTF-8";

main {
    padding: 0 0 20%;
}
/*
===================================================================

CONTENTS

	1: IMPORT
		1-1: RESET
		1-2: NAV
	2: BODY AND BASE SETTING
		2-1: HTML + BODY
		2-2: GENERAL SETTING
		2-3: FONT SIZE & STYLE
		2-4: CONTAINER
		2-5: SLIDER - bxslider
		2-6: thumbnail_box / thumbnail_list_box
		2-7: BG-COLOR
		2-8: ScrollTrigger
	3: STYLE
		3-1: styles
		
===================================================================
*/


/*
====================================================
1: IMPORT
====================================================
*/
@import url(sanitize.css);
/*@import url(nav.css);*/
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho&display=swap');



#news-page #container,
#news-page #container .flex {
height:100%;
}






/* --------------------------------------------------------------------------------------------
2: HTML + BODY
-------------------------------------------------------------------------------------------- */
html { 
	font-size: 62.5%; 
    height:100%;
}
body { 
	line-height: 1.75;
	font-size: 1.6rem;
	line-height: 1.8;
	background:#000 ;
	color: #333333;
	letter-spacing: .075em;
  height:100%;
 }

img{
	width: 100%;
  height:auto;
}

ul {margin:0;padding: 0;}
li {list-style:none}

h1,h2,h3,h4,p{
	margin: 0 0 1rem;
	font-weight: normal;
}


@media screen and (max-width: 767px) {
	.pc{
		display: none;
	}
}
@media screen and (min-width: 768px) {
	.sp{
		display: none;
	}
}

a{
	text-decoration: none;
	transition: 0.3s linear;
	color: #333;
}
a:hover{
	opacity:0.8;
}




body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
}









/*========= ローディング画面のためのCSS ===============*/





/*========= 画面遷移のためのCSS ===============*/











/* --------------------------------------------------------------------------------------------
3: CONTAINER
-------------------------------------------------------------------------------------------- */








@media screen and (max-width:767px){




}



.link-svg{
	color: #fff;
	width: 18px;
	filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(129deg) brightness(103%) contrast(100%);
	margin: 0 0 5px 5px;
}

/* --------------------------------------------------------------------------------------------
	footer
-------------------------------------------------------------------------------------------- */


footer{
	text-align:center;
	padding: 4% 0 15px;
}







@media screen and (max-width:767px){

	footer{
		text-align:center;
		padding: 10% 0 15px;
	}

}








.container{
	max-width: 96rem;
	margin:10% auto 10%;
	padding: 0 6%;
	text-align:left;
}


.ttl01{
	  font-family: "Noto Sans JP", sans-serif;
	  font-weight: 500;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    letter-spacing: .09em;
    font-size: 2.4rem;
    line-height: 1.637931034;
    text-align:left;
}



.ttl-block{
	background:#324C5E;
	display:inline;
	color: #fff;
	padding: 5px 10px 7px 10px;
}



.map {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    /* 16:9のアスペクト比 */
    height: 0;
}

.map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}








.btn{
    right: 0;
    position: absolute;
    margin-right: 10%;
  }


.btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	width: 180px;
	height: 40px;
	color: #333;
	font-size: 1.4rem;
	font-weight: 700;
	text-decoration: none;
	transition: 0.3s;
}

.btn a:hover {
	color: #f2f2f2;
}

.btn02 a {
	background-color: #92c11a;
	border: 1px solid #7fa50d;
	border-radius: 35px;
}

.btn02 a:hover {
	background-color: #7fa50d;
	border: 1px solid #333;
}

.btn02 a::before {
	content: '';
	position: absolute;
	top: calc(50% - 5px);
	right: -35px;
	transform: rotate(30deg);
	width: 12px;
	height: 1px;
	background-color: #333;
}

.btn02 a::after {
	content: '';
	position: absolute;
	top: 50%;
	right: -35px;
	transform: translateY(-50%);
	width: 70px;
	height: 1px;
	background-color: #333;
}











.table_design03 {
	border-collapse: collapse;
	width: 100%;
	font-size:1.6rem;
}
.table_design03 th, .table_design03 td {
	border-bottom: 2px solid #c1c7c6;
	padding: 15px;
}
.table_design03 th {
	border-bottom: 2px solid #90C21E;;
	font-weight: bold;
	text-align: center;
	width: 30%;
	min-width: 4em;
	}







ul.info-list{
	margin:20px 0;
	letter-spacing:0.5px;
}

ul.info-list li{
	margin:10px 0;
    border-bottom: 1px solid #ccc;
    font-size: 1.4rem;
    padding: 10px 0;
}

ul.info-list .cat {
	padding:5px 10px;
	border-radius: 3px;
	margin:0 10px 0 0;
	font-size:1.4rem;
    width: 110px;
    text-align: center;
    display: inline-block;
}


ul.info-list li div.cat147266{
	background:#e19393;
}
ul.info-list li div.cat147267{
	background:#e1c893;
}
ul.info-list li div.cat147268{
	background:#dddbdb;
}


ul.info-list li .entry-date{
	margin:0 10px 0 0;
    display: inline-block;
}

ul.info-list li .entry-ttl{
    display: inline-block;
}


@media screen and (max-width:767px){
  ul.info-list li{
    padding:  0;
  }
  
  ul.info-list li .entry-ttl{
    font-size: 1.8rem;
    display: block;
    margin: 10px 0;
  }
}












h2.ttl-rl span.left {
        transform: translate(16px, 81px);
        display:inline-block
    }



#business .ttl-box.biz01{
	display:flex;
	flex-wrap: wrap;
	justify-content:space-between;
		font-family: "Shippori Mincho", serif;
		background:url(../img/biz01.jpg) no-repeat;
		background-size: contain;
		background-position: 0px 30px;
}
#business .ttl-box.biz02{
	display:flex;
	flex-wrap: wrap;
	justify-content:space-between;
		font-family: "Shippori Mincho", serif;
		background:url(../img/biz03.jpg) no-repeat;
		background-size: contain;
		background-position: 0px 30px;
}


#business .ttl-box.biz03{
	display:flex;
	flex-wrap: wrap;
	justify-content:space-between;
		font-family: "Shippori Mincho", serif;
		background:url(../img/biz05.jpg) no-repeat;
		background-size: contain;
		background-position: 0px 30px;
}
#business .ttl-box.biz04{
	display:flex;
	flex-wrap: wrap;
	justify-content:space-between;
		font-family: "Shippori Mincho", serif;
		background:url(../img/biz07.jpg) no-repeat;
		background-size: contain;
		background-position: 0px 30px;
}





.biz-in{
	margin: 20% 0 0%;
			font-family: "Shippori Mincho", serif;
			font-size: 1.6rem;
}


.biz-in dt{
	font-weight:bold;
	padding:.5em;
	background-color:#e0e0e0;
}
.biz-in dd{
	padding-top:.5em;
	padding-bottom:.5em;
	margin:0;
}

.biz-in dd span {
	display:block;
	padding-left:.5em;
	border-left:1px solid #333;
	margin: 0 0 15px;
}



.biz-in .txt-hide {
font-family: "Zen Kaku Gothic New", sans-serif;
}






h2.ttl-rl{
	writing-mode: vertical-rl;
	font-size:3.6rem;
	width:25%;
	order: 2;
letter-spacing:10%;

  color: #000;
  text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
}

.ttl-lead{
	width: 74%;
	font-size:1.8rem;
	margin: 56% 0 0;
	line-height:1.4;
	padding:2%;

  color: #000;
  text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;

}





.ttl-box-L h2.ttl-rl{
	writing-mode: vertical-rl;
	width:17%;
	order: 1;

}

.ttl-box-L  .ttl-lead{
	order: 2;
}






.txt-hide{
	display: none;
}

button.more {
	width: 120px;
	margin: 20px auto;
	display: block;
	background-color: #92c11a;
	color: #fff;
	padding:10px 15px;
	border: none;
	outline: 0;
	transition: .5s;
	-erbkit-transition: .5s;
}
 
button.more::after {
	content: "View More";
	transition: .2s;
	-erbkit-transition: .2s;
}

button.more.on-click::after{
	content: "CLOSE";
}











.heading05 {
	position: relative;
	padding-bottom: 5rem;
	font-size: 1.6rem;
	text-align: center;
	line-height: 1.4;
	margin-top: 20%;
}

.heading05::before {
	content: attr(data-en);
	display: block;
	color: #c8d3b0;
	font-size: 3.4rem;
	font-style: italic;
	    font-weight: bold;
	text-transform: uppercase;
}

.heading05::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translate(-50%) rotate(30deg);
	width: 1px;
	height: 40px;
	background-color: #c8d3b0;
}









.heading06 {
	position: relative;
	padding-top: 50px;
	padding-bottom: 50px;
	font-size: 26px;
	text-align: center;
}

.heading06 span {
	position: relative;
	z-index: 2;
}

.heading06::before {
	content: attr(data-en);
	position: absolute;
	top: -20px;
	left: 50%;
	transform: translateX(-50%);
	color: rgba(144, 193, 28,0.2);
	font-size: 80px;
	font-style: italic;
}




.heading06::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translate(-50%) rotate(30deg);
	width: 1px;
	height: 40px;
	background-color: rgba(144, 193, 28,1);
}






.heading07 {
	position: relative;
	padding-top: 50px;
	padding-left: 30px;
	font-size: 26px;
}

.heading07 span {
	position: relative;
	z-index: 2;
}

.heading07::before {
	content: attr(data-en);
	position: absolute;
	transform: rotate(-5deg);
	top: -20px;
	left: 0;
	color: rgba(144, 193, 28,0.6);
	font-size: 80px;
	font-weight: 400;
	font-family: luxus-brut, cursive;
	font-style: italic;
}







.heading08 {
	font-size: 26px;
}

.heading08 span {
	display: flex;
	align-items: center;
	color: #498ee0;
	font-size: 18px;
	text-transform: uppercase;
}

.heading08 span::before {
	content: '';
	display: inline-block;
	margin-right: 20px;
	width: 40px;
	height: 1px;
	background-color: #498ee0;
}



.heading10 {
	position: relative;
	padding-top: 30px;
	font-size: 26px;
	border-bottom: 1px solid rgba(5,62,98,1);
}

.heading10 span {
	position: relative;
	z-index: 2;
}

.heading10::before {
	content: attr(data-en);
	position: absolute;
	top: 0px;
	left: 0;
	color: rgba(5,62,98,0.2);
	font-size: 40px;
	text-transform: uppercase;
	z-index: 1;
}
















/* ////////////////////////////////// */
/* inview.js */
/* ////////////////////////////////// */


/* 下からフェードイン */
.fadeIn_up {
  opacity: 0;
  transform: translate(0, 50%);
  transition: 2s;
}
.fadeIn_up.is-show {
  transform: translate(0, 0);
  opacity: 1;
}


/* 左からフェードイン */
.fadeIn_left {
  opacity: 0;
  transform: translate(-50%, 0);
  transition: 2s;
}
.fadeIn_left.is-show {
  transform: translate(0, 0);
  opacity: 1;
}


/* 右からフェードイン */
.fadeIn_right {
	opacity: 0;
	transform: translate(200px, 0);
	transition: 2s;
}
.fadeIn_right.is-show {
	transform: translate(0, 0);
	opacity: 1;
}





















