@charset "utf-8";
/* CSS Document */
/* ====================== BASE ====================== */
/*
font-family: 'Neuton', serif;
font-family: 'Noto Sans JP', sans-serif;
font-family: 'Roboto', sans-serif;
font-family: 'Shippori Mincho', serif;
*/
html {
font-family: 'Noto Sans JP', sans-serif;
font-size: 16px;
}
.img-c {
text-align: center;
}
.mb10 {
margin-bottom: 10px;
}
.mb30 {
margin-bottom: 30px;
}
.mb50 {
margin-bottom: 50px;
}
.mb80 {
margin-bottom: 80px;
}
.mb100 {
margin-bottom: 100px;
}
p,a {
color: #000;
text-align: left;
text-decoration: none;
}
.fwb {
    font-weight: bold;
}
.fs20 {
    font-size: 20px;
}
.inner {
width: 1200px;
margin: 0 auto;
}
.flex {
display: flex;	
justify-content: space-between;
}
h2 {
text-align: center;
font-size: 30px;
font-weight: 200;
position: relative;
padding-top: 50px;
margin-bottom: 30px;
font-weight: 400;
}
h2 span {
font-size: 18px;
color: #FF9900;
display: block;
}
h2::before{
content: "";
display: block;
width: 40px;
height: 40px;
background-image: url("../images/bg_h2.png");
background-repeat: no-repeat;
background-size: 100% auto;
position: absolute;
top: 15px;
left: 50%;
transform: translate(-50%, 0);
-webkit-transform: translate(-50%, 0);
-ms-transform: translate(-50%, 0);
}
h3 {
background-color: #FF9900;
color: #fff;
text-align: center;
padding: 5px;
font-weight: 600;
margin-bottom: 20px;
font-size: 22px;
margin: 0 auto;
margin-bottom: 30px;
}
.lead {
font-size: 16px;
font-weight: lighter;
text-align: center;
margin-bottom: 30px;
}
.sp {
display: none;
}
.pc {
display: block;
}


/* ====================== PC ====================== */
/*========= header =========*/
header {
padding: 10px 0 10px 0;
border-top: 5px solid #FF9900;
}
header h1 img {
width: 300px;
}
header .global_nav_pc {
margin-top: auto;
}

header .global_nav_pc ul {
width: auto;
}

header .global_nav_pc ul li{
position: relative;
text-align: center;
width: 182px;
font-size: 20px;
}

header .global_nav_pc ul li+li::before{
content: "";
display: block;
height: 100%;
border-left: 1px solid #999;
position: absolute;
top: 0;
bottom: 0;
}
/*========= mainvisual =========*/
.mainvisual {
position: relative;
}
.mainvisual .copy {
position: absolute;
right: 5%;
bottom: 10%;
-ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
.mainvisual .copy span {
background: #FF9900;
color: #fff;
display: inline;
line-height: 67px;
padding: 5px;
font-size: 30px;
}
.mainvisual img {
width: 100%;
height: auto;
}


/*========= news =========*/
#news .inner {
padding-top: 20px;
padding-bottom: 50px;
}
#news dl {
width: 80%;
margin: 0 auto;	
flex-wrap: wrap;
padding-bottom: 50px;
overflow-y: scroll;
height: 250px;
}
#news dl dt,
#news dl dd {
padding: 27px;
border-bottom: 1px solid #B3B3B3;
}
#news dl dt {
width: 20%;
font-weight:bold;
}
#news dl dd {
width: 80%;
}
#news dl dd a {
text-decoration: underline;
}

/*========= business =========*/
#business {
padding: 100px 0;
background-image: url("../images/bg_main.jpg");
background-size: cover;
}
#business .inner {
background: linear-gradient(#FFDAA5, #ffffff);
position: relative;
padding-top: 100px;
}
#business .deco-txt {
position: absolute;
top: -100px;
left: 50%;
transform: translate(-50%, 0);
-webkit-transform: translate(-50%, 0);
-ms-transform: translate(-50%, 0);
font-size: 150px;
color: #fff;
font-family: 'Roboto', sans-serif;
font-weight: bold;
width: 100%;
text-align: center;
letter-spacing: 10px;
}
#business .img-c img {
width: 690px;
height: auto;
margin-bottom: 20px;
}
#business .copy {
font-weight: bold;
font-size: 24px;
text-align: center;
letter-spacing: 5px;
}

#business .business01 .inner,
#business .business02 .inner, 
#business .business03 .inner, 
#business .business04 .inner {
width: 90%;
margin: 0 auto;
background: none;
padding-top: 30px;
}
#business .business01 .lead,
#business .business02 .lead,
#business .business03 .lead,
#business .business04 .lead {
font-weight: bold;
}
#business .business01 .img-c img,
#business .business02 .img-c img,
#business .business03 .img-c img{
width: 100%;
height: auto;
}
#business .business04 .img-c img {
width: 500px;
height: auto;
}
.business01-list {
flex-wrap: wrap;
justify-content: center;
}
.business01-list li {
   width: 200px;
    margin-right: 60px;
	margin-bottom: 10px;
	}
.business01 ul li:nth-child(4),
.business01 ul li:last-child {
    margin-right: 0;
}
.business01 ul li.space {
    width: 100%;
    background: none;
    height: 10px;
}
.business01-list h4 {
position: relative;
padding-left: 20px;
}
.business01-list h4::after {
content: "■";
color: #FF9200;
position: absolute;
top: 0;
left: 0;
}
.business01-list img {
border-radius: 50%;
width: 100%;
margin-bottom: 10px;
}
.business01-list p {
font-size: 14px;
}
.business02 ol,
.business04 ol {
display: flex;
flex-wrap: wrap;
justify-content: center;
padding-top: 30px;
padding-bottom: 50px;
}
.business02 ol li,
.business04 ol li {
width: 154px;
height: 154px;
background-color: #FFDAA5;
border-radius: 50%;
position: relative;
list-style: none;
margin-right: 60px;
}
.business02 ol li:nth-child(4),
.business02 ol li:last-child,
.business04 ol li:nth-child(3),
.business04 ol li:last-child {
margin-right: 0;
}
.business02 ol li p.txt, 
.business04 ol li p.txt {
font-size: 22px;
text-align: center;
color: #FF9900;
padding-top: 45px;
}
.business02 ol li .number, 
.business04 ol li .number {
position: absolute;
font-size: 87px;
font-family: 'Neuton', serif;
top: -60px;
left: 50%;
transform: translate(-50%, 0);
-webkit-transform: translate(-50%, 0);
-ms-transform: translate(-50%, 0);
}
.business02 ol li.space,
.business04 ol li.space {
width: 100%;
background: none;
height: 10px;
} 

/*========= company =========*/
#company {
background-image: url("../images/bg_business.jpg");
background-repeat: no-repeat;
background-size: cover;
padding: 60px 0;
}
#company table {
border: 1px solid;
background-color: #fff;
font-size: 17px;
width: 1100px;
margin: 0 auto;
border-collapse: 0;
  border-spacing: 0;
}
#company table th,
#company table td {
padding: 15px;
border-bottom: 1px solid #BBBBBB;
}
#company table th {
background-color: #FFEBD5;
}


/*========= contact =========*/
#contact {
padding: 40px 0;
}
#contact p {
text-align: center;
}
#contact p.tel {
font-size: 48px;
}
#contact p.tel span {
font-size: 28px;
}
#contact p.txt-s {
font-size: 16px;
}

/*========= aside =========*/
aside  {
margin-bottom: 30px;
}
aside img {
width: 300px;
border: 1px solid #333;
}


/*========= footer =========*/
footer {
background-image: url("../images/bg_footer.jpg");
background-repeat: no-repeat;
background-size: 100% auto;
height: 200px;
text-align: center;
box-sizing: border-box;
padding: 30px;
}
footer p {
text-align: center;
font-size: 10px;
color: #fff;
}


.global_nav_sp {
    display: none;
}

/* ====================== TABLET ====================== */
@media screen and (min-width:768px) and (max-width:1300px) {
/*========= BASE =========*/
.inner {
    width: 90%;
}
header .global_nav_pc ul li {
    width: 132px;
    font-size: 17px;
}

/*========= header =========*/
header h1 img {
    width: 200px;
}

/*========= mainvisual =========*/
.mainvisual .copy {	
    bottom: 36%;
}
.mainvisual .copy span {
    line-height: 56px;
    font-size: 21px;
}

/*========= news =========*/
#news dl {
width: 100%;
display: block;
}

#news dl dt,
#news dl dd {
width: 100%;
}
#news dl dt {
border: none;
padding: 10px 5px 0 5px;
}
#news dl dd {
padding: 10px 5px 20px 5px;
}
/*========= business =========*/
#business .inner {
height: auto;
    padding-top: 51px;
}
#business .deco-txt {
    top: -64px;
    left: 50%;
    font-size: 99px;
    letter-spacing: 5px;
}

#business .img-c img {
    width: 80%;
}
.business01-list li {
	width: 20%;
    margin-right: 40px;
}

.business01-list li h4 {
	font-size: 14px;
}

.business01-list li p {
	font-size: 12px;
}

.business02 ol {
    padding-bottom: 30px;
}
.business02 ol li, 
.business04 ol li {
    width: 100px;
    height: 100px;
}
.business02 ol li .number,
.business04 ol li .number {
    font-size: 67px;
    top: -46px;
}
.business02 ol li p.txt,
.business04 ol li p.txt {
    font-size: 15px;
    padding-top: 35px;
}

/*========= company =========*/
#company table {
    width: 100%;
}

}



/* ====================== SP ====================== */
@media screen and (max-width: 767px){
/*========= BASE =========*/
html {
width: 100%;
font-size: 14px;
}
.inner {
width: 90%;
margin: 0 auto;
}
h2 {
font-size: 18px;
}
h2 span {
font-size: 13px;
}
h2::before {
    width: 30px;
    height: 30px;
    top: 21px;
}
h3 {
font-size: 17px;
margin-bottom: 15px;
}
.lead {
    font-size: 13px;
}
.sp {
display: block;
}
.pc {
display: none;
}
#business-link,
#company-link,
#contact-link {
padding-top: 65px;
margin-top:-65px;
}

	/*========= header =========*/
	header {
	padding: 0;
    height: 59px;
	}
    header h1 img {
        display:none;
    }
	header .global_nav_pc {
	display: none;
	}
	header .global_nav_sp {
		border-top: 5px solid #FF9900;
		width: 100%;
		height: 65px;
		display: block;
		position: fixed;
		top: 0;
		left: 50%;
		transform: translateX(-50%);
		background: #fff url(../images/bg_board.jpg) repeat-x top left;;
		background-size: auto 7px;
		z-index: 9999;
	}
	header .global_nav_sp .logo_sp {
		display: inline-block;
		position: relative;
	    z-index: 3;
	}
	header .global_nav_sp .logo_sp img {
    width: 217px;
    height: auto;
    margin: 13px 0 17px 12px;
	}
	header .global_nav_sp.smaller {
		height: 65px;
	}
	header .global_nav_sp .menu_sp {
    	width: 100%;
		height: calc(100vh - 110px);
		display: none;
		position: fixed;
    	top: 60px;
    	right: 0;
		background: rgba(255,255,255,0.5);
    	z-index: 1;
    	overflow-y: scroll!important;
    	-webkit-overflow-scrolling: touch;
    	overflow-scrolling: touch;
		padding-bottom: 180px;
		box-sizing: border-box;
		z-index: 9999;
	}
	.menu_sp > ul {
	    background: rgba(255,255,255,0.9);
	}
	header .global_nav_sp .menu_sp ul li a {
		height: 45px;
		display: block;
		position: relative;
		color: #333;
		font-size: 1em;
		font-weight: 500;
		line-height: 1.3;
		text-decoration: none;
		border-top: 1px solid rgba(188,197,192,0.5);
		padding: 14px 40px 14px 10px;
		box-sizing: border-box;
	}
	header .global_nav_sp .menu_sp ul li:last-child a {
		border-bottom: 1px solid rgba(188,197,192,0.5);
	}
	.menu_sp ul li a:after {
		width: 6px;
		height: 8px;
		display: block;
		content: "";
		position: absolute;
		top: 50%;
		right: 10px;
		transform: translateY(-50%);
		background: url(../images/arrow_r_bk.svg) no-repeat top left;
		background-size: contain;
	}
	.menu_sp.fix {
		display: block;
	}
	/*==== accordion.js ====*/
	.menu_sp ul > li > h3 + ul {
		display: none;
	}
	.menu_sp ul > li > h3 {
		height: 45px;
    	display: block;
    	position: relative;
    	color: #333;
		font-size: small;
		font-weight: 500;
		line-height: 1.3;
    	text-decoration: none;
    	border-top: 1px solid rgba(188,197,192,0.5);
    	padding: 14px 40px 14px 30px;
    	box-sizing: border-box;
	}
	.menu_sp ul > li > h3:after {
		width: 8px;
		height: 11px;
		display: block;
		content: "";
		position: absolute;
		top: 50%;
		left: 13px;
		transform: translateY(-50%);
		background: url(../images/arrow_r_pk.svg) no-repeat top left;
		background-size: contain;
		transition: .6s;
	}
	.menu_sp ul > li > h3.open:after {
		transform: translateY(-50%) rotate(90deg);
	}
	.menu_sp ul > li:nth-child(2) > ul > li:nth-child(4) {
		display: none;
	}

	/*==== menu.js ====*/
	.toggle {
		position: absolute;
		top: 5px;
		right: 5px;
		width: 50px;
		height: 60px;
		transition: all .7s ease;
		cursor: pointer;
		z-index: 2;
	}
	.bar {
		position: relative;
		top: 15px;
		right:0;
		display: block;
		height: 2px;
		width: 33px;
		background: #000;
		margin: 6px auto;
		transition: all .7s ease;
		z-index: 2;
	}
	.smaller .bar{
		background: #000;
	}
	.middle {
		margin: 0 auto;
	}
	.toggle.on .top {
		-webkit-transform: translateY(8px) rotateZ(45deg);
		transform: translateY(8px) rotateZ(45deg);
	}
	.toggle.on .bottom {
		-webkit-transform: translateY(-8px) rotateZ(-45deg);
		transform: translateY(-8px) rotateZ(-45deg);
	}
	.toggle.on .middle {
		width: 0;
	}
	
/*========= mainvisual =========*/
.mainvisual .copy {
    left: 5%;
    bottom: 15%;
    -ms-writing-mode: normal;
    writing-mode: horizontal-tb;
}
	.mainvisual .copy span {
    font-size: 16px;
    line-height: 41px;
}

/*========= news =========*/
#news .inner {
     padding-bottom: 0; 
}

#news dl {
width: 100%;
display: block;
height: 200px;
margin-bottom: 30px;
}

#news dl dt,
#news dl dd {
width: 100%;
}
#news dl dt {
border: none;
padding: 10px 5px 0 5px;
}
#news dl dd {
padding: 10px 5px 20px 5px;
}

/*========= business =========*/
#business {
    padding: 30px 0;
}
#business .inner {
    margin-top: 20px;
    margin-bottom: 20px;
    padding-top: 30px;
	height: auto;
}
#business .inner .mb50 {
   margin-bottom: 30px;
}
#business h2 {
    margin-bottom: 10px;
	padding-top: 30px;
}
#business h2::before {
    top: 2px;
}
#business .deco-txt {
font-size: 40px;
top: -24px;
font-family: 'Roboto', sans-serif;
letter-spacing: 5px;
}
#business .img-c img {
    width: 80%;
    height: auto;
    margin-bottom:0;
}
#business .copy {
    font-size: 15px;
    letter-spacing: 2px;
}
#business .img-wrap, #business .txt-wrap {
    height: auto;
    width: 90%;
	margin: 0 auto;
}
.business01,
.business02 {
height: auto;
margin-bottom: 30px;
}
.business01,
.business02 {
height: auto;
width: 100%;
}
#business .business01 .inner,
#business .business02 .inner{
padding-top: 0;
}
#business .lead {
    margin-bottom: 15px;
}
.business01-list {
    justify-content: space-between;
}
.business01-list li {
    width: 46%;
    margin-right: 0;
	margin-bottom: 10px;
}
.business01-list h4 {
    font-size: 14px;
}
.business01-list li p {
    font-size: 12px;
}
.business01 ul li.space {
    display: none;
}

.business01 p.mb30, 
.business02 p.mb30 {
margin-bottom: 10px;
}
.business02 .flex.mb80 {
    margin-bottom: 40px;
}
.business02 ol,
.business04 ol {
   padding-bottom: 30px;
}
.business02 ol li,
.business04 ol li {
    width: 65px;
    height: 65px;
    margin-right: 10px;
}
.business02 ol li:nth-child(4),
.business04 ol li:nth-child(4) {
    margin-right: 0;
}
.business02 ol li:last-child,
.business04 ol li:last-child {
    margin-right: 0;
}
.business02 ol li .number, 
.business04 ol li .number {
    font-size: 40px;
    top: -28px;
}
.business02 ol li p.txt, 
.business04 ol li p.txt {
    font-size: 10px;
    padding-top: 18px;
    line-height: 1.2;
}
#business .business04 .img-c img {
width: 100%;
height: auto;
}


/*========= company =========*/
#company {
    padding: 0 0 50px 0;
}
#company table,
#company table th,
#company table tr,
#company table td {
display: block;
    width: 100%;
	font-size: 14px;
}
#company table tr:last-child td {
    border-bottom: none;
}

/*========= contact =========*/
#contact {

    padding: 0 0 50px 0;
}
#contact p.tel {
    font-size: 28px;
}
#contact p.tel span {
    font-size: 18px;
}
#contact p.txt-s {
    font-size: 12px;
}
#contact p.txt-s.mb50 {
   margin-bottom: 30px;
}

/*========= aside =========*/
aside  {
margin-bottom: 30px;
}
aside img {
width: 200px;
}


/*========= footer =========*/
footer {
background-size: cover;
height: 100px;
}
}



/*▼▼▼下層ページ▼▼▼*/
#news-page .mainvisual, 
#recruit-page .mainvisual {
background-image: url(../images/bg_footer.jpg);
background-repeat: no-repeat;
background-size: 100% auto;
height: 100px;
box-sizing: border-box;
padding: 30px;
margin-bottom: 30px;
}
@media screen and (max-width: 767px){
#news-page .mainvisual, 
#recruit-page .mainvisual {
background-size: auto 100%;
}
}

/*========= bread =========*/
.bread ol {
    display: flex;
    margin-bottom: 50px;
}
.bread ol li {
    list-style: none;
}
.bread ol li:last-child:after {
    display: none;
}
.bread ol li:after {
    content: "/";
    display: inline-block;
    padding: 0 10px;
}

/*========= recruit-article =========*/
.recruit-article .inner {
margin-bottom: 50px;
}
.recruit-article table {
border: 1px solid;
background-color: #fff;
font-size: 17px;
width: 1100px;
margin: 0 auto;
border-collapse: 0;
  border-spacing: 0;
margin-bottom: 20px;
}
.recruit-article table th,
.recruit-article table td {
padding: 15px;
border-bottom: 1px solid #BBBBBB;
}
.recruit-article table th {
background-color: #FFEBD5;
}
@media screen and (min-width:768px) and (max-width:1300px) {
.recruit-article .img-c img,
.recruit-article table {
width: 100%;
}
}
@media screen and (max-width: 767px){
.recruit-article .img-c img {
width: 100%;
}
.recruit-article table {
width: 100%;
font-size: 16px;
}
.recruit-article table th {
padding: 10px;
}
.recruit-article table tr,
.recruit-article table th,
.recruit-article table td {
width: 100%;
display: block;
}
}

/*========= news-article =========*/
.news-article .inner {
margin-bottom: 50px;
}
.news-article h2 {
padding-top: 0;
font-size: 25px;
}
.news-article h2::before {
    display: none;
}
.news-article p {
    padding-bottom: 10px;
	font-size: 14px;
}
.btn_more a {
display: block;
width: 200px;
margin: 0 auto;
padding: 10px;
text-align: center;
background-color: #FF9900;
color: #fff;	
}
@media screen and (max-width: 767px){
.news-article .img-c img {
width: 100%;
}
.news-article h2 {
font-size: 18px;
}
}

