@charset "utf-8";

/* -----------------------------------------------------------
	contents-wrap
-------------------------------------------------------------- */
.contents-wrap{
    display: flex;
    justify-content: space-between;
}
.contents-right {
	padding: 0 0 0;
	width: 920px;
}
.contents-left {
	padding: 0 0 50px;
	width: 230px;
}

@media screen and (max-width: 768px) {
    .contents-wrap{
        flex-direction: column;
        justify-content: flex-start;
        gap: 0;
    }
    .contents-right {
		padding: 0;
		width: auto;
		margin: 10px 20px 50px;
	}
	 .contents-left {
		padding: 0;
		width: 100%;
	}
}

/* -----------------------------------------------------------
	contents-nav
-------------------------------------------------------------- */

/*pc only*/
@media screen and (min-width: 769px) {
    #c-outline .is-fix {
		position: fixed;
		top: 130px;
        width: 230px;
	}
	
	#c-outline .is-opacity {
		opacity: 0;
		display: none;
	}
}

/*sp*/
/*@media screen and (max-width: 768px){

	#c-outline .contents-nav p{
		padding: 0 0 5px;
		margin: 0 0 15px;
	}
	#c-outline .contents-nav ul {
		display: flex;
		flex-wrap: wrap;
	}
	#c-outline .contents-nav ul li{
        font-size: 1.7rem;
		display: block;
		margin: 0 10px 10px 0;
	}
	#c-outline .contents-nav ul li a{
		display: block;
		padding: 10px 15px 11px;
	}
}*/


/* -----------------------------------------------------------
 	 contents-left contents-nav
-------------------------------------------------------------- */
.contents-left .contents-nav .nav-ling-ttl a.link{
	display: block;
	margin: 0 0 5px;
	border-radius: 10px;
    padding: 20px;
    font-size: 1.7rem;
    font-weight: 500;
	background-color: #f4f5f7;
    position: relative;
	line-height: 1.4;
}
.contents-left .contents-nav .nav-ling-ttl a.link::before{
	content: "";
	width: 28px;
	height: 6px;
	background: url("../img/arrow-g-small.svg") no-repeat center / contain;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 15px;
	margin: auto 0;
	transition: .5s;
}
.contents-left .contents-nav .nav-ling-ttl a.link:hover::before{
	right: 10px;
}
.contents-left .contents-nav .nav-ling-ttl a.link.outline::before{
	display: none;
}
.contents-left .contents-nav .nav-ling-ttl a.link.outline{
	background: var(--main);
	color: #fff;
}
.contents-left .contents-nav ul li a{
    display: flex;
    flex-direction: column;
    padding: 10px 0 10px 40px;
    font-size: 1.9rem;
    font-weight: 500;
    position: relative;
}
.contents-left .contents-nav ul li:last-child a{
    margin: 0 0 15px;
}
.contents-left .contents-nav ul li a.is-active{
    color: var(--main);
}
.contents-left .contents-nav ul li a::before{
    content: "";
	display: block;
	width: 9px;
	height: 9px;
	border: 1px solid var(--main);
	border-radius: 50%;
	position: absolute;
	top: 1.45rem;
	left: 15px;
}
.contents-left .contents-nav ul li a::after{
    content: "";
	display: block;
	width: 9px;
	height: 9px;
	border: 1px solid var(--main);
	background-color: var(--main);
	border-radius: 50%;
	position: absolute;
	top: 1.45rem;
	left: 15px;
	transform: scale(0, 0);
	transition: transform ease 0.5s;
}
.contents-left .contents-nav ul li a.is-active::after{
    transform: scale(1.1, 1.1);
}
    
@media screen and (max-width: 768px){
	.contents-left .contents-nav{
		margin: 0;
		background-color: var(--sub-blue);
		padding: 20px 20px;
	}
	.contents-left .contents-nav .nav-ling-ttl a.link{
		display: block;
		margin: 0 0 10px;
		border-radius: 10px;
		padding: 15px;
		font-size: 1.7rem;
		font-weight: 500;
		background-color: #fff;
		position: relative;
	}
	.contents-left .contents-nav .nav-ling-ttl a.link::before{
		content: "";
		width: 28px;
		height: 6px;
		background: url("../img/arrow-g-small.svg") no-repeat center / contain;
		position: absolute;
		top: 0;
		bottom: 0;
		right: 15px;
		margin: auto 0;
		transition: .5s;
	}
	.contents-left .contents-nav .nav-ling-ttl a.link:hover::before{
		right: 10px;
	}
	.contents-left .contents-nav .nav-ling-ttl a.link.outline::before{
		display: none;
	}
	.contents-left .contents-nav .nav-ling-ttl a.link.outline{
		background: var(--main);
		color: #fff;
		margin: 0;
		border-radius: 10px 10px 0 0;
	}
	.contents-left .contents-nav .nav-ttl{
		font-size: 2rem;
		text-align: center;
		font-family: var(--en-font);
		color: #fff;
		font-weight: 500;
		margin: 0 0 10px;
		line-height: 1;
	}
	.contents-left .contents-nav ul{
		width: 100%;
		margin: 0 auto 10px;
		padding: 5px 0;
		background: var(--main);
		border-radius: 0 0 10px 10px;
	}
	.contents-left .contents-nav ul li{
		width: calc(100% - 20px);
		height: auto;
		margin: 0 auto;
	}
	.contents-left .contents-nav ul li a{
		width: 100%;
		height: auto;
		color: #333;
		display: flex;
		justify-content: flex-start;
		flex-direction: row;
		font-size: 1.6rem;
		padding: 15px;
		background-color: #fff;
		border-radius: 10px;
		margin: 0 0 3px;
		position: inherit;
	}
	.contents-left .contents-nav ul li a::before{
		content: "\f078";
		display: inline-block;
		width: auto;
		height: auto;
		font-weight: 600;
		font-family: "Font Awesome 5 Free";
		padding: 1px 8px 0 0;
		font-size: 1.8rem;
		vertical-align: middle;
		border: none;
		position: inherit;
	}
	.contents-left .contents-nav ul li a::after{
		display: none;
	}

}


/* -----------------------------------------------------------
 	 contents-right
-------------------------------------------------------------- */
.contents-right .com-box{
    margin: 0 0 100px;
}
.contents-right .com-box:last-child{
    margin: 0;
}

.contents-right .titlebox{
    text-align: left;
}

@media screen and (max-width: 768px){
    
    .contents-right .com-box{
        margin: 0 0 50px;
    }

    .contents-right .titlebox{
        text-align: left;
    }
}
/* -------------------------
 	 経営理念　philodophy
------------------------- */

@media screen and (max-width: 768px){
    
}


/* -------------------------
 	 経営方針　policy
------------------------- */
.contents-right #policy.com-box li{
	border-bottom: 1px #e2e2e2 solid;
	padding: 10px 0 12px;
	position: relative;
}
.contents-right #policy.com-box li:first-of-type{
	border-top: 1px #e2e2e2 solid;
}
.contents-right #policy.com-box .catch{
	font-size: 2.4rem;
	padding: 10px 0;
	margin: 0 0 0 20px;
	line-height: 1.2;
}
.contents-right #policy.com-box .sub-list{
	padding: 4px 0 2px 0;
}
.contents-right #policy.com-box .sub-list li{
	border: none;
	font-size: 1.8rem;
	font-weight: 500;
	margin: 0 0 0 20px;
	padding: 0 0 10px 0;
}
.contents-right #policy.com-box .sub-list li:first-of-type{
	border: none;
}
.contents-right #policy.com-box .sub-list ::before{
	content: "";
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background-color: var(--main);
	vertical-align: middle;
	margin: -5px 7px 0 7px;
}

.pdf-link {
	position: absolute;
	left: 300px;
	top: 15px;
	z-index: 1;
}
.pdf-link a {
	padding: 5px;
	display: inline-block;
}
.pdf-link a:hover {
	color:var(--main);
}
.pdf-link a::before {
	display: inline-block;
	margin: 0 8px 0 0;
	content: "\f1c1";
	font-family: 'Font Awesome 5 Free';
	font-size: 1.5rem;
	font-weight: bold;
	color: var(--main);
}

@media screen and (max-width: 768px){
    .contents-right #policy.com-box .catch{
		font-size: 2.0rem;
		padding: 10px 0;
	}
	.contents-right #policy.com-box .sub-list li{
		font-size: 1.6rem;
	}
	.contents-right #policy.com-box .sub-list ::before{
		width: 5px;
		height: 5px;
		margin: -5px 7px 0 7px;
	}
	
	.pdf-link {
		position: static;
		left: auto;
		top: auto;
		margin: -5px 0 0;
		padding: 0 0 0 20px;
	}

}




/* -------------------------
 	 概要　outline
------------------------- */
.contents-right .com-box.outline .table{
	width: 100%;
	border-collapse: collapse;
	font-size: 1.6rem;
	line-height: 1.5;
	border-top: 1px #e2e2e2 solid;
	/*margin: 0 0 50px;*/
}
.contents-right .com-box.outline .table tr {
	border-bottom: 1px #e2e2e2 solid;
}
.contents-right .com-box.outline .table tr th{
	border-bottom: 1px #e2e2e2 solid;
	font-weight: 500;
	padding: 15px;
	width: 170px;
	line-height: 1.7;
	vertical-align: top;
	text-align: left;
}
.contents-right .com-box.outline .table tr td span.ruby {
	font-size: 1.0rem;
}
.contents-right .com-box.outline .table tr td.list{
	display: flex;
    gap: 0 50px;
    font-size: 1.4rem;
	padding: 15px 0 15px 15px;
}
.contents-right .com-box.outline .table tr td.list ul:nth-child(-n+2){
	flex-shrink: 0;
}
.contents-right .com-box.outline .table tr td.list li{
	margin: 0 0 8px;
	line-height: 1.3;
}
.contents-right .com-box.outline .table tr td.list li:last-of-type{
	margin: 0;
}

.system .system-list {
	display: flex;
}
.system .system-list dt,
.system .system-list dd {
	padding: 1px 0;
	line-height: 1.5;
}
.system .system-list dt{
	width: 145px;
	white-space: nowrap;
}

@media screen and (max-width: 768px){
	
    .contents-right .com-box.outline .table tr th{
        border-bottom: none;
        padding: 10px 0 0;
        width: 100%;
        display: block;
    }
    .contents-right .com-box.outline .table tr td{
        padding: 0 0 10px;
        width: 100%;
        display: block;
    }
    .contents-right .com-box.outline .table tr td span.ruby {
        font-size: 1.0rem;
    }
    .contents-right .com-box.outline .table tr td.list{
        flex-direction: column;
        gap: 0;
        font-size: 1.6rem;
        line-height: 1.5;
    }
}


/* -------------------------
 	 組織図　chart
------------------------- */
.contents-right .com-box.chart .img {
	width: 800px;
}
.contents-right .com-box.chart .img img{
	width: 100%;
}

@media screen and (max-width: 768px){
	.contents-right .com-box.chart .contents-box{
		overflow-x: scroll;
	}
	.contents-right .com-box.chart .img {
		width: 500px;
	}
	.contents-right .com-box.chart .img img{
		max-width: inherit;
	}
}


/* -------------------------
 	 沿革　history
------------------------- */
.contents-right .com-box.history dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.contents-right .com-box.history dl dt {
    text-align: left;
    width: 9em;
    padding: 15px 20px 10px 0;
    position: relative;
    flex-shrink: 0;
}

.contents-right .com-box.history dl dt::after {
    content: '●';
    position: absolute;
    right: -0.55em;
    top: 13px;
    font-size: 1.5rem;
    color: var(--main);
}

.contents-right .com-box.history dl dd {
    width: calc(100% - 9em);
    padding: 10px 30px 30px;
    border-left: 2px solid #ccc;
    line-height: 1.7;
}

.contents-right .com-box.history dl dd:last-child {
    padding-bottom: 20px;
}

@media screen and (max-width: 768px){
    
    .contents-right .com-box.history dl {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }

    .contents-right .com-box.history dl dt {
        text-align: left;
        width: 9em;
        padding: 15px 20px 10px 0;
        position: relative;
        flex-shrink: 0;
    }

    .contents-right .com-box.history dl dt::after {
        content: '●';
        position: absolute;
        right: -0.55em;
        top: 13px;
        font-size: 1.5rem;
        color: var(--main);
    }

    .contents-right .com-box.history dl dd {
        width: calc(100% - 9em);
        padding: 10px 30px 30px;
        border-left: 2px solid #ccc;
        line-height: 1.7;
    }

    .contents-right .com-box.history dl dd:last-child {
        padding-bottom: 20px;
    }

    
    .contents-right .com-box.history dl dt {
        width: 8.5em;
    }
    .contents-right .com-box.history dl dd {
        width: calc(100% - 8.5em);
        padding: 10px 0 30px 20px;
    }
}





