@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,100..900;1,100..900&family=Noto+Serif+JP:wght@200..900&family=Noto+Serif:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP&family=Noto+Serif:ital,wght@0,100..900;1,100..900&display=swap');

html{
	scroll-behavior: smooth;
	}

div,p,li,header,footer{
	box-sizing: border-box;
	}
img{
	border : 0px;
	vertical-align: bottom;
	}

/* リンク */
a:link { color: #353535; text-decoration : none;} 
a:visited { color: #353535; text-decoration : none;} 
a:hover { color: #353535; text-decoration : none;} 
a:active { color: #353535; text-decoration : none;} 
a:focus{ outline:none;}

.ce{
	text-align : center;
	}
.rr{
	text-align : right;
	}
.ll{
	text-align : left;
	}

p{
	margin : 0;
	}

.mb10{margin-bottom: 10px;}
.mb20{margin-bottom: 20px;}
.mb30{margin-bottom: 30px;}
.mb40{margin-bottom: 40px;}
.mb50{margin-bottom: 50px;}


form{
	margin : 0;
	}
input,select,button{
	margin : 0 0 10px 0;
	}
table{
	text-align: left;
	border-collapse: collapse;
	width: 100%;
	}
ul,ol,li,dl,dt,dd,td,tr{
	margin : 0;
	padding : 0;
	list-style: none;
	}







body{
	font-family: 'Noto Sans', "Hiragino Kaku Gothic Pro","ヒラギノ角ゴシック Pro", "メイリオ", Meiryo, Osaka, sans-serif;
    font-style: normal;
    font-weight: 400;
	font-size: 18px;
	line-height: 2;
	color: #3a3a3a;
	margin: 0 auto;
	padding: 0;
	}




header{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 40px;
	position: fixed;
	width: 100%;
	height: 80px;
	min-width: 1200px;
	background: rgba(255,255,255,0.8);
	border-bottom: solid 1px #eee;
	z-index: 9999;
	}
header h1{
	font-family: 'Noto Serif','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
	font-weight: 500;
	font-size: 24px;
	line-height: 1.6;
	}
header h1 img{
	margin: 0 5px 0 0;
	}
header ul{
	display: flex;
	justify-content: space-between;
	min-width: 40%;
	gap: 30px;
	font-weight: 700;
	margin-right: 2%;
	}
header ul li a{
	transition: 0.2s;
	font-size: 16px;
	}
header ul li a:hover{
	color: #7ad8e3;
	transition: 0.2s;
	}
header .contact a{
	display: block;
	border: solid 1px #7ad8e3;
	background: #fff;
	color: #7ad8e3;
	position: relative;
	padding: 3px 40px;
	transition: 0.5s;
	}
header .contact a:hover{
	background: #7ad8e3;
	color: #fff;
	}
header .contact a:after{
	content: "";
	width: 6px;
	height: 6px;
	border-bottom: solid 2px #7ad8e3;
	border-right: solid 2px #7ad8e3;
	transform: rotate(-45deg);
	position: absolute;
	right: 14px;
	top: 15px;
	transition: 0.5s;
	}
header .contact a:hover:after{
	border-bottom: solid 2px #fff;
	border-right: solid 2px #fff;
	}



footer{
	border-top: solid 1px #dedede;
	font-size: 14px;
	padding: 40px 20px;
	}
footer .content{
	width: 1200px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	line-height: 1.4;
	}
footer .content .data h1{
	font-family: 'Noto Serif','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
	font-weight: 500;
	font-size: 24px;
	line-height: 1.6;
	}
footer .content .data  h1 img{
	margin: 0 5px 0 0;
	}


footer .content ul{
	display: flex;
	gap: 40px;
	}
footer .content ul li a{
	transition: 0.2s;
	}
footer .content ul li a:hover{
	color: #7ad8e3;
	transition: 0.2s;
	}

#copy{
	color: #fff;
	background: #5a5a5a;
	font-size: 12px;
	text-align: center;
	padding: 5px 0;
	}













.scroll-top{
	position: fixed;
	bottom: 20px;
	right: 20px;
	width: 38px;
	height: 38px;
	cursor: pointer;
	display: none;
	z-index: 9999;
	}
.scroll-top:hover{
	bottom: 30px;
	transition: 0.2s;
	}






/*animation*/
#kv .fade1{
	opacity: 0;
	animation: fadeIn 1.5s forwards;
	}
#kv .fade2{
	opacity: 0;
	animation: fadeIn 1s 1s forwards;
	}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}



.amt.fadeup{
	opacity: 0;
	transition-duration: .5s;
	transform: translateY(100px);
	}
.amt.fadeup.active{
	opacity: 1;
	transform: translateY(0px);
	}

.amt.zoom{
	opacity: 0;
	transition-duration: .5s;
	transform:scale(0.2);
	}
.amt.zoom.active{
	opacity: 1;
	transform:scale(1);
	}





/* index */

#index_kv{
	min-width: 1200px;
	position: relative;
	}
#index_kv img{
	width: 100%;
	}
#index_kv h2{
	position: absolute;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	font-family: 'Noto Serif','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
	font-weight: 100;
	font-size: 2.0vw;
	top: 20%;
	right: 20%;
	}


#index_information{
	width: 1200px;
	margin: 0 auto;
	padding: 130px 0;
	display: flex;
	justify-content: space-between
	}
#index_information .content .title{
	font-size: 30px;
	color: #7ad8e3;
	font-weight: 500;
	line-height: 1;
	}
#index_information .content .jp_title{
	font-size: 18px;
	font-weight: 300;
	}
#index_information .content .btn a{
	display: block;
	border: solid 1px #7ad8e3;
	background: #fff;
	color: #7ad8e3;
	position: relative;
	padding: 3px 40px;
	transition: 0.5s;
	margin: 40px 0 0 0;
	text-align: center;
	}
#index_information .content .btn a:hover{
	background: #7ad8e3;
	color: #fff;
	}
#index_information .content .btn a:after{
	content: "";
	width: 6px;
	height: 6px;
	border-bottom: solid 2px #7ad8e3;
	border-right: solid 2px #7ad8e3;
	transform: rotate(-45deg);
	position: absolute;
	right: 14px;
	top: 15px;
	transition: 0.5s;
	}
#index_information .content .btn a:hover:after{
	border-bottom: solid 2px #fff;
	border-right: solid 2px #fff;
	}
#index_information ul{
	border-top: solid 1px #efefef;
	width: 850px;
	}
#index_information ul li{
	border-bottom: solid 1px #efefef;
	padding: 25px 0;
	}




#index_business,
#index_recruit{
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0 0 200px 0;
	}
#index_business .content,
#index_recruit .content{
	width: 40%;
	display: flex;
	justify-content: center;
	}
#index_business .image,
#index_recruit .image{
	width: 60%;
	}
#index_business .image img,
#index_recruit .image img{
	width: 100%;
	}
#index_business .content,
#index_recruit .content{
	text-align: center;
	}
#index_business .content .title,
#index_recruit .content .title{
	font-size: 24px;
	color: #7ad8e3;
	font-weight: 500;
	line-height: 1;
	}
#index_business .content .jp_title,
#index_recruit .content .jp_title{
	font-size: 14px;
	font-weight: 300;
	}
#index_business .content .text,
#index_recruit .content .text{
	font-size: 14px;
	border-top: solid 1px #efefef;
	border-bottom: solid 1px #efefef;
	margin: 20px 0 0 0;
	padding: 25px 0;
	}
#index_business .content .btn a,
#index_recruit .content .btn a{
	display: block;
	border: solid 1px #7ad8e3;
	background: #fff;
	color: #7ad8e3;
	position: relative;
	padding: 3px 40px;
	transition: 0.5s;
	margin: 40px 0 0 0;
	text-align: center;
	}
#index_business .content .btn a:hover,
#index_recruit .content .btn a:hover{
	background: #7ad8e3;
	color: #fff;
	}
#index_business .content .btn a:after,
#index_recruit .content .btn a:after{
	content: "";
	width: 6px;
	height: 6px;
	border-bottom: solid 2px #7ad8e3;
	border-right: solid 2px #7ad8e3;
	transform: rotate(-45deg);
	position: absolute;
	right: 14px;
	top: 15px;
	transition: 0.5s;
	}
#index_business .content .btn a:hover:after,
#index_recruit .content .btn a:hover:after{
	border-bottom: solid 2px #fff;
	border-right: solid 2px #fff;
	}




#index_works{
	background-image: url('http://www.ollie-creation.co.jp/fukudadoboku/wp-content/uploads/2025/05/bg01.png'),url('img/common/bg.png');
	background-repeat: no-repeat,no-repeat;
	background-position: left top,right bottom;
	padding: 80px 0 120px 0;
	margin: 0 0 200px 0;
	}
#index_works .content{
	width: 1200px;
	margin: 0 auto 80px;
	display: flex;
	justify-content: left;
	align-items: center;
	gap: 30px;
	}
#index_works .content .title{
	font-size: 24px;
	color: #fff;
	line-height: 1;
	text-align: center;
	}
#index_works .content .jp_title{
	font-size: 14px;
	text-align: center;
	}
#index_works .content .btn a{
	display: block;
	border: solid 1px #fff;
	color: #fff;
	position: relative;
	padding: 3px 60px;
	transition: 0.5s;
	text-align: center;
	}
#index_works .content .btn a:hover{
	background: #fff;
	color: #7ad8e3;
	}
#index_works .content .btn a:after{
	content: "";
	width: 6px;
	height: 6px;
	border-bottom: solid 2px #fff;
	border-right: solid 2px #fff;
	transform: rotate(-45deg);
	position: absolute;
	right: 14px;
	top: 15px;
	transition: 0.5s;
	}
#index_works .content .btn a:hover:after{
	border-bottom: solid 2px #7ad8e3;
	border-right: solid 2px #7ad8e3;
	}

#index_works ul li img{
	width: 100%;
    height: 18vw;
    object-fit: cover;
}

.slider .slick-slide {
	padding: 0 50px;
	box-sizing: border-box;
	}
.slider {
	margin: 0 auto;
	box-sizing: border-box;
	width: 95%;
	}
.slick-prev,.slick-next{
	width: 30px !important;
	height: 30px !important;
	}
.slick-prev:before, .slick-next:before {
	font-size: 30px !important;
	}
.slick-dots {
	display: flex;
	justify-content: center;
	bottom: -35px !important;
	}
.slick-dots li button:before{
	font-size:15px!important;
	}







#all{
	padding: 80px 0 0 0;
	}
	
#breadcrumb{
	background: #f0f0f0;
	font-size: 14px;
	}
#breadcrumb ul{
	width: 1200px;
	margin: 0 auto;
	padding: 5px 0;
	display: flex;
	justify-content: left;
	gap: 10px;
	}
	
.page_title{
	display: none;
	}

#page_title h2{
	font-size: 36px;
	font-weight: 100;
	}
#page_title span{
	display: block;
	font-size: 16px;
	font-weight: 500;
	}


/* company */


#company #page_title{
	background: url('img/common/main01.jpg') no-repeat;
	padding: 80px 0 60px 0;
	text-align: center;
	color: #fff;
	line-height: 1;
	}


#company #president {
	position: relative;
	width: 100%;
	}

#company #president .image {
	position: relative;
	width: 100%;
	}

#company #president .image img {
	width: 100%;
	height: auto;
	display: block;
	}

#company #president .data {
	position: absolute;
	top: 20%;
	left: 40%;
	color: #fff;
	font-size: 1.8vw;
	}

#company #president .data .title{
	font-size: 36px;
	line-height: 1;
	}
#company #president .data .en{
	font-size: 24px;
	margin: 0 0 50px 0;
	}
#company #message{
	padding: 80px 0;
	width: 1200px;
	margin: 0 auto;
	}
#company #message p{
	margin: 0 0 30px 0;
	}
#company #message .rr{
	font-size: 22px;
	font-family: 'Noto Serif','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
	font-weight: 700;
	}
#company #philosophy{
	background: url('img/common/bg.png') no-repeat;
	padding: 120px 0;
	text-align: center;
	line-height: 1;
	font-size: 32px;
	}
#company #philosophy .title{
	}
#company #philosophy .en{
	font-size: 16px;
	margin: 0 0 50px 0;
	}
#company #philosophy .philosophy{
	font-family: 'Noto Serif','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
	font-weight: 700;
	}
#company #action{
	border-bottom: solid 1px #ccc;
	}
#company #action .content{
	width: 1000px;
	padding: 150px 0;
	margin: 0 auto;
	}
#company #action .content .title{
	font-size: 32px;
	line-height: 1;
	text-align: center;
	}
#company #action .content .en{
	font-size: 16px;
	margin: 0 0 50px 0;
	text-align: center;
	}
#company #action .content .block{
	margin: 0 0 50px 0;
	display: flex;
	gap: 50px;
	}
#company #action .content .block .image img{
	margin: 0 0 10px 0;
	}
#company #action .content .block .title{
	font-weight: bold;
	font-size: 24px;
	margin: 0 0 20px 0;
	text-align: left;
	}
#company #action .content .text{
	margin: 0 0 30px 0;
	}

#company #action .content dl.csr{
	margin: 0 0 50px 0;
	}
#company #action .content dl.csr dt{
	margin: 0 0 10px 0;
	font-weight: bold;
	border-bottom: solid 3px #ccc;
	position: relative;
	}
#company #action .content dl.csr dt::before {
    content: '';
    position: absolute;
    bottom: -3px;
    width: 30%;
    height: 3px;
    background: #7ad8e3;
	}

#company #data{
	width: 1000px;
	padding: 150px 0 50px 0;
	margin: 0 auto;
	}
#company #data .content{
	margin: 0 0 150px 0;
	}
#company #data .content .title{
	font-size: 32px;
	line-height: 1;
	text-align: center;
	}
#company #data .content .en{
	font-size: 16px;
	margin: 0 0 30px 0;
	text-align: center;
	}
#company #data .content table th{
	border: solid 1px #d8d8d8;
	background: #ececec;
	padding: 15px;
	font-weight: bold;
	width: 20%;
	}
#company #data .content table td{
	border: solid 1px #d8d8d8;
	padding: 15px;
	}


/* business */
#business #page_title{
	background: url('img/common/main02.jpg') no-repeat;
	padding: 80px 0 60px 0;
	text-align: center;
	color: #fff;
	line-height: 1;
	}
.business_list{
	width: 1200px;
	margin: 0 auto;
	padding: 100px 0 50px 0;
	}
.business_list li{
	padding: 0 0 180px 0;
	position: relative;
	}
.business_list li .number{
	background: #81d3cc;
	color: #fff;
	font-size: 50px;
	border-radius: 50%;
	width: 100px;
	height: 100px;
	z-index: 99999;
	position: absolute;
	display: flex;
	justify-content: center;
	left: 550px;
	}
.business_list li .image{
	z-index: -9999;
	}
.business_list li .title{
	font-size: 32px;
	text-align: center;
	margin: 30px 0;
	}
.business_list li .text{
	margin: 0 0 30px 0;
	text-align: center;
	}






/* works */


#works #page_title{
	background: url('img/common/main02.jpg') no-repeat;
	padding: 80px 0 60px 0;
	text-align: center;
	color: #fff;
	line-height: 1;
	}
#works ul.works_list {
	padding: 100px 10px 50px 10px;
	display: flex;
	flex-wrap: wrap;
	gap: 2%;
	}

#works ul.works_list li {
	width: 32%;
	margin: 0 0 2% 0;
	position: relative;
	}

#works ul.works_list li .image img {
	width: 100%;
	aspect-ratio: 6 / 4;
	height: fit-content;
	overflow: hidden;
	object-fit: cover;
	}
#works ul.works_list li .noimage {
	width: 100%;
	aspect-ratio: 6 / 4;
	height: fit-content;
	object-fit: cover;
	background: #eee;
	display: flex;
	justify-content: center;
	align-items: center;
	}

#works ul.works_list li .image img:hover {
	opacity: 0.8;
	transition: 0.2s;
	}

#works ul.works_list li .data{
	line-height: 1.4;
	color: #fff;
	position: absolute;
	bottom: 10px;
	left: 20px;
	background: rgba(0, 0, 0, 0.6);
	padding: 10px;
	border-radius: 5px;
	pointer-events: none;
	}



#works ul.info_list {
	width: 1000px;
	margin: 100px auto 250px;
	}
#works ul.info_list li {
	border-bottom: solid 1px #ccc;
	padding: 20px 0;
	}
#works ul.info_list li a{
    color: #7ad8e3;
	}



#works .pagination{
	margin: 0 auto 100px;
	text-align: center;
	}
#works .pagination .page-numbers{
	padding: 6px;
    width: 2em;
    height: 2em;
    background: #7ad8e3;
    display: inline-block;
    color: #fff;
	}
#works .pagination .current{
    background: #eee;
    color: #333;
	}


#works .works{
	padding: 100px 0 250px;
	width: 1000px;
	margin: 0 auto;
	}
#works .works .title{
	font-size: 30px;
	font-weight: bold;
	margin: 0 0 80px 0;
	text-align: center;
	border-bottom: solid 1px #999;
	}
#works .works .image{
	margin: 0 0 80px 0;
	}
#works .works .image .aligncenter{
	text-align: center;
	margin: 0 auto;
	display: block;
	}
#works .works dl{
	display: flex;
	border-bottom: solid 1px #ccc;
	padding: 20px 0;
	gap: 5%;
	}
#works .works dl dt{
	font-weight: bold;
	width: 10%;
	}
#works .works dl dd{
	width: 95%;
	}
#works .works .prev a{
	margin: 50px auto 0;
	text-align: center;
	display: block;
    color: #7ad8e3;
	}







/* recruit */

#recruit #page_title{
	background: url('img/common/main01.jpg') no-repeat;
	padding: 80px 0 60px 0;
	text-align: center;
	color: #fff;
	line-height: 1;
	}
#recruit #message{
	padding: 120px 0;
	width: 1200px;
	margin: 0 auto;
	text-align: center;
	}
#recruit #message .title{
	font-size: 32px;
	color: #81d3cc;
	margin: 0 0 50px 0;
	text-align: center;
	}
#recruit #works{
	padding: 80px 0;
	background: #f1f1f1;
	}
#recruit #works .title{
	font-size: 32px;
	line-height: 1;
	text-align: center;
	}
#recruit #works .en{
	font-size: 16px;
	margin: 0 0 50px 0;
	text-align: center;
	}
#recruit #works ul{
	display: flex;
	margin: 0 0 50px 0;
	}
#recruit #works ul li{
	}
#recruit #works ul li img{
	width: 100%;
	}
#recruit #works .text{
	width: 1200px;
	margin: 0 auto;
	}
#recruit #workbalance{
	padding: 150px 0 100px 0;
	margin: 0 auto;
	border-bottom: solid 1px #ccc;
	}
#recruit #workbalance .content{
	width: 1200px;
	}
#recruit #workbalance .title{
	font-size: 32px;
	line-height: 1;
	text-align: center;
	margin: 0 0 50px 0;
	}
#recruit #workbalance .title span{
	position: relative;
	border-bottom: 3px solid #e8e8e8;
	padding-bottom: 5px;
	}
#recruit #workbalance .title span::before{
	content: '';
	position: absolute;
	bottom: -3px;
	width: 53%;
	height: 3px;
	background: #7ad8e3;
	}
#recruit #workbalance .title span strong{
	color: #7ad8e3;
	font-weight: normal;
	}
#recruit #workbalance .text{
	text-align: center;
	margin: 0 0 30px 0;
	}
#recruit #interview{
	padding: 150px 0 50px 0;
	width: 1200px;
	margin: 0 auto;
	}
#recruit #interview .title{
	font-size: 32px;
	line-height: 1;
	text-align: center;
	}
#recruit #interview .en{
	font-size: 16px;
	margin: 0 0 50px 0;
	text-align: center;
	}
#recruit #interview .staff{
	margin: 0 0 150px 0;
	}
#recruit #interview .staff .name{
	width: 250px;
	background: #81d3cc;
	color: #fff;
	text-align: center;
	margin: -30px 0 0 50px;
	position: absolute;
	font-size: 36px;
	}
#recruit #interview .staff dl{
	margin: 100px auto 100px;
	width: 1000px;
	}
#recruit #interview .staff dl dt{
	font-size: 24px;
	font-weight: 500;
	}
#recruit #interview .staff dl dt span{
	color: #81d3cc;
	margin: 0 10px 0 0;
	}
#recruit #interview .staff dl dd{
	margin: 0 0 30px 0;
	}
#recruit #data{
	margin: 100px auto 250px;
	width: 1000px;
	}
#recruit #data .title{
	font-size: 32px;
	line-height: 1;
	text-align: center;
	}
#recruit #data .en{
	font-size: 16px;
	margin: 0 0 30px 0;
	text-align: center;
	}
#recruit #data table th{
	border: solid 1px #d8d8d8;
	background: #ececec;
	padding: 15px;
	font-weight: bold;
	width: 20%;
	}
#recruit #data table td{
	border: solid 1px #d8d8d8;
	padding: 15px;
	}










/* contact */

#contact #page_title{
	background: url('img/common/main01.jpg') no-repeat;
	padding: 80px 0 60px 0;
	text-align: center;
	color: #fff;
	line-height: 1;
	}
#contact #all .content{
	width: 1000px;
	margin: 100px auto 250px;
	}

#contact .text{
	margin : 0 0 30px 0;
	}

#contact table{
	width : 100%;
	margin : 0 0 80px 0;
	}
#contact table th{
	width : 300px;
	border : solid 1px #ccc;
	padding : 25px 10px;
	background : #eee;
	position: relative;
	}
#contact table td{
	border : solid 1px #ccc;
	padding : 25px 0 25px 20px;
	}
#contact table th.req::after {
    content: "必須";
    background: #e67816;
    padding: 0px 10px;
    font-size: 12px;
    color: #fff;
    position: absolute;
    right: 10px;
    top: 40%;
	}
#contact table input[type=text],
#contact table input[type=email],
#contact table input[type=tel],
#contact table textarea{
	margin : 5px 0;
	padding : 10px;
	border-radius : 5px;
	border: solid 1px #ccc;
	width : 500px;
	}
#contact table select{
	margin : 5px 0;
	padding : 10px;
	}
	
#contact form h2{
	border-bottom: solid 1px #000;
	font-size: 24px;
	text-align: left;
	margin: 0 0 30px 0;
	font-weight: bold;
	}
	.kiyaku_box{
		overflow : auto;
		height : 200px;
		border : solid 1px #cdcdcd;
		margin : 0 0 30px 0;
		background : #fff;
		}
	.kiyaku_box .text{
		padding : 25px;
		}
	.kiyaku_box .text ol{
		list-style : decimal;
		padding : 0 0 0 15px;
		}
	.kiyaku_box .text ol li{
		margin : 0 0 10px 0;
		}
	.kiyaku_box .text .title{
		font-size : 18px !important;
		border-bottom : solid 1px #cdcdcd;
		}
	.kiyaku_box .text p{
		margin : 0 0 15px 0;
		}
	.submit{
		background : #ff811b;
		border : none;
		color : #fff;
		font-family: 'Noto Sans', "Hiragino Kaku Gothic Pro","ヒラギノ角ゴシック Pro", "メイリオ", Meiryo, Osaka, sans-serif;
		padding : 10px 0;
		width : 300px;
		font-size : 16px;
		cursor : pointer;
		margin: 0 auto;
		display: block;
		}
	.submit:hover{
		background : #ffad6a;
		font-family: 'Noto Sans', "Hiragino Kaku Gothic Pro","ヒラギノ角ゴシック Pro", "メイリオ", Meiryo, Osaka, sans-serif;
		}










/********************************************************************************************************************************************************************************/
@media screen and (min-width: 950px) {
/********************************************************************************************************************************************************************************/

a[href^="tel:"] { pointer-events: none; color:#000;}



	.sp{
		display : none;
		}

#sp_menu{
	display : none;
	}








/********************************************************************************************************************************************************************************/
}
@media screen and (max-width: 949px) {
/********************************************************************************************************************************************************************************/


	.pc{
		display : none;
		}

img{
	max-width: 100%;
	}

body{
	color : #353535;
	font-size : 16px;
	padding: 0;
	margin: 0;
	}


#sp_menu{
	display : block;
	}






/* メニューボタン */

.menu_btn{
    position: fixed;
    top: 8px;
    right: 10px;
    display: flex;
    height: 40px;
    width: 40px;
    justify-content: center;
    align-items: center;
    z-index: 999999;
    background: #7ad8e3;
    border-radius: 5px;
	}
.menu_btn span,
.menu_btn span:before,
.menu_btn span:after{
	transition: all .4s;
    content: '';
    display: block;
    height: 2px;
    width: 20px;
    border-radius: 3px;
    background: #ffffff;
    position: absolute;
	}
.menu_btn span:before{
    bottom: 6px;
	}
.menu_btn span:after{
    top: 6px;
	}


#menu_btn_check:checked ~ .menu_btn{
    background: #fff;
	}

#menu_btn_check:checked ~ .menu_btn span{
    background-color: rgba(255, 255, 255, 0);
	}
#menu_btn_check:checked ~ .menu_btn span::before{
    background: #7ad8e3;
    bottom: 0;
    transform: rotate(495deg);
	}
#menu_btn_check:checked ~ .menu_btn span::after{
    background: #7ad8e3;
    top: 0;
    transform: rotate(-495deg);
	}

#menu_btn_check{
    display: none;
	}

#menu_btn_check:checked ~ .content{
    left: 0;
	}



#sp_menu .content {
    width: 100%;
    height: 100%;
    position: fixed;
    overflow: auto;
    top: 0;
    left: 100%;
    z-index: 2;
    background-color: rgb(122,216,227,0.96);
    transition: all 0.5s;
    color: #fff;
    padding: 0 20px;
	}
#sp_menu .content ul {
    padding: 50px 0 0 0;
	}
#sp_menu .content ul:first-child li {
    border-bottom: solid 1px #fff;
    list-style: none;
	}
#sp_menu .content ul:first-child li a{
    display: block;
    width: 100%;
    font-size: 18px;
    box-sizing: border-box;
    color: #fff;
    text-decoration: none;
    padding: 9px 15px 10px 0;
    position: relative;
	}



header{
	padding: 0 10px;
	position: static;
	width: 100%;
	height: auto;
	min-width: 100%;
	z-index: 9999;
	}
header h1{
	font-size: 18px;
	}
header h1 img{
	width: 30px;
	}
header ul{
	display: none;
	}
header .contact a{
	display: none;
	}



footer{
	padding: 10px;
	}
footer .content{
	width: 100%;
	}
footer .content .data h1{
	font-size: 18px;
	margin: 0 0 5px 0;
	}
footer .content .data  h1 img{
	width: 30px;
	}
footer .content ul{
	display: none;
	}



.scroll-top{
	bottom: 10px;
	right: 10px;
	width: 38px;
	height: 38px;
	}
.scroll-top:hover{
	bottom: 10px;
	}









/* index */

#index_kv{
	min-width: 100%;
	}
#index_kv img{
	object-fit: cover;
	object-position: 40% 100%;
	height: 450px;
	}
#index_kv h2{
	font-size: 6.0vw;
	top: 15%;
	right: 15%;
	}


#index_information{
	width: 100%;
	margin: 0 auto 20px;
	padding: 80px 10px;
	display: block;
	}
#index_information .content .title{
	text-align: center;
	font-size: 24px;
	}
#index_information .content .jp_title{
	text-align: center;
	font-size: 14px;
	}
#index_information ul{
	width: 100%;
	margin: 20px 0 0 0;
	}
#index_information ul li{
	border-bottom: solid 1px #efefef;
	padding: 15px 0;
	}




#index_business{
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 100px 0;
	}
#index_recruit{
	display: block;
	margin: 0 0 100px 0;
	}
#index_business .content{
	width: 100%;
	order: 2;
	}
#index_recruit .content{
	width: 100%;
	}
#index_business .image{
	width: 100%;
	margin: 0 0 20px 0;
	order: 1;
	}
#index_recruit .image{
	width: 100%;
	margin: 0 0 20px 0;
	}
#index_business .image img,
#index_recruit .image img{
	width: 100%;
	}
#index_business .content div,
#index_recruit .content div{
	width: 100%;
	padding: 0 10px;
	}




#index_works{
	padding: 50px 10px;
	margin: 0 0 50px 0;
	}
#index_works .content{
	width: 100%;
	margin: 0 auto 40px;
	}

#index_works ul li img{
    height: 45vw;
}




#all{
	padding: 0;
	}
	
#breadcrumb{
	font-size: 12px;
	padding: 0 10px;
	}
#breadcrumb ul{
	width: 100%;
	}
#page_title h2{
	font-size: 26px;
	}
#page_title span{
	font-size: 14px;
	}





/* company */

#company #page_title{
	padding: 30px 0 20px 0;
	}


#company #president {
	width: 100%;
	}

#company #president .image {
	width: 100%;
	}

#company #president .image img {
	width: 100%;
	}

#company #president .data {
	font-size: 3vw;
	line-height: 1.4;
	}

#company #president .data .title{
	font-size: 20px;
	margin: 0 0 5px 0;
	}
#company #president .data .en{
	font-size: 12px;
	margin: 0 0 10px 0;
	}
#company #message{
	padding: 40px 10px;
	width: 100%;
	}
#company #message p{
	margin: 0 0 30px 0;
	}
#company #message .rr{
	font-size: 18px;
	}
#company #philosophy{
	padding: 60px 0;
	font-size: 26px;
	}
#company #philosophy .en{
	font-size: 12px;
	margin: 0 0 30px 0;
	}
#company #philosophy .philosophy{
	font-size: 18px;
	}
#company #action{
	border-bottom: solid 1px #ccc;
	}
#company #action .content{
	width: 100%;
	padding: 80px 10px 40px 10px;
	}
#company #action .content .title{
	font-size: 26px;
	}
#company #action .content .en{
	font-size: 12px;
	margin: 0 0 30px 0;
	}
#company #action .content .block{
	margin: 0 0 50px 0;
	display: block;
	}
#company #action .content .block:last-child{
	margin: 0;
	display: flex;
	gap: 20px;
	}
#company #action .content .block:last-child .image{
	width: 100%;
	margin: 3em 0 0 0;
	}
#company #action .content .block .image{
	display: flex;
	gap: 20px;
	justify-content: center;
	}
#company #action .content .block .title{
	font-size: 20px;
	}

#company #data{
	width: 100%;
	padding: 80px 10px 0 10px;
	}
#company #data .content{
	margin: 0 0 80px 0;
	}
#company #data .content .title{
	font-size: 26px;
	}
#company #data .content .en{
	font-size: 12px;
	}
#company #data .content table th{
	padding: 10px;
	white-space: nowrap;
	}
#company #data .content table td{
	padding: 10px;
	}




/* business */
#business #page_title{
	padding: 30px 0 20px 0;
	}
.business_list{
	width: 100%;
	padding: 50px 10px 0 10px;
	box-sizing: border-box;
	}
.business_list li{
	padding: 0 0 80px 0;
	}
.business_list li .number{
	font-size: 16px;
	border-radius: 50%;
	width: 30px;
	height: 30px;
	left: 47%;
	}
.business_list li .title{
	font-size: 22px;
	}






/* works */


#works #page_title{
	padding: 30px 0 20px 0;
	}
#works ul.works_list {
	padding: 50px 10px;
	}

#works ul.works_list li {
	width: 49%;
	}



#works ul.works_list li .data{
	bottom: 0px;
	left: 0px;
	padding: 5px;
	border-radius: 0px;
	font-size: 14px;
	}


#works .works{
	padding: 50px 10px;
	width: 100%;
	}
#works .works .title{
	font-size: 20px;
	margin: 0 0 40px 0;
	}
#works .works .image{
	margin: 0 0 20px 0;
	}
#works .works dl{
	display: block;
	padding: 10px 0;
	}
#works .works dl dt{
	width: 100%;
	}
#works .works dl dd{
	width: 100%;
	}







/* recruit */

#recruit #page_title{
	padding: 30px 0 20px 0;
	}
#recruit #message{
	padding: 40px 10px;
	width: 100%;
	}
#recruit #message .title{
	font-size: 24px;
	line-height: 1.4;
	margin: 0 0 40px 0;
	}
#recruit #works{
	padding: 50px 10px;
	background: #f1f1f1;
	}
#recruit #works .title{
	font-size: 20px;
	}
#recruit #works .en{
	font-size: 12px;
	margin: 0 0 30px 0;
	}
#recruit #works ul{
	display: flex;
	margin: 0 0 50px 0;
	}
#recruit #works ul li{
	}
#recruit #works ul li img{
	width: 100%;
	}
#recruit #works .text{
	width: 100%;
	margin: 0 auto;
	}


#recruit #workbalance{
	padding: 50px 10px;
	}
#recruit #workbalance .content{
	width: 100%;
	}
#recruit #workbalance .title{
	font-size: 26px;
	border-bottom: 3px solid #7ad8e3;
	padding: 0;
	line-height: 1.4;
	position: relative;
	width: 70%;
	margin: 0 auto 50px;
	}
#recruit #workbalance .title:before{
	content: '';
	position: absolute;
	bottom: -3px;
	width: 50%;
	height: 3px;
	background: #e8e8e8;
	right: 0;
	}
#recruit #workbalance .title span{
	border-bottom: none;
	padding-bottom: 5px;
	}
#recruit #workbalance .title span::before{
	background: none;
	}

#recruit #interview{
	padding: 50px 10px 0 10px;
	width: 100%;
	}
#recruit #interview .title{
	font-size: 24px;
	}
#recruit #interview .en{
	font-size: 12px;
	margin: 0 0 30px 0;
	}
#recruit #interview .staff{
	margin: 0 0 100px 0;
	}
#recruit #interview .staff .name{
	width: 150px;
	margin: -30px 0 0 20px;
	font-size: 20px;
	}
#recruit #interview .staff dl{
	margin: 50px auto;
	width: 100%;
	}
#recruit #interview .staff dl dt{
	font-size: 20px;
	}

#recruit #data{
	margin: 50px auto;
	width: 100%;
	padding: 0 10px;
	}
#recruit #data .title{
	font-size: 24px;
	}
#recruit #data .en{
	font-size: 12px;
	}
#recruit #data table th{
	padding: 10px;
	white-space: nowrap;
	}
#recruit #data table td{
	padding: 10px;
	}










/* contact */

#contact #page_title{
	padding: 30px 0 20px 0;
	}
#contact #all .content{
	width: 100%;
	margin: 50px 10px;
	box-sizing: border-box;
	}


#contact table{
	display: block;
	width : 100%;
	box-sizing: border-box;
	}
#contact table tbody{
	display: block;
	width : 100%;
	box-sizing: border-box;
	}
#contact table th{
	width : 100%;
	padding : 10px;
	display: block;
	box-sizing: border-box;
	}
#contact table td{
	width : 100%;
	padding : 10px;
	display: block;
	box-sizing: border-box;
	}
#contact table input[type=text],
#contact table textarea{
	width : 100%;
	box-sizing: border-box;
	}
#contact table select{
	margin : 5px 0;
	padding : 10px;
	}
	
#contact form h2{
	font-size: 20px;
	}
	.kiyaku_box{
		overflow : auto;
		height : 200px;
		border : solid 1px #cdcdcd;
		margin : 0 0 30px 0;
		background : #fff;
	box-sizing: border-box;
		}
	.kiyaku_box .text{
		padding : 15px;
		}










































/********************************************************************************************************************************************************************************/
}
/********************************************************************************************************************************************************************************/


