@charset "utf-8";

/* company */


/* header
----------------------------------------- */
.page-visual-area::after {
	background: url(page-visual_sp0.jpg) center center no-repeat;
	background-size: cover;
}


/* contents
----------------------------------------- */
/* profile-sec */
.profile-sec {
	margin-bottom: 80px;
}
.profile-sec .sec-ttl {
	position: relative;
	margin-bottom: 32px;
	padding-bottom: 80px;
}
.profile-sec .sec-ttl::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1px;
	height: 50px;
	margin: 0;
	background-image: linear-gradient(to bottom, #232584, #232584 1px, transparent 1px, transparent 3px);
	background-size: 2px 3px;
	background-repeat: repeat-y;
}
.profile-sec-inner {
}
.profile-sec-inner-left {
	margin-bottom: 80px;
}
.profile-sec-inner-right {
}

.profile-sec-inner-ttl {
	margin-bottom: 35px;
	text-align: center;
}
.profile-sec-inner-ttl .num {
	position: absolute;
	top: -12px;
	left: -14px;
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 700;
	font-size: 1.3rem;
	letter-spacing: 0.02em;
	color: #232584;
}
.profile-sec-inner-ttl .jpn {
	position: relative;
	display: inline-block;
	margin-bottom: 8px;
	font-size: 2.2rem;
	line-height: 1.3;
}
.profile-sec-inner-ttl .eng {
	display: block;
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 400;
	font-size: 1.0rem;
	line-height: 1.3;
	letter-spacing: 0.04em;
	color: #232584;
}

.profile-list {
	padding: 0 30px;
}
.profile-list li {
	margin-bottom: 18px;
	padding: 0 10px 18px;
	border-bottom: 1px solid #E3E3E3;
	font-size: 1.3rem;
	line-height: 1.6;
}
.profile-list li:last-child {
	
}
.profile-list-ttl {
	margin-bottom: 5px;
}
.profile-list-cont {
	color: #666;
}

/* access-sec */
.access-sec {
	margin-bottom: 70px;
}
.access-sec .sec-ttl {
	position: relative;
	margin-bottom: 32px;
	padding-bottom: 80px;
}
.access-sec .sec-ttl::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1px;
	height: 50px;
	margin: 0;
	background-image: linear-gradient(to bottom, #232584, #232584 1px, transparent 1px, transparent 3px);
	background-size: 2px 3px;
	background-repeat: repeat-y;
}
.access-map {
	margin-bottom: 20px;
}
.gmap {
	padding: 0;
}
.gmap iframe {
	width: 100%;
	height: 400px;
	vertical-align: bottom
}
.access-map-link {
	margin-bottom: 15px;
	padding: 0 30px;
}
.access-map-link a {
	position: relative;
	padding-right: 65px;
	color: #232584;
	font-size: 1.3rem;
}
.access-map-link a::before {
	display: block;
	content: '';
	position: absolute;
	top: 10px;
	right: 21px;
	width: 30px;
	height: 1px;
	background-color: #232584;
}
.access-map-link a::after {
	display: block;
	content: '';
	position: absolute;
	top: 10px;
	right: 21px;
	width: 7px;
	height: 1px;
	background-color: #232584;
	transform-origin: right bottom;
	transform: rotate(40deg);
}
.access-sec-info {
	padding: 0 30px;
}
.access-sec-info a {
	color: #111;
}
.company-name {
	margin-bottom: 12px;
	font-size: 1.6rem;
	line-height: 1.6;
}	
.company-info {
	font-size: 1.3rem;
	color: #666;
	line-height: 1.8;
}
.company-info a {
	color: #666;
}

/* slide-img-area */
.slide-img01 {
	width: 100%;
}
.slide-img01 li {
	width: 320px !important;
	height: auto;
}
.slide-img01 img {
	width: 320px !important;
	height: auto;
}
















































/* tablet 560px - 959px */
@media only screen and (min-width: 560px) {

/* header
----------------------------------------- */
.page-visual-area::after {
	background: url(page-visual_pc0.jpg) center center no-repeat;
	background-size: cover;
}


/* contents
----------------------------------------- */
/* profile-sec */
.profile-sec {
	margin-bottom: 100px;
}
.profile-sec .sec-ttl {
	position: relative;
	margin-bottom: 42px;
	padding-bottom: 80px;
}
.profile-sec .sec-ttl::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1px;
	height: 50px;
	margin: 0;
	background-image: linear-gradient(to bottom, #232584, #232584 1px, transparent 1px, transparent 3px);
	background-size: 2px 3px;
	background-repeat: repeat-y;
}
.profile-sec-inner {
}
.profile-sec-inner-left {
	margin-bottom: 100px;
}
.profile-sec-inner-right {
}

.profile-sec-inner-ttl {
	margin-bottom: 45px;
	text-align: center;
}
.profile-sec-inner-ttl .num {
	position: absolute;
	top: -12px;
	left: -14px;
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 700;
	font-size: 1.3rem;
	letter-spacing: 0.02em;
	color: #232584;
}
.profile-sec-inner-ttl .jpn {
	position: relative;
	display: inline-block;
	margin-bottom: 8px;
	font-size: 2.8vw;
	line-height: 1.3;
}
.profile-sec-inner-ttl .eng {
	display: block;
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 400;
	font-size: 1.0rem;
	line-height: 1.3;
	letter-spacing: 0.04em;
	color: #232584;
}

.profile-list {
	width: 80%;
	margin: 0 auto;
	padding: 0;
}
.profile-list li {
	display: flex;
	margin-bottom: 22px;
	padding: 0 10px 22px;
	border-bottom: 1px solid #E3E3E3;
	font-size: 1.3rem;
	line-height: 1.6;
}
.profile-list li:last-child {
	
}
.profile-list-ttl {
	width: 8em;
	margin: 0 2em 0 0;
}
.profile-list-cont {
	width: calc(100% - 10em);
	color: #666;
}

/* access-sec */
.access-sec {
	width: 80%;
	margin: 0 auto 90px;
}
.access-sec .sec-ttl {
	position: relative;
	margin-bottom: 42px;
	padding-bottom: 80px;
}
.access-sec .sec-ttl::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1px;
	height: 50px;
	margin: 0;
	background-image: linear-gradient(to bottom, #232584, #232584 1px, transparent 1px, transparent 3px);
	background-size: 2px 3px;
	background-repeat: repeat-y;
}
.access-map {
	margin-bottom: 20px;
}
.gmap {
	padding: 0;
}
.gmap iframe {
	width: 100%;
	height: 400px;
	vertical-align: bottom
}
.access-map-link {
	margin-bottom: 15px;
	padding: 0;
	text-align: right;
}
.access-map-link a {
	position: relative;
	padding-right: 65px;
	color: #232584;
	font-size: 1.3rem;
}
.access-map-link a::before {
	display: block;
	content: '';
	position: absolute;
	top: 10px;
	right: 21px;
	width: 30px;
	height: 1px;
	background-color: #232584;
}
.access-map-link a::after {
	display: block;
	content: '';
	position: absolute;
	top: 10px;
	right: 21px;
	width: 7px;
	height: 1px;
	background-color: #232584;
	transform-origin: right bottom;
	transform: rotate(40deg);
}
.access-sec-info {
	padding: 0;
}
.access-sec-info a {
	color: #111;
}
.company-name {
	margin-bottom: 12px;
	font-size: 1.8rem;
	line-height: 1.6;
}
.company-name .br-sp {
	display: none;
}
.company-info {
	font-size: 1.3rem;
	color: #666;
	line-height: 1.8;
}
.company-info a {
	color: #666;
}

/* slide-img-area */
.slide-img01 {
	width: 100%;
}
.slide-img01 li {
	width: 380px !important;
	height: auto;
}
.slide-img01 img {
	width: 380px !important;
	height: auto;
}

} /* tablet end */



















































/* PC 960px - */
@media only screen and (min-width: 960px) {

/* header
----------------------------------------- */
.page-visual-area::after {
	background: url(page-visual_pc0.jpg) center center no-repeat;
	background-size: cover;
}


/* contents
----------------------------------------- */
/* profile-sec */
.profile-sec {
	margin-bottom: 100px;
}
.profile-sec .sec-ttl {
	position: relative;
	margin-bottom: 45px;
	padding-bottom: 108px;
}
.profile-sec .sec-ttl::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1px;
	height: 68px;
	margin: 0;
	background-image: linear-gradient(to bottom, #232584, #232584 1px, transparent 1px, transparent 3px);
	background-size: 2px 3px;
	background-repeat: repeat-y;
}
.profile-sec-inner {
	display: flex;
	width: 87%;
	max-width: 1600px;
	margin: 0 auto;
}
.profile-sec-inner-left {
	width: 46%;
	margin: 0 8% 0 0;
}
.profile-sec-inner-right {
	width: 46%;
}

.profile-sec-inner-ttl {
	margin-bottom: 75px;
	text-align: center;
}
.profile-sec-inner-ttl .num {
	position: absolute;
	top: -12px;
	left: -14px;
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 700;
	font-size: 1.3rem;
	letter-spacing: 0.02em;
	color: #232584;
}
.profile-sec-inner-ttl .jpn {
	position: relative;
	display: inline-block;
	margin-bottom: 10px;
	font-size: 2.8rem;
	line-height: 1.3;
}
.profile-sec-inner-ttl .eng {
	display: block;
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 400;
	font-size: 1.1rem;
	line-height: 1.3;
	letter-spacing: 0.04em;
	color: #232584;
}

.profile-list {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}
.profile-list li {
	display: flex;
	margin-bottom: 24px;
	padding: 0 10px 24px;
	border-bottom: 1px solid #E3E3E3;
	font-size: 1.5rem;
	line-height: 1.6;
}
.profile-list li:last-child {
	
}
.profile-list-ttl {
	width: 9em;
	margin: 0 2em 0 0;
}
.profile-list-cont {
	width: calc(100% - 11em);
	color: #666;
}

/* access-sec */
.access-sec {
	width: 87%;
	margin: 0 auto 135px;
}
.access-sec .sec-ttl {
	position: relative;
	margin-bottom: 45px;
	padding-bottom: 108px;
}
.access-sec .sec-ttl::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1px;
	height: 68px;
	margin: 0;
	background-image: linear-gradient(to bottom, #232584, #232584 1px, transparent 1px, transparent 3px);
	background-size: 2px 3px;
	background-repeat: repeat-y;
}
.access-map {
	margin-bottom: 25px;
}
.gmap {
	padding: 0;
}
.gmap iframe {
	width: 100%;
	height: 500px;
	vertical-align: bottom
}
.access-map-link {
	margin-bottom: 0;
	padding: 0;
	text-align: right;
}
.access-map-link a {
	position: relative;
	padding-right: 65px;
	color: #232584;
	font-size: 1.4rem;
	transition: color .3s;
}
.access-map-link a:hover {
	color: #393CC6;
}
.access-map-link a::before {
	display: block;
	content: '';
	position: absolute;
	top: 11px;
	right: 21px;
	width: 30px;
	height: 1px;
	background-color: #232584;
	transition: all .3s;
}
.access-map-link a:hover::before {
	position: absolute;
	top: 11px;
	right: 16px;
	width: 35px;
}
.access-map-link a::after {
	display: block;
	content: '';
	position: absolute;
	top: 11px;
	right: 21px;
	width: 8px;
	height: 1px;
	background-color: #232584;
	transform-origin: right bottom;
	transform: rotate(40deg);
	transition: right .3s;
}
.access-map-link a:hover::after {
	position: absolute;
	top: 11px;
	right: 16px;
}
.access-sec-info {
	margin-top: -25px;
	padding: 0;
}
.access-sec-info a {
	color: #111;
}
.company-name {
	margin-bottom: 12px;
	font-size: 2.0rem;
	line-height: 1.6;
}
.company-name .br-sp {
	display: none;
}
.company-info {
	font-size: 1.4rem;
	color: #666;
	line-height: 1.8;
}
.company-info a {
	color: #666;
}

/* slide-img-area */
.slide-img01 {
	width: 100%;
}
.slide-img01 li {
	width: 420px !important;
	height: auto;
}
.slide-img01 img {
	width: 420px !important;
	height: auto;
}

} /* PC end */





















































/* PC:1201px - */
@media only screen and (min-width: 1201px) {

} /* PC end */


