@charset "utf-8";


/* common.css
----------------------------------------- */
html {
	font-size: 62.5%;
}
body {
	font-family: YakuHanJP, "Zen Kaku Gothic New", sans-serif;
	font-size: 1.6rem;
	color: var(--c-black);
	line-height: 1.8;
	letter-spacing: 0.06em;
	text-align: left;
	font-weight: 500;
	background-color: var(--c-white);
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
a {
	color: var(--c-black);
	text-decoration: none;
}
a:hover {
	color: var(--c-black);
	text-decoration: none;
}
a:focus {
}
.pc {
	display: none !important;
}
.sp {
	display: block !important;
}
input:focus,
select:focus,
textarea:focus {
}
img {
	width: 100%;
	height: auto;
}
* {
	box-sizing: border-box;
}

/* color */
:root {
  --c-primary-blue: #0168B7;
  --c-primary-blue-hover: #0082E6;
  --c-blue-pale-dark: #E8EEF5;
  --c-blue-pale-light: #F2F7FC;
  --c-black: #000000;
  --c-gray: #999999;
  --c-white: #ffffff;
}
.grecaptcha-badge {
	visibility: hidden;
}


/* common
----------------------------------------- */
/* loading */
#contents-wrap {
	opacity: 0;
	transition: all 1.0s;
	overflow-x: clip;
}
#contents-wrap.fade-in {
	opacity: 1;
}
.loading-img {
	position: fixed;
	top: 50%;
	left: 50%;
	width: 80px;
	height: 80px;
	margin-top: -45px;
	margin-left: -40px;
	text-align: center;
	color: #fff;
	z-index: 2;
	text-align: center;
}
.loading-img img {
	width: 100%;
	height: auto;
}

/* breadcrumbs-area */
.breadcrumbs-area {
}
.breadcrumbs-list {
	display: flex;
	flex-wrap: wrap;
}
.breadcrumbs-list li {
	line-height: 1;
}
.breadcrumbs-list a,
.breadcrumbs-list li span {
	display: inline-block;
	font-size: 1.2rem;
	line-height: 1.6;
}
.breadcrumbs-list a {
	position: relative;
	margin-right: 20px;
}
.breadcrumbs-list li span {
	color: var(--c-primary-blue);
}
.breadcrumbs-list a:hover {
	color: var(--c-primary-blue);
}
.breadcrumbs-list a::before {
	display: block;
	content: '';
	position: absolute;
	top: 50%;
	right: -12px;
	width: 6px;
	height: 1px;
	background-color: var(--c-black);
}

/* ttl */
.section-ttl.vertical-type {
    display: flex;
}
.section-ttl .eng {
    font-family: "Poppins", sans-serif;
    font-size: 1.2rem;
    color: var(--c-primary-blue);
    font-weight: 500;
}
.section-ttl.horizontal .eng {
    letter-spacing: 0.03em;
}
.section-ttl .jpn {
    font-size: 2.2rem;
    letter-spacing: 0.08em;
}
.section-ttl.vertical-type .eng,
.section-ttl.vertical-type .jpn {
    writing-mode: vertical-rl;
    vertical-align: top;
}
/* * sec-ttl_line * */
.sec-ttl_line {
	padding-bottom: 14px;
	margin-bottom: 32px;
	border-bottom: 1px solid var(--c-black);
	font-size: 1.8rem;
	line-height: 1.6;
}
.sec-ttl_line span {
    color: var(--c-primary-blue);
}

/* link */
.sec-btn_black {
	display: inline-block;
	padding: 13px 20px;
	border-radius: 7px;
	background-color: var(--c-black);
	color: var(--c-white);
	font-size: 1.4rem;
	line-height: 1.6;
}
.sec-btn_black:hover {
	color: var(--c-white);
}
.sec-btn_blue-line {
	display: inline-block;
	padding: 13px 24px;
	border-radius: 7px;
	border: 1px solid var(--c-primary-blue);
	color: var(--c-primary-blue);
	font-size: 1.4rem;
	line-height: 1.6;
}
.sec-btn_blue-line:hover {
	color: var(--c-primary-blue);
}

/* text */


/* header
----------------------------------------- */
#header {
	position: relative;
	padding: 8px;
}
.header-logo {
	position: absolute;
	top: 0;
	left: 0;
	padding: 20px 24px 18px 24px;
	border-bottom-right-radius: 8px;
	background-color: var(--c-white);
	z-index: 10;
}
.header-logo::before {
	content: '';
	position: absolute;
	top: 8px;
	right: -8px;
	width: 8px;
	height: 8px;
	background: url(../images/common/logo-bg-r_sp.svg) 0 0 no-repeat;
	background-size: 8px 8px;
}
.header-logo::after {
	content: '';
	position: absolute;
	bottom: -8px;
	left: 8px;
	width: 8px;
	height: 8px;
	background: url(../images/common/logo-bg-r_sp.svg) 0 0 no-repeat;
	background-size: 8px 8px;
}
.header-logo img {
	width: 162px;
	height: auto;
}

/* page-visual-area */
.page-visual-area {
    position: relative;
    margin-bottom: 16px;
}
.page-visual_img {
}
.page-visual_img img {
	border-radius: 8px;
}
.page-visual_ttl-area {
    position: absolute;
    bottom: 40px;
    left: 40px;
    z-index: 10;
}
.page-visual_ttl-area .eng span,
.page-visual_ttl-area .jpn span {
	color: var(--c-primary-blue);
	background-color: var(--c-white);
	border-radius: 7px;
	line-height: 1.4;
	opacity: 0;
	transform: translateY(12px);
	transition: opacity .5s ease, transform .5s ease;
}
.page-visual_ttl-area .eng span {
	transition-delay: .1s;
}
.page-visual_ttl-area .jpn span {
	transition-delay: .2s;
}
.fade-in .page-visual_ttl-area .eng span,
.fade-in .page-visual_ttl-area .jpn span {
	opacity: 1;
	transform: translateY(0);
}
.page-visual_ttl-area .eng {
	margin-bottom: 8px;
}
.page-visual_ttl-area .eng span {
	display: inline-block;
	padding: 6px 14px;
	font-family: "Poppins", sans-serif;
	font-size: 1.8rem;
}
.page-visual_ttl-area .jpn span {
	display: inline-block;
	padding: 4px 14px;
	font-size: 1.3rem;
}

/* header-nav_sp */
.header-nav_sp {
}

/* slide-menu_btn */
.slide-menu_btn {
	position: fixed;
	top: 18px;
	right: 18px;
	z-index: 10000;
}

/* slide-menu_nav */
.slide-menu_nav {
	box-sizing: border-box;
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	padding: 18vh 0 0 0;
	background-color: #fff;
	overflow-y: scroll;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	z-index: 9000;
	opacity: 0;
	visibility: hidden;
	transition: all .3s;
}
.slide-menu_nav.open {
	visibility: visible;
	opacity: 1;
}
.slide-menu_nav-logo {
	position: absolute;
	top: 20px;
	left: 24px;
	width: 162px;
	height: auto;
}
.slide-menu_nav .gnav_sp {
	position: relative;
	margin-bottom: 50px;
	text-align: center;
}
.slide-menu_nav .gnav_sp > li {
	position: relative;
	margin-bottom: 20px;
}
.slide-menu_nav li:last-child {
	margin-bottom: 0;
}
.slide-menu_nav .gnav_sp > li > a {
	position: relative;
	display: inline-block;
	background-color: #F5F8FC;
	border-radius: 7px;
	padding: 12px 18px 12px;
	font-weight: 500;
	line-height: 1.1;
	font-size: 1.5rem;
}
.slide-menu_nav .gnav01 {
	opacity: 0;
	transition: all .6s;
}
.slide-menu_nav .gnav02 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .04s;
}
.slide-menu_nav .gnav03 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .08s;
}
.slide-menu_nav .gnav04 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .12s;
}
.slide-menu_nav .gnav05 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .16s;
}
.slide-menu_nav .gnav06 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .20s;
}
.slide-menu_nav.open .gnav01,
.slide-menu_nav.open .gnav02,
.slide-menu_nav.open .gnav03,
.slide-menu_nav.open .gnav04,
.slide-menu_nav.open .gnav05,
.slide-menu_nav.open .gnav06,
.slide-menu_nav.open .slide-menu_nav_address {
	opacity: 1;
}
#top .gnav01 a,
#service .gnav02 a,
#recruit .gnav03 a,
#company .gnav04 a,
#news .gnav05 a,
#contact .gnav06 a {
	background-color: var(--c-primary-blue);
	color: var(--c-white);
}
.slide-menu_nav_address{
	position: absolute;
	left: 40px;
	bottom: 36px;
	font-size: 1.1rem;
	font-style: normal;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.1em;
	opacity: 0;
	transition: all .6s;
	transition-delay: .24s;
	z-index: -1;
}

/* menu-trigger */
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .3s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background-color: var(--c-primary-blue);
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 16px;
	height: 1px;
	border-radius: 2px;
	background-color: var(--c-white);
}
.menu-trigger.active span {
	background-color: var(--c-white);
}
.menu-trigger span:nth-of-type(1) {
	top: 15px;
	left: 10px;
}
.menu-trigger span:nth-of-type(2) {
	bottom: 15px;
	left: 10px;
}
.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(3px) rotate(-45deg);
	transform: translateY(3px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
	-webkit-transform: translateY(-2px) rotate(45deg);
	transform: translateY(-2px) rotate(45deg);
}


/* contents
----------------------------------------- */
#contents {
	position: relative;
	margin-top: 24px;
}
#contents::before {
	content: '';
	position: absolute;
	top: -100px;
	left: -148px;
	width: 620px;
	height: 492px;
	background: url(../images/common/intro-sec_bg-mark.svg) 0 0 no-repeat;
	background-size: 620px 492px;
	z-index: -10;
}
#top #contents::before {
	display: none;
}
#top #contents {
	margin-top: 0;
}

/* news-sec_list */
.news-sec_list {
    position: relative;
	padding-top: 24px;
}
.news-sec_list::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(to right, var(--c-black) 1px, transparent 1px);
    background-size: 4px 1px;
    background-repeat: repeat-x;
}
.news-sec_list li {
    position: relative;
    margin-bottom: 24px;
    padding-bottom: 20px;
}
.news-sec_list li:last-child {
    margin-bottom: 0;
}
.news-sec_list li::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(to right, var(--c-black) 1px, transparent 1px);
    background-size: 4px 1px;
    background-repeat: repeat-x;
}
.news-sec_meta {
    display: flex;
    align-items: center;
    margin-bottom: 3px;
}
.news-sec_date {
    min-width: 96px;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 1.4rem;
    line-height: 1.4;
    letter-spacing: 0.03em;
    color: var(--c-gray);
}
.news-sec_cat {
    display: inline-block;
    min-width: 72px;
    background-color: var(--c-primary-blue);
    padding: 4px 10px;
    border-radius: 100px;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 1.0rem;
    line-height: 1.3;
    text-align: center;
    letter-spacing: 0.03em;
    color: var(--c-white);
}
.news-sec_ttl {
    font-size: 1.4rem;
    line-height: 1.6;
}

/* qa-list */
.qa-list {
}
.qa-item {
    border: 1px solid var(--c-primary-blue);
    padding: 16px 24px 14px;
    border-radius: 8px;
    margin-bottom: 12px;
}
.qa-item:last-child {
    margin-bottom: 0;
}
.qa-q {
    display: flex;
    margin-bottom: 4px;
    cursor: pointer;
}
.qa-q .label {
    width: 32px;
    font-family: "Poppins", sans-serif;
    font-size: 1.8rem;
    line-height: 1.4;
    color: var(--c-primary-blue);
}
.qa-q .ttl {
    position: relative;
    width: calc(100% - 32px);
    padding-top: 2px;
    padding-right: 24px;
    font-size: 1.3rem;
    line-height: 1.8;
}
.qa-q .ttl::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -4px;
    width: 14px;
    height: 8px;
    margin-top: -3px;
    background: url(../images/common/qa_icon.svg) no-repeat center center;
    background-size: contain;
    transition: rotate .3s;
}
.qa-item.is-open .qa-q .ttl::after {
    rotate: 180deg;
}
.qa-a {
    display: none;
}
.qa-a .label {
    width: 32px;
    font-family: "Poppins", sans-serif;
    font-size: 1.8rem;
    line-height: 1.4;
    color: var(--c-primary-blue);
    transform: translateY(1px);
}
.qa-a .text {
    width: calc(100% - 32px);
    padding-top: 2px;
    padding-right: 24px;
    font-size: 1.3rem;
    line-height: 1.8;
}

/* contact-sec */
.contact-sec {
	position: relative;
	width: calc(100% - 16px);
	margin: 88px auto 8px;
	padding: 56px 8px;
	border-radius: 8px;
	background-color: var(--c-primary-blue);
	overflow: hidden;
}
#top .contact-sec {
	margin-top: 0;
}
.contact-sec::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/common/cta-bg-bottom_sp.png) center center no-repeat;
	background-size: cover;
	z-index: 1;
}
.contact-sec::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/common/cta-bg-top_sp.png) center center no-repeat;
	background-size: cover;
	z-index: 3;
}
.contact-sec_copy-eng {
	display: none;
}
.contact-sec_inner {
	position: relative;
	padding: 48px 20px;
}
.contact-sec_inner::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 8px;
	background-color: var(--c-white);
	z-index: 2;
}
.contact-sec_inner-text {
	position: relative;
	z-index: 10;
}
.contact-sec_ttl-area {
	position: relative;
	margin-bottom: 24px;
	z-index: 10;
	text-align: center;
}
.contact-sec_ttl-area .jpn {
	font-size: 2.6rem;
}
.contact-sec_ttl-area .eng {
	font-size: 1.2rem;
}
.contact-sec_lead {
	margin-bottom: 32px;
	font-size: 1.4rem;
	line-height: 2.0;
	text-align: center;
}
.contact-sec_btn-tel-area {
}
.contact-sec_btn-wrap {
	margin-bottom: 24px;
	text-align: center
}
.contact-sec_btn {
	display: inline-block;
	padding: 20px 40px;
	border-radius: 16px;
	color: var(--c-white);
	background-color: var(--c-primary-blue);
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.6;
}
.contact-sec_btn:hover {
	color: var(--c-white);
}
.contact-sec_tel-area {
	padding: 0 24px;
}
.contact-sec_tel {
	position: relative;
	padding-left: 32px;
	font-size: 3.2rem;
}
.contact-sec_tel-label {
	position: absolute;
	top: 14px;
	left: 0;
	font-family: "Poppins", sans-serif;
	font-size: 1.4rem;
}
.contact-sec_tel-note {
	font-size: 1.1rem;
}
.contact-sec_copy-jpn {
	display: none;
}


/* footer
----------------------------------------- */
#footer {
	width: calc(100% - 16px);
	margin: 0 auto 8px;
	padding: 48px 32px 32px;
	border-radius: 8px;
	border: 1px solid #C7DCEC;
}
.footer-inner {
} 
.footer-nav {
	margin-bottom: 56px;
}
.footer-nav_list {
}
.footer-nav_list li {
	margin-bottom: 16px;
}
.footer-nav_list li:last-child {
	margin-right: 0;
}
.footer-nav_list li a {
	position: relative;
	display: inline-block;
	background-color: #F5F8FC;
	border-radius: 7px;
	padding: 8px 10px;
	font-weight: 500;
	line-height: 1.1;
	font-size: 1.4rem;
}
#top .fnav01 a,
#service .fnav02 a,
#recruit .fnav03 a,
#company .fnav04 a,
#news .fnav05 a,
#contact .fnav06 a {
	background-color: var(--c-primary-blue);
	color: var(--c-white);
}
.footer-logo-area {
	margin-bottom: 56px;
}
.footer-logo {
	display: block;
	width: 180px;
	margin-bottom: 16px;
}
.footer-address {
	font-size: 1.1rem;
}
.footer-copyright {
	font-family: "Poppins", sans-serif;
	text-align: center;
	font-size: 1.0rem;
	letter-spacing: 0.03em;
}




































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

/* common
----------------------------------------- */
/* loading */
#contents-wrap {
	opacity: 0;
	transition: all 1.0s;
}
#contents-wrap.fade-in {
	opacity: 1;
}
.loading-img {
	position: fixed;
	top: 50%;
	left: 50%;
	width: 80px;
	height: 80px;
	margin-top: -45px;
	margin-left: -40px;
	text-align: center;
	color: #fff;
	z-index: 2;
	text-align: center;
}
.loading-img img {
	width: 100%;
	height: auto;
}

/* breadcrumbs-area */
.breadcrumbs-area {
	padding: 0 16px;
}
.breadcrumbs-list {
	display: flex;
	flex-wrap: wrap;
}
.breadcrumbs-list li {
	line-height: 1;
}
.breadcrumbs-list a,
.breadcrumbs-list li span {
	display: inline-block;
	font-size: 1.2rem;
	line-height: 1.6;
}
.breadcrumbs-list a {
	position: relative;
	margin-right: 20px;
}
.breadcrumbs-list li span {
	color: var(--c-primary-blue);
}
.breadcrumbs-list a:hover {
	color: var(--c-primary-blue);
}
.breadcrumbs-list a::before {
	display: block;
	content: '';
	position: absolute;
	top: 50%;
	right: -12px;
	width: 6px;
	height: 1px;
	background-color: var(--c-black);
}

/* ttl */
.section-ttl.vertical-type {
    display: flex;
}
.section-ttl .eng {
    font-family: "Poppins", sans-serif;
    font-size: 1.2rem;
    color: var(--c-primary-blue);
    font-weight: 500;
}
.section-ttl.horizontal .eng {
    letter-spacing: 0.03em;
}
.section-ttl .jpn {
    font-size: 2.2rem;
    letter-spacing: 0.08em;
}
.section-ttl.vertical-type .eng,
.section-ttl.vertical-type .jpn {
    writing-mode: vertical-rl;
    vertical-align: top;
}
/* * sec-ttl_line * */
.sec-ttl_line {
	padding-bottom: 18px;
	margin-bottom: 40px;
	border-bottom: 1px solid var(--c-black);
	font-size: 2.2rem;
	line-height: 1.6;
}
.sec-ttl_line span {
    color: var(--c-primary-blue);
}

/* link */
.sec-btn_black {
	display: inline-block;
	padding: 13px 20px;
	border-radius: 7px;
	background-color: var(--c-black);
	color: var(--c-white);
	font-size: 1.4rem;
	line-height: 1.6;
}
.sec-btn_black:hover {
	color: var(--c-white);
}
.sec-btn_blue-line {
	display: inline-block;
	padding: 13px 24px;
	border-radius: 7px;
	border: 1px solid var(--c-primary-blue);
	color: var(--c-primary-blue);
	font-size: 1.4rem;
	line-height: 1.6;
}
.sec-btn_blue-line:hover {
	color: var(--c-primary-blue);
}

/* text */


/* header
----------------------------------------- */
#header {
	position: relative;
	padding: 8px;
}
.header-logo {
	position: absolute;
	top: 0;
	left: 0;
	padding: 20px 24px 18px 24px;
	border-bottom-right-radius: 8px;
	background-color: var(--c-white);
	z-index: 10;
}
.header-logo::before {
	content: '';
	position: absolute;
	top: 8px;
	right: -8px;
	width: 8px;
	height: 8px;
	background: url(../images/common/logo-bg-r_sp.svg) 0 0 no-repeat;
	background-size: 8px 8px;
}
.header-logo::after {
	content: '';
	position: absolute;
	bottom: -8px;
	left: 8px;
	width: 8px;
	height: 8px;
	background: url(../images/common/logo-bg-r_sp.svg) 0 0 no-repeat;
	background-size: 8px 8px;
}
.header-logo img {
	width: 162px;
	height: auto;
}

/* page-visual-area */
.page-visual-area {
    position: relative;
    margin-bottom: 16px;
}
.page-visual_img {
}
.page-visual_img img {
	border-radius: 8px;
}
.page-visual_ttl-area {
    position: absolute;
    bottom: 40px;
    left: 40px;
    z-index: 10;
}
.page-visual_ttl-area .eng span,
.page-visual_ttl-area .jpn span {
	color: var(--c-primary-blue);
	background-color: var(--c-white);
	border-radius: 7px;
	line-height: 1.4;
}
.page-visual_ttl-area .eng {
	margin-bottom: 8px;
}
.page-visual_ttl-area .eng span {
	display: inline-block;
	padding: 6px 14px;
	font-family: "Poppins", sans-serif;
	font-size: 1.8rem;
}
.page-visual_ttl-area .jpn span {
	display: inline-block;
	padding: 4px 14px;
	font-size: 1.3rem;
}

/* header-nav_sp */
.header-nav_sp {
}

/* slide-menu_btn */
.slide-menu_btn {
	position: fixed;
	top: 18px;
	right: 18px;
	z-index: 10000;
}

/* slide-menu_nav */
.slide-menu_nav {
	box-sizing: border-box;
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	padding: 18vh 0 0 0;
	background-color: #fff;
	overflow-y: scroll;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	z-index: 9000;
	opacity: 0;
	visibility: hidden;
	transition: all .3s;
}
.slide-menu_nav.open {
	visibility: visible;
	opacity: 1;
}
.slide-menu_nav-logo {
	position: absolute;
	top: 20px;
	left: 24px;
	width: 162px;
	height: auto;
}
.slide-menu_nav .gnav_sp {
	position: relative;
	margin-bottom: 50px;
	text-align: center;
}
.slide-menu_nav .gnav_sp > li {
	position: relative;
	margin-bottom: 20px;
}
.slide-menu_nav li:last-child {
	margin-bottom: 0;
}
.slide-menu_nav .gnav_sp > li > a {
	position: relative;
	display: inline-block;
	background-color: #F5F8FC;
	border-radius: 7px;
	padding: 12px 18px 12px;
	font-weight: 500;
	line-height: 1.1;
	font-size: 1.5rem;
}
.slide-menu_nav .gnav01 {
	opacity: 0;
	transition: all .6s;
}
.slide-menu_nav .gnav02 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .04s;
}
.slide-menu_nav .gnav03 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .08s;
}
.slide-menu_nav .gnav04 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .12s;
}
.slide-menu_nav .gnav05 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .16s;
}
.slide-menu_nav .gnav06 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .20s;
}
.slide-menu_nav.open .gnav01,
.slide-menu_nav.open .gnav02,
.slide-menu_nav.open .gnav03,
.slide-menu_nav.open .gnav04,
.slide-menu_nav.open .gnav05,
.slide-menu_nav.open .gnav06,
.slide-menu_nav.open .slide-menu_nav_address {
	opacity: 1;
}
#top .gnav01 a,
#service .gnav02 a,
#recruit .gnav03 a,
#company .gnav04 a,
#news .gnav05 a,
#contact .gnav06 a {
	background-color: var(--c-primary-blue);
	color: var(--c-white);
}
.slide-menu_nav_address{
	position: absolute;
	left: 40px;
	bottom: 36px;
	font-size: 1.1rem;
	font-style: normal;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.1em;
	opacity: 0;
	transition: all .6s;
	transition-delay: .24s;
	z-index: -1;
}

/* menu-trigger */
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .3s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background-color: var(--c-primary-blue);
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 16px;
	height: 1px;
	border-radius: 2px;
	background-color: var(--c-white);
}
.menu-trigger.active span {
	background-color: var(--c-white);
}
.menu-trigger span:nth-of-type(1) {
	top: 15px;
	left: 10px;
}
.menu-trigger span:nth-of-type(2) {
	bottom: 15px;
	left: 10px;
}
.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(3px) rotate(-45deg);
	transform: translateY(3px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
	-webkit-transform: translateY(-2px) rotate(45deg);
	transform: translateY(-2px) rotate(45deg);
}


/* contents
----------------------------------------- */
#contents {
	position: relative;
	margin-top: 40px;
}
#top #contents {
	margin-top: 0;
}
#contents::before {
	content: '';
	position: absolute;
	top: -160px;
	left: -200px;
    width: 1000px;
    height: 794px;
	background: url(../images/common/intro-sec_bg-mark.svg) 0 0 no-repeat;
	background-size: 1000px 794px;
	z-index: -10;
}
#top #contents::before {
	display: none;
}

/* news-sec_list */
.news-sec_list {
    position: relative;
	padding-top: 34px;
}
.news-sec_list::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(to right, var(--c-black) 1px, transparent 1px);
    background-size: 4px 1px;
    background-repeat: repeat-x;
}
.news-sec_list li {
    display: flex;
    align-items: flex-start;
    position: relative;
    margin-bottom: 34px;
    padding-bottom: 30px;
}
.news-sec_list li:last-child {
    margin-bottom: 0;
}
.news-sec_list li::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(to right, var(--c-black) 1px, transparent 1px);
    background-size: 4px 1px;
    background-repeat: repeat-x;
}
.news-sec_meta {
    display: flex;
    align-items: center;
    margin-bottom: 0;
    margin-right: 20px;
}
.news-sec_date {
    min-width: 96px;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 1.4rem;
    line-height: 1.4;
    letter-spacing: 0.03em;
    color: var(--c-gray);
}
.news-sec_cat {
    display: inline-block;
    min-width: 72px;
    background-color: var(--c-primary-blue);
    padding: 4px 10px;
    border-radius: 100px;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 1.0rem;
    line-height: 1.3;
    text-align: center;
    letter-spacing: 0.03em;
    color: var(--c-white);
}
.news-sec_ttl {
    width: calc(100% - 220px);
    font-size: 1.4rem;
    line-height: 1.6;
}

/* qa-list */
.qa-list {
}
.qa-item {
    border: 1px solid var(--c-primary-blue);
    padding: 16px 24px 14px;
    border-radius: 8px;
    margin-bottom: 16px;
}
.qa-item:last-child {
    margin-bottom: 0;
}
.qa-q {
    display: flex;
    margin-bottom: 4px;
    cursor: pointer;
}
.qa-q .label {
    width: 32px;
    font-family: "Poppins", sans-serif;
    font-size: 1.8rem;
    line-height: 1.4;
    color: var(--c-primary-blue);
}
.qa-q .ttl {
    position: relative;
    width: calc(100% - 32px);
    padding-top: 2px;
    padding-right: 24px;
    font-size: 1.3rem;
    line-height: 1.8;
}
.qa-q .ttl::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -4px;
    width: 14px;
    height: 8px;
    margin-top: -3px;
    background: url(../images/common/qa_icon.svg) no-repeat center center;
    background-size: contain;
    transition: rotate .3s;
}
.qa-item.is-open .qa-q .ttl::after {
    rotate: 180deg;
}
.qa-a {
    display: none;
}
.qa-a .label {
    width: 32px;
    font-family: "Poppins", sans-serif;
    font-size: 1.8rem;
    line-height: 1.4;
    color: var(--c-primary-blue);
    transform: translateY(1px);
}
.qa-a .text {
    width: calc(100% - 32px);
    padding-top: 2px;
    padding-right: 24px;
    font-size: 1.3rem;
    line-height: 1.8;
}

/* contact-sec */
.contact-sec {
	position: relative;
	width: calc(100% - 16px);
	margin: 120px auto 8px;
	padding: 56px 8px;
	border-radius: 8px;
	background-color: var(--c-primary-blue);
	overflow: hidden;
}
#top .contact-sec {
	margin-top: 0;
}
.contact-sec::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/common/cta-bg-bottom_sp.png) center center no-repeat;
	background-size: cover;
	z-index: 1;
}
.contact-sec::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/common/cta-bg-top_sp.png) center center no-repeat;
	background-size: cover;
	z-index: 3;
}
.contact-sec_copy-eng {
	display: none;
}
.contact-sec_inner {
	position: relative;
	padding: 48px 20px;
}
.contact-sec_inner::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 8px;
	background-color: var(--c-white);
	z-index: 2;
}
.contact-sec_inner-text {
	position: relative;
	z-index: 10;
}
.contact-sec_ttl-area {
	position: relative;
	margin-bottom: 24px;
	z-index: 10;
	text-align: center;
}
.contact-sec_ttl-area .jpn {
	font-size: 2.6rem;
}
.contact-sec_ttl-area .eng {
	font-size: 1.2rem;
}
.contact-sec_lead {
	margin-bottom: 32px;
	font-size: 1.4rem;
	line-height: 2.0;
	text-align: center;
}
.contact-sec_btn-tel-area {
}
.contact-sec_btn-wrap {
	margin-bottom: 24px;
	text-align: center
}
.contact-sec_btn {
	display: inline-block;
	padding: 20px 40px;
	border-radius: 16px;
	color: var(--c-white);
	background-color: var(--c-primary-blue);
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.6;
}
.contact-sec_btn:hover {
	color: var(--c-white);
}
.contact-sec_tel-area {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 0 24px;
}
.contact-sec_tel {
	position: relative;
	padding-left: 32px;
	font-size: 3.2rem;
}
.contact-sec_tel-label {
	position: absolute;
	top: 14px;
	left: 0;
	font-family: "Poppins", sans-serif;
	font-size: 1.4rem;
}
.contact-sec_tel-note {
	font-size: 1.1rem;
}
.contact-sec_copy-jpn {
	display: none;
}



/* footer
----------------------------------------- */
#footer {
	width: calc(100% - 16px);
	margin: 0 auto 8px;
	padding: 48px 32px 32px;
	border-radius: 8px;
	border: 1px solid #C7DCEC;
}
.footer-inner {
}
.footer-nav {
	margin-bottom: 56px;
}
.footer-nav_list {
}
.footer-nav_list li {
	margin-bottom: 22px;
	text-align: center;
}
.footer-nav_list li:last-child {
	margin-right: 0;
}
.footer-nav_list li a {
	position: relative;
	display: inline-block;
	background-color: #F5F8FC;
	border-radius: 7px;
	padding: 8px 10px;
	font-weight: 500;
	line-height: 1.1;
	font-size: 1.4rem;
}
#top .fnav01 a,
#service .fnav02 a,
#recruit .fnav03 a,
#company .fnav04 a,
#news .fnav05 a,
#contact .fnav06 a {
	background-color: var(--c-primary-blue);
	color: var(--c-white);
}
.footer-logo-area {
	margin-bottom: 56px;
}
.footer-logo {
	display: block;
	width: 180px;
	margin-bottom: 16px;
}
.footer-address {
	font-size: 1.1rem;
}
.footer-copyright {
	font-family: "Poppins", sans-serif;
	text-align: center;
	font-size: 1.0rem;
	letter-spacing: 0.03em;
}




} /* tablet end */



























































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

.pc {
	display: block !important;
}
.sp {
	display: none !important;
}
img {
	width: 100%;
	height: auto;
}


/* common
----------------------------------------- */
/* loading */
#contents-wrap {
	position: relative;
	opacity: 0;
	transition: all 1.0s;
}
#contents-wrap.fade-in {
	opacity: 1;
}
.loading-img {
	position: fixed;
	top: 50%;
	left: 50%;
	width: 100px;
	height: 100px;
	margin-top: -70px;
	margin-left: -50px;
	text-align: center;
	color: #fff;
	z-index: 2;
	text-align: center;
}
.loading-img img {
	width: 100%;
	height: auto;
}

/* breadcrumbs-area */
.breadcrumbs-area {
	position: absolute;
	bottom: 0;
	right: 12px;
	padding: 0;
}
.breadcrumbs-list {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	padding: 18px 32px 0 40px;
	border-top-left-radius: 10px;
	background-color: var(--c-white);
}
.breadcrumbs-list::before {
	content: '';
	position: absolute;
	top: -10px;
	right: 0;
	width: 10px;
	height: 10px;
	background: url(../images/common/breadcrumbs-bg-r.svg) 0 0 no-repeat;
	background-size: 10px 10px;
}
.breadcrumbs-list::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: -10px;
	width: 10px;
	height: 10px;
	background: url(../images/common/breadcrumbs-bg-r.svg) 0 0 no-repeat;
	background-size: 10px 10px;
}
.breadcrumbs-list li {
	line-height: 1;
}
.breadcrumbs-list a,
.breadcrumbs-list li span {
	display: inline-block;
	font-size: 1.2rem;
	line-height: 1.6;
}
.breadcrumbs-list a {
	position: relative;
	margin-right: 20px;
	transition: color .3s;
}
.breadcrumbs-list li span {
	color: var(--c-primary-blue);
}
.breadcrumbs-list a:hover {
	color: var(--c-primary-blue);
}
.breadcrumbs-list a::before {
	display: block;
	content: '';
	position: absolute;
	top: 50%;
	right: -12px;
	width: 6px;
	height: 1px;
	background-color: var(--c-black);
}

/* ttl */
.section-ttl.vertical-type {
    display: flex;
}
.section-ttl .eng {
    font-family: "Poppins", sans-serif;
    font-size: 1.4rem;
    color: var(--c-primary-blue);
    font-weight: 500;
}
.section-ttl.horizontal .eng {
    letter-spacing: 0.03em;
}
.section-ttl .jpn {
    font-size: 2.8rem;
    letter-spacing: 0.08em;
}
.section-ttl.vertical-type .eng,
.section-ttl.vertical-type .jpn {
    writing-mode: vertical-rl;
    vertical-align: top;
}
.section-ttl.vertical-type .eng{
   padding-top: 3px;
}
/* * sec-ttl_line * */
.sec-ttl_line {
	padding-bottom: 32px;
	margin-bottom: 64px;
	border-bottom: 1px solid var(--c-black);
	font-size: 2.8rem;
	line-height: 1.6;
}
.sec-ttl_line span {
    color: var(--c-primary-blue);
}

/* link */
.sec-btn_black {
	display: inline-block;
	padding: 13px 30px;
	border-radius: 7px;
	background-color: var(--c-black);
	color: var(--c-white);
	font-size: 1.6rem;
	line-height: 1.6;
	transition: background-color .3s;
}
.sec-btn_black:hover {
	color: var(--c-white);
	background-color: var(--c-primary-blue);
}
.sec-btn_blue-line {
	display: inline-block;
	padding: 13px 30px;
	border-radius: 7px;
	border: 1px solid var(--c-primary-blue);
	color: var(--c-primary-blue);
	font-size: 1.6rem;
	line-height: 1.6;
	transition: all .3s;
}
.sec-btn_blue-line:hover {
	color: var(--c-white);
	background-color: var(--c-primary-blue);
}

/* text */


/* header
----------------------------------------- */
#header {
	position: relative;
	padding: 12px 12px 0;
}
.header-logo {
	position: absolute;
	top: 0;
	left: 0;
	padding: 34px 44px 32px 52px;
	border-bottom-right-radius: 10px;
	background-color: var(--c-white);
	z-index: 10;
}
.header-logo::before {
	content: '';
	position: absolute;
	top: 12px;
	right: -10px;
	width: 10px;
	height: 10px;
	background: url(../images/common/logo-bg-r_sp.svg) 0 0 no-repeat;
	background-size: 10px 10px;
}
.header-logo::after {
	content: '';
	position: absolute;
	bottom: -10px;
	left: 12px;
	width: 10px;
	height: 10px;
	background: url(../images/common/logo-bg-r_sp.svg) 0 0 no-repeat;
	background-size: 10px 10px;
}
.header-logo img {
	width: 260px;
	height: auto;
}

/* header-gnav_pc */
.header-gnav_pc {
	position: absolute;
	top: 20px;
	right: 44px;
	z-index: 1000;
}
.header-gnav_pc_list {
	display: flex;
	padding-top: 24px;
}
.header-gnav_pc_list.fixed {
	position: fixed;
	top: 0;
	right: 44px;
	z-index: 1000;
}
.header-gnav_pc_list li {
	margin-left: 20px
}
.header-gnav_pc_list li a {
	position: relative;
	display: inline-block;
	width: calc(1em + 16px);
	padding: 10px 8px 6px;
	border-radius: 7px;
	background-color: #fff;
	font-size: 1.5rem;
	line-height: 1.0;
	letter-spacing: 0.12em;
	writing-mode: vertical-rl;
	vertical-align: top;
	transition: all .3s;
}
.header-gnav_pc_list li a:hover {
	background-color: var(--c-primary-blue);
	color: var(--c-white);
}
#top .gnav01 a,
#service .gnav02 a,
#recruit .gnav03 a,
#company .gnav04 a,
#news .gnav05 a,
#contact .gnav06 a {
	background-color: var(--c-primary-blue);
	color: var(--c-white);
}

/* page-visual-area */
.page-visual-area {
    position: relative;
    margin-bottom: 0;
}
.page-visual_img {
}
.page-visual_img img {
	border-radius: 8px;
}
.page-visual_ttl-area {
    position: absolute;
    bottom: 96px;
    left: 112px;
    z-index: 10;
}
.page-visual_ttl-area .eng span,
.page-visual_ttl-area .jpn span {
	color: var(--c-primary-blue);
	background-color: var(--c-white);
	border-radius: 7px;
	line-height: 1.4;
}
.page-visual_ttl-area .eng {
	margin-bottom: 8px;
}
.page-visual_ttl-area .eng span {
	display: inline-block;
	padding: 6px 14px;
	font-family: "Poppins", sans-serif;
	font-size: 2.0rem;
}
.page-visual_ttl-area .jpn span {
	display: inline-block;
	padding: 4px 14px;
	font-size: 1.4rem;
}
.page-visual_ttl-area .eng span {
	transition-delay: .3s;
}
.page-visual_ttl-area .jpn span {
	transition-delay: .4s;
}


/* contents
----------------------------------------- */
#contents {
	position: relative;
	margin-top: 120px;
}
#top #contents {
	margin-top: 0;
}
#contents::before {
	content: '';
	position: absolute;
	top: -360px;
	left: -10vw;
	width: 1521px;
    height: 1200px;
	background: url(../images/common/intro-sec_bg-mark.svg) 0 0 no-repeat;
	background-size: 1521px 1200px;
	z-index: -10;
}
#top #contents::before {
	display: none;
}

/* news-sec_list */
.news-sec_list {
    position: relative;
	padding-top: 34px;
}
.news-sec_list::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(to right, var(--c-black) 1px, transparent 1px);
    background-size: 4px 1px;
    background-repeat: repeat-x;
}
.news-sec_list li {
    display: flex;
    align-items: flex-start;
    position: relative;
    margin-bottom: 34px;
    padding-bottom: 30px;
}
.news-sec_list li:last-child {
    margin-bottom: 0;
}
.news-sec_list li::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(to right, var(--c-black) 1px, transparent 1px);
    background-size: 4px 1px;
    background-repeat: repeat-x;
}
.news-sec_meta {
    display: flex;
    align-items: center;
    margin-bottom: 0;
    margin-right: 50px;
}
.news-sec_date {
    min-width: 120px;
    padding-left: 10px;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 1.4rem;
    line-height: 1.4;
    letter-spacing: 0.03em;
    color: var(--c-gray);
}
.news-sec_cat {
    display: inline-block;
    min-width: 100px;
    background-color: var(--c-primary-blue);
    padding: 4px 10px;
    border-radius: 100px;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 1.1rem;
    line-height: 1.3;
    text-align: center;
    letter-spacing: 0.03em;
    color: var(--c-white);
    transition: all .3s;
}
.news-sec_cat:hover {
    color: var(--c-white);
    background-color: var(--c-primary-blue-hover);   
}
.news-sec_ttl {
    width: calc(100% - 280px);
    font-size: 1.6rem;
    line-height: 1.6;
    transform: translateY(-2px);
    transition: color .3s;
}
.news-sec_ttl:hover {
    color: var(--c-primary-blue);
}

/* qa-list */
.qa-list {
}
.qa-item {
    border: 1px solid var(--c-primary-blue);
    padding: 20px 32px 18px;
    border-radius: 8px;
    margin-bottom: 16px;
}
.qa-item:last-child {
    margin-bottom: 0;
}
.qa-q {
    display: flex;
    margin-bottom: 8px;
    cursor: pointer;
	transition: color .3s;
}
.qa-q:hover {
	color: var(--c-primary-blue);
}

.qa-q .label {
    width: 32px;
    font-family: "Poppins", sans-serif;
    font-size: 2.4rem;
    line-height: 1.4;
    color: var(--c-primary-blue);
}
.qa-q .ttl {
    position: relative;
    width: calc(100% - 32px);
    padding-top: 4px;
    padding-right: 24px;
    font-size: 1.6rem;
    line-height: 1.8;
}
.qa-q .ttl::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -4px;
    width: 14px;
    height: 8px;
    margin-top: -3px;
    background: url(../images/common/qa_icon.svg) no-repeat center center;
    background-size: contain;
    transition: rotate .3s;
}
.qa-item.is-open .qa-q .ttl::after {
    rotate: 180deg;
}
.qa-a {
    display: none;
}
.qa-a .label {
    width: 32px;
    font-family: "Poppins", sans-serif;
    font-size: 2.4rem;
    line-height: 1.4;
    color: var(--c-primary-blue);
    transform: translateY(1px);
}
.qa-a .text {
    width: calc(100% - 32px);
    padding-top: 4px;
	padding-bottom: 10px;
    padding-right: 24px;
    font-size: 1.4rem;
    line-height: 2.0;
}

/* contact-sec */
.contact-sec {
	display: flex;
	justify-content: center;
	position: relative;
	width: calc(100% - 24px);
	margin: 160px auto 12px;
	padding: 56px 0;
	border-radius: 10px;
	background-color: var(--c-primary-blue);
	overflow: hidden;
}
#top .contact-sec {
	margin-top: 0;
}
.contact-sec::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/common/cta-bg-bottom_pc.png) center center no-repeat;
	background-size: cover;
	z-index: 1;
}
.contact-sec::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/common/cta-bg-top_pc.png) center center no-repeat;
	background-size: cover;
	z-index: 3;
}
.contact-sec_copy-eng {
	display: none;
}
.contact-sec_inner {
	position: relative;
	width: 960px;
	margin: 0;
	padding: 80px 0 88px;
}
.contact-sec_copy-jpn {
	display: none
}
.contact-sec_inner::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 10px;
	background-color: var(--c-white);
	z-index: 2;
}
.contact-sec_inner-text {
	position: relative;
	z-index: 10;
}
.contact-sec_ttl-area {
	position: relative;
	margin-bottom: 40px;
	z-index: 10;
	text-align: center;
}
.contact-sec_ttl-area .jpn {
	font-size: 3.2rem;
}
.contact-sec_ttl-area .eng {
	font-size: 1.4rem;
}
.contact-sec_lead {
	margin-bottom: 56px;
	font-size: 1.6rem;
	line-height: 2.2;
	text-align: center;
}
.contact-sec_lead .br {
	display: none;
}
.contact-sec_btn-tel-area {
	display: flex;
	justify-content: center;
}
.contact-sec_btn-wrap {
	margin-bottom: 0;
	text-align: center
}
.contact-sec_btn {
	display: inline-block;
	padding: 20px 70px;
	border-radius: 16px;
	color: var(--c-white);
	background-color: var(--c-primary-blue);
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.6;
	transition: background-color .3s;
}
.contact-sec_btn:hover {
	color: var(--c-white);
	background-color: var(--c-primary-blue-hover);
}
.contact-sec_tel-area {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 0;
}
.contact-sec_tel {
	position: relative;
	margin-bottom: 3px;
	padding-left: 38px;
	font-size: 3.8rem;
	line-height: 1.2;
	transform: translateY(-4px);
}
.contact-sec_tel-label {
	position: absolute;
	top: 8px;
	left: 0;
	font-family: "Poppins", sans-serif;
	font-size: 1.6rem;
}
.contact-sec_tel-note {
	padding-left: 100px;
	font-size: 1.2rem;
}


/* footer
----------------------------------------- */
#footer {
	position: relative;
	width: calc(100% - 24px);
	margin: 0 auto 12px;
	padding: 44px 40px 48px;
	border-radius: 10px;
	border: 1px solid #C7DCEC;
}
.footer-inner {
}
.footer-nav {
	margin-bottom: 0;
}
.footer-nav_list {
	display: flex;
	position: absolute;
	top: 44px;
	right: 38px;
}
.footer-nav_list li {
	margin: 0 20px 0 0;
	text-align: right;
}
.footer-nav_list li:last-child {
	margin-right: 0;
}
.footer-nav_list li a {
	position: relative;
	display: inline-block;
	width: calc(1em + 16px);
	padding: 10px 8px 6px;
	border-radius: 7px;
	background-color: #F5F8FC;
	font-size: 1.5rem;
	line-height: 1.0;
	font-weight: 500;
	letter-spacing: 0.12em;
	writing-mode: vertical-rl;
	vertical-align: top;
	transition: all .3s;
}
.footer-nav_list li a:hover {
	background-color: var(--c-primary-blue);
	color: var(--c-white);
}
#top .fnav01 a,
#service .fnav02 a,
#recruit .fnav03 a,
#company .fnav04 a,
#news .fnav05 a,
#contact .fnav06 a {
	background-color: var(--c-primary-blue);
	color: var(--c-white);
}
.footer-logo-area {
	margin-bottom: 40px;
}
.footer-logo {
	display: block;
	width: 260px;
	margin-bottom: 24px;
}
.footer-address {
	font-size: 1.2rem;
	line-height: 1.6;
}
.footer-copyright {
	font-family: "Poppins", sans-serif;
	text-align: center;
	font-size: 1.0rem;
	letter-spacing: 0.06em;
}


} /* pc end */




















































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

/* header
----------------------------------------- */
.contact-sec_copy-eng {
	display: flex;
	justify-content: center;
	align-items: center;
	width: calc((100% - 960px) / 2);
	writing-mode: vertical-rl;
	font-family: "Poppins", sans-serif;
	font-size: 1.5rem;
	color: var(--c-white);
	z-index: 10;
	transform: translateX(-2px);
}
.contact-sec_inner {
	position: relative;
	width: 960px;
	margin: 0;
	padding: 80px 0 88px;
}
.contact-sec_copy-jpn {
	display: flex;
	justify-content: center;
	align-items: center;
	width: calc((100% - 960px) / 2);
	writing-mode: vertical-rl;
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: 0.03em;
	color: var(--c-white);
	z-index: 10;
	transform: translateX(5px);
}

} /* pc end */





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

} /* PC end */