@charset "UTF-8";
/* --------------------------------

PC Wide

-------------------------------- */
/* 非表示 */
.sp-view{display: none;}
.small-view{display: none;}
#sp-head{display: none;}
/* ヘッダー */
.pc-menu{
	width: 100%;
	background:rgba(0,0,0,0.5);
	position: fixed;
	top:0;
	left: 0;
	z-index: 999;
	transition: all .5s ease;
}

.pc-menu a{
	color: #FFF;
	position: relative;
}

.pc-menu a::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	z-index: 3;
	background:#fff;
	width: 100%;
	height: 1px;
	transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	transform-origin: right top;
}

.pc-menu a:hover{
	color: #fff;
}

.pc-menu a:hover::after {
	transform-origin:left top;
	transform:scale(1, 1);
}

.pc-menu i.searchmenu-btn{
	color: #FFF;
}

ul.pc-navi-list{
	width: 100%;
	max-width: 78rem;
	height: 88px;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	justify-content: flex-start;
	position: relative;
	margin:0 auto 0;
	/*background-image: linear-gradient(90deg, rgba(14, 244, 255, 1) 50%, rgba(65, 164, 253, 1) 50%);*/
}

ul.pc-navi-list li{
	font-size: 1rem;
	line-height: 1.5;
	font-weight: bold;
	margin-right: 2rem;
}

/*ul.pc-navi-list li:nth-of-type(5){
	margin-left: 1.5rem;
	margin-right: 3rem;
}

ul.pc-navi-list li:nth-of-type(9){
	margin-left: 1rem;
	margin-right: 3rem;
}*/

ul.pc-navi-list li:last-child{
	margin-right: 0px;
}

ul.pc-navi-list > li:hover .megamenu {
 max-height: 9999px;
 opacity: 1;
 padding: 20px 0;
}
 
.megamenu {
 background: rgba(255,255,255,1);
 /*border-bottom: 1px solid #ccc;*/
 box-shadow: 0 3px 5px 0 rgba(0,0,0,0.1);
 max-height: 0;
 opacity: 0;
 overflow: hidden;
 width: 100%;
 position: fixed;
 top: 60px;
 left: 0;
 transition: all .5s ease;
 z-index: 990;
}

.searchmenu-btn{
	cursor: pointer;
}

.searchmenu-close{
	width: 100px;
	display: block;
	color: var(--color-saphire-blue);
	text-align: center;
	border:1px solid var(--color-saphire-blue);
	border-radius: 40px;
	background-color: #FFF;
	margin:0 auto 20px;
	padding: 5px 0px;
	cursor: pointer;
	transition: all .5s ease;
}

.searchmenu-close:hover{
	color: #FFF;
	background-color: var(--color-saphire-blue);
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(0); /* 上からスライドイン */
  }
  to {
    opacity: 1;
    transform: translateY(0); /* 元の位置 */
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
    transform: translateY(0); /* 上からスライドイン */
  }
  to {
    opacity: 0;
    transform: translateY(0); /* 元の位置 */
  }
}

.searchmenu-open{
	display: block;
	max-height: 9999px;
	opacity: 0;
	background: rgba(255,255,255,1);
	box-shadow: 0 3px 5px 0 rgba(0,0,0,0.1);
	overflow: hidden;
	width: 100%;
	position: fixed;
	top: 0px;
	left: 0;
	z-index: 996;
	animation: fadeIn 0.3s ease-out forwards; /* 0.5秒でアニメーション実行 */
}

.searchmenu {
    opacity: 0;
    display: none;
    transition: opacity 0.5s ease; /* フェードインの設定 */
}


ul.pc-navi-inner{
	width: 100%;
	max-width: 78rem;
	margin:0 auto 0;
	padding: 30px 0px;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.pc-navi-inner li:nth-of-type(1){
	width: 25%;
	margin-right: 0px;
}

ul.pc-navi-inner li:nth-of-type(2){
	width: 35%;
	margin-left: 5%;
	margin-right: 0px;
}

ul.pc-navi-inner li:nth-of-type(3){
	width: 30%;
	margin-left: 5%;
	margin-right: 0px;
}

ul.pc-navi-inner-wide{
	width: 95%;
	max-width: 75rem;
	margin:0 auto 0;
	padding: 30px 0px;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.pc-navi-inner-wide li:nth-of-type(1){
	width: 20%;
	margin-right: 0px;
}

ul.pc-navi-inner-wide li:nth-of-type(2){
	width: 25%;
	margin-left: 5%;
	margin-right: 0px;
}

ul.pc-navi-inner-wide li:nth-of-type(3){
	width: 20%;
	margin-left: 5%;
	margin-right: 0px;
}

ul.pc-navi-inner-wide li:nth-of-type(4){
	width: 20%;
	margin-left: 5%;
	margin-right: 0px;
}

ul.worldwide-inner {
	width: 95%;
	max-width: 1260px;
	margin:0 auto 0;
	padding: 30px 0px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
 
ul.worldwide-inner li {
 width: calc(100% / 5);
 padding: 0;
}

ol.worldwide-inner {
	width: 95%;
	max-width: 1260px;
	margin:0 auto 0;
	padding: 30px 0px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
 
ol.worldwide-inner li {
 width: calc(100% / 5);
 padding: 0;
}

.menu-title{
	font-size: 1.5rem;
	line-height: 1.5;
	font-weight: bold;
	color: var(--color-saphire-blue);
}

.sub-menu-title{
	font-size: 1rem;
	line-height: 1.5;
	font-weight: bold;
	color: var(--color-saphire-blue);
	border-bottom: 1px solid var(--color-saphire-blue);
	text-align: left;
}

dl.main-navi-list{
	width: 100%;
}

dl.main-navi-list dd{
	width: 100%;
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	border-bottom:1px solid var(--color-saphire-blue);
	position: relative;
	transition: all .5s ease;
}

dl.main-navi-list dd:hover{
	background-color: #f5f5fa;
}

dl.main-navi-list dd p{
	width: 100%;
	display: block;
	padding: 10px;
	cursor: pointer;
	position: relative;
}

dl.main-navi-list dd p i{
	position: absolute;
	right: 10px;
	bottom:14px;
}

dl.main-navi-list dd a{
	width: 100%;
	display: block;
	color: var(--color-saphire-blue);
	padding: 10px;
	position: relative;
}

dl.main-navi-list dd a::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	z-index: 3;
	background:var(--color-saphire-blue);
	width: 100%;
	height: 1px;
	transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	transform-origin: right top;
}

dl.main-navi-list dd a:hover{
	color: var(--color-saphire-blue);
}

dl.main-navi-list dd a:hover::after {
	transform-origin:left top;
	transform:scale(1, 1);
}

dl.main-navi-list dd a i{
	position: absolute;
	right: 10px;
	bottom:14px;
}

.sub-navi-list{
	display: none;
}

.sub-navi-list.open{
	display: block;
}

.sub-navi-btn{
	transition: all .5s ease;
}

.sub-navi-btn.open{
	background-color: #f5f5fa;
}

.sub-navi-list-2{
	display: none;
}

.sub-navi-list-2.open{
	display: block;
}

.sub-navi-btn-2{
	transition: all .5s ease;
}

.sub-navi-btn-2.open{
	background-color: #f5f5fa;
}

ul.menu-link{
	width: 100%;
}

ul.menu-link li{
	width: 100%;
	text-align: left;
	border-bottom: 1px solid var(--color-saphire-blue);
}

ul.menu-link li a{
	width: 100%;
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	padding: 10px;
	position: relative;
}

ul.menu-link li a:hover{
	background-color: #f5f5fa;
	color: var(--color-saphire-blue);
}

ul.menu-link li a::after{
	content: '';
	border-bottom: 1px solid var(--color-saphire-blue);
}

ul.menu-link li a i{
	position: absolute;
	right: 10px;
	bottom:14px;
}

.head-logo{
	width: 154px;
	margin-left: 1.5rem;
	margin-right: 1rem;
	position: relative;
	z-index: 995;
}

.head-logo img{
	width: 100%;
	height: auto;
}

.nav-active{
	background-color: #fff;
	/*border-bottom: 1px solid #ccc;*/
	box-shadow: 0 3px 5px 0 rgba(0,0,0,0.1);
}

.nav-active a.home-link{
	color: #002855;
	padding-bottom: 5px;
	position: relative;
}

.nav-active a.home-link::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	z-index: 3;
	background:#FFF;
	width: 100%;
	height: 1px;
	transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	transform-origin: right top;
	opacity: 0;
}

.nav-active a.home-link:hover{
	color: #002855;
}

.nav-active a.home-link:hover::after {
	transform-origin:left top;
	transform:scale(1, 1);
}

.nav-active a{
	color: #002855;
	padding-bottom: 5px;
	position: relative;
}

.nav-active a::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	z-index: 3;
	background:#002855;
	width: 100%;
	height: 1px;
	transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	transform-origin: right top;
}

.nav-active a:hover{
	color: #002855;
}

.nav-active a:hover::after {
	transform-origin:left top;
	transform:scale(1, 1);
}

.nav-active i.searchmenu-btn{
	color: #002855;
	padding-bottom: 5px;
	position: relative;
	z-index: 999;
}

.nav-active i.searchmenu-btn::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	z-index: 3;
	background:#002855;
	width: 100%;
	height: 1px;
	transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	transform-origin: right top;
}

.nav-active i.searchmenu-btn:hover{
	color: #002855;
}

.nav-active i:hover::after {
	transform-origin:left top;
	transform:scale(1, 1);
}

.logo-image{
	display: none;
	position: absolute;
	top:0;
	left:0;
}

.logo-image.logo-active{
	display: block;
}

/* 検索 */
.search-wrap{
	width: 50%;
	max-width:75rem; 
	margin:0 auto 0;
	padding: 20px 0px;
	display: flex;
}

.search-wrap input{
	width: 90%;
	font-size: 1rem;
	padding: 10px 20px; 
	border:1px solid var(--color-saphire-blue);
}

.search-wrap input:focus{
	outline: none;
}

button {
  padding: 0;
  border: none;
  outline: none;
  font: inherit;
  color: inherit;
  background: none
}

.search-wrap button{
	width: 10%;
	display: block;
	font-size: 1rem;
	color:#fff;
	background-color:var(--color-saphire-blue);
	border:1px solid var(--color-saphire-blue);
	cursor: pointer;
	padding: 10px;
	transition: all .5s ease;
}

.search-wrap button:hover{
	opacity: 0.9;
}

/* トップスライダー */
#top-slide{
	width: 100%;
	max-width: 2000px;
	margin:0 auto 0;
}

.top-slide-box{
	width: 100%;
	/*height: 66vh;*/
	/*overflow: hidden;*/
	
}

.top-slide-box img{
	width: 100%;
	height: auto;
}

.slide-item{
	width: 100%;
	position: relative;
}

.slide-box{
	width: 100%;
	max-width: 75rem;
	height: 395px;
	position: absolute;
    top: 60%;
    left: 50%;
    transform: translate(-60%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    z-index: 2;
}

.slide-title{
	width: 63%;
	display: block;
	font-size: 2rem;
	line-height: 1.7;
	color: var(--color-saphire-blue);
	background:var(--color-bg-90);
	padding: 30px 50px 30px 50px;
	position: absolute;
	top:0;
}

.slide-deal-area{
	width: 38%;
	background:var(--color-saphire-blue);
	opacity: 0.9;
	padding: 30px;
	position: absolute;
	right: 60px;
	top:100px;
}

.slide-photo{
	width: 100%;
	/*max-height: 600px;*/
	/*overflow: hidden;*/
}

table.slide-table{
	width: 100%;
	color: #FFF;
}

table.slide-table thead th{
	width: 80%;
	font-size: 0.875rem;
	text-align: left;
	border-bottom: 1px solid #fff;
	padding: 0px 10px 5px 10px;
}

table.slide-table thead td{
	width: 20%;
	font-size: 0.875rem;
	text-align: right;
	border-bottom: 1px solid #fff;
	padding: 0px 10px 5px 10px;
}

table.slide-table tbody tr:first-child>*{
	font-weight: bold;
}

table.slide-table tbody th{
	width: 80%;
	text-align: left;
	border-bottom: 1px solid #fff;
	padding: 10px;
}

table.slide-table tbody td{
	width: 20%;
	text-align: right;
	border-bottom: 1px solid #fff;
	padding: 10px;
}

.txt-chuki{
	font-size: 0.75rem;
	line-height: 1.5;
	color: #FFF;
	text-align: right;
	margin-right: 10px;
}


/* 共通 */
.top-main-title-big{
	width: 85%;
	max-width: 60rem;
	font-size: 1.5rem;
	line-height: 1.7;
	text-align: center;
	margin:0 auto;
	padding: 80px 0px;
}

.top-main-title{
	width: 85%;
	max-width: 60rem;
	font-size: 1.5rem;
	line-height: 1.7;
	text-align: center;
	margin:0 auto;
	padding: 80px 0px;
}

.main-copy{
	width: 85%;
	max-width: 56rem;
	margin:0 auto;
	padding: 80px 0px;
}

.main-copy h1{
	font-size: 1.5rem;
	line-height: 1.7;
}

.content-wrap{
	width: 85%;
	max-width: 75rem;
	font-size: 1.2rem;
	line-height: 1.7;
	margin:0 auto 0;
}

.content-wrap p{
	margin-bottom: 0.5em;
}

.content-wrap p:last-of-type{
	margin-bottom: 0;
}


ul.block-2{
	width: 85%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.block-2 li{
	width: 47.5%;
	margin-right: 5%;
	margin-bottom: 5%;
}

ul.block-2 li:nth-of-type(2n){
	margin-right: 0;
}

ul.tab-block-2{
	width: 100%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.tab-block-2 li{
	width: 47.5%;
	margin-right: 5%;
	margin-bottom: 2%;
	display: block;
}

ul.tab-block-2 li:nth-of-type(2n){
	margin-right: 0;
}

ul.block-3{
	width: 100%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.block-3 li{
	width: 30%;
	margin-right: 5%;
	margin-bottom: 5%;
	display: block;
}

ul.block-3 li:nth-of-type(3n){
	margin-right: 0;
}

ul.tab-block-3{
	width: 100%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.tab-block-3 li{
	width: 30%;
	margin-right: 5%;
	margin-bottom: 10px;
	display: block;
}

ul.tab-block-3 li:nth-of-type(3n){
	margin-right: 0;
}

ul.block-4{
	width: 100%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.block-4 li{
	width: 21.2%;
	margin-right: 5%;
	margin-bottom: 5%;
	display: block;
}

ul.block-4 li:nth-of-type(4n){
  margin-right: 0;
}

ul.block-4-6{
	width: 100%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.block-4-6 li:nth-of-type(1){
	width: 35%;
	margin-right: 5%;
	margin-bottom: 5%;
	display: block;
}

ul.block-4-6 li:nth-of-type(2){
	width: 60%;
	margin-right: 0;
	margin-bottom: 5%;
	display: block;
}

ul.block-5{
	width: 100%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.block-5 li{
	width: 17.6%;
	margin-right: 3%;
	margin-bottom: 3%;
	display: block;
}

ul.block-5 li:nth-of-type(5n){
  margin-right: 0;
}

ul.member-block{
	width: 85%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.member-block li{
	width: 47.5%;
	margin-right: 5%;
	margin-bottom: 5%;
}

ul.member-block li:nth-of-type(2n){
	margin-right: 0;
}

.cat-title-left{
	font-size: 2rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
}

.cat-title-big{
	font-size: 2rem;
	line-height: 1.5;
	font-weight: bold;
	color: var(--color-saphire-blue);
}

.cat-title-mid{
	font-size: 1.7rem;
	line-height: 1.5;
	font-weight: bold;
	color: var(--color-saphire-blue);
}

.cat-title-small{
	font-size: 1.2rem;
	line-height: 1.5;
	font-weight: bold;
	color: var(--color-saphire-blue);
}

.cat-title-right{
	width: 90%;
	font-size: 2rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
}

.cat-title-center{
	font-size: 2rem;
	line-height: 1.5;
	text-align: center;
	color: var(--color-saphire-blue);
}

.cat-title-center-white{
	font-size: 2rem;
	line-height: 1.5;
	text-align: center;
	color: #fff;
}

.cat-text-box-left{
	width: 100%;
	font-size: 1.2rem;
	line-height: 1.7;
}

.cat-text-box-left ul{
	width: 100%;
	list-style-type: disc;
	padding-left: 10px;
}

.cat-text-box-left ul li{
	width: 100%;
	margin: 10px;
}

.cat-text-box-left ol{
	width: 100%;
	list-style-type: decimal;
	padding-left: 18px;
}

.cat-text-box-left ol li{
	width: 100%;
	margin: 10px;
}

.cat-text-box-right{
	width: 100%;
	font-size: 1.2rem;
	line-height: 1.7;
}

.cat-text-box-right ul{
	width: 100%;
	list-style-type: disc;
	padding-left: 10px;
}

.cat-text-box-right ul li{
	width: 100%;
	margin: 10px;
}

.cat-text-box-right ol{
	width: 100%;
	list-style-type: decimal;
	padding-left: 18px;
}

.cat-text-box-right ol li{
	width: 100%;
	margin: 10px;
}

.cat-text{
	font-size: 1.2rem;
	line-height: 1.7;
}

.contact-block{
	width: 100%;
	display: flex;
}

.contact-block-long{
	width: 100%;
	display: flex;
	margin:0 auto 0;
}

.profile-text-area{
	width: 60%;
	color: #fff;
	background-color: var(--color-saphire-blue);
	position: relative;
}

.profile-name{
	width: 100%;
	font-size: 1.5rem;
	padding: 15px 20px;
}

.profile-name span{
	font-size: 0.75rem;
}

.profile-contact{
	width: 100%;
	position: absolute;
	bottom: 0;
	color: #FFF;
	font-size: 0.75rem;
	background-color: #1d4d7a;
	padding:7px 10px;
}

.profile-contact a{
	display: block;
	color: #FFF;
	font-size: 0.75rem;
	background-color: #1d4d7a;
	padding:7px 10px;
}

.profile-contact a:hover{
	opacity: 0.7;
}

.profile-photo-area{
	width: 40%;
	aspect-ratio: 1 / 1.2;
	overflow: hidden;
	position: relative;
}

.profile-photo-area img{
	width: 100%;
	height: auto;
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.mailmagazine-block{
	width: 60%;
	font-size: 0.875rem;
	line-height: 1.7;
	background-color: #f5f5fa;
	padding: 30px 30px;
}

.mailmagazine-title{
	font-size: 1.2rem;
	line-height: 1.7;
	color: var(--color-saphire-blue);
}

.mailmaga-form{
	width: 60%;
}

dl.text-list{
	width: 100%;
}

dl.text-list dt{
	font-size: 1rem;
	line-height: 1.7;
	margin-bottom: 3px;
	float: left;
}

dl.text-list dd{
	font-size: 1rem;
	line-height: 1.7;
	margin-left: 1.2em;
	margin-bottom: 3px;
}

table.blue-table{
	width: 90%;
	margin:10px auto 10px;
}
table.blue-table tr{
	border-bottom: 1px solid var(--color-saphire-blue);
}

table.blue-table thead th{
	width: 80%;
	font-size: 0.75rem;
	line-height: 1.5;
	padding: 10px 0px;
}

table.blue-table thead td{
	width: 20%;
	font-size: 0.75rem;
	line-height: 1.5;
	padding: 10px 0px;
}

table.blue-table thead td:last-child{
	text-align: right;
}

table.blue-table tbody tr:first-child>*{
	color: var(--color-saphire-blue);
}

table.blue-table tbody th{
	width: 80%;
	font-size: 1.2rem;
	line-height: 1.5;
	padding: 0.5rem 0px;
}

table.blue-table tbody td{
	width: 20%;
	font-size: 1.2rem;
	line-height: 1.5;
	padding: 0.5rem 0px;
}

table.blue-table tbody td:last-child{
	text-align: right;
}

/*アコーディオン*/
.accordion-btn-area{
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

.accordion-btn-area summary{
	/*width: 47.5%;*/
	width: 100%;
	/*margin-right: 5%;*/
	margin-bottom: 30px;
	display: block;
}

/*.accordion-btn-area summary:nth-of-type(2n){
	margin-right: 0;
}*/

.accordion-btn-area section {
}

/*アコーディオンタイトル*/
.accordion-title {
    position: relative;/*+マークの位置基準とするためrelative指定*/
    cursor: pointer;
    font-size:1.2rem;
    font-weight: normal;
    color: var(--color-saphire-blue);
    background-color: #f5f5fa;
    padding: 18px 15px;
    transition: all .5s ease;
}


/*アイコンの＋と×*/
.accordion-title::before,
.accordion-title::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 2px;
    background-color: var(--color-saphire-blue);
    transition: all .5s ease;
    
}
.accordion-title::before{
    top:48%;
    right: 15px;
    transform: rotate(0deg);
    
}
.accordion-title::after{    
    top:48%;
    right: 15px;
    transform: rotate(90deg);

}

.accordion-title.close{
	color: #fff;
	background-color: var(--color-saphire-blue);
}

/*　closeというクラスがついたら形状変化　*/
.accordion-title.close::before{
	background-color: #FFF;
	transform: rotate(0deg);
}

.accordion-title.close::after{
	background-color: #FFF;
	transform: rotate(0deg);
}

/*アコーディオンで現れるエリア*/
.accordion-text {
    display: none;/*はじめは非表示*/
    font-size: 1rem;
    line-height: 1.5;
	margin:0;
    padding: 20px;
    border-left:1px solid var(--color-saphire-blue);
    border-right:1px solid var(--color-saphire-blue);
    border-bottom:1px solid var(--color-saphire-blue);
}

.accordion-text-wrap{
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

.accordion-text-wrap ul{
	width: 50%;
	list-style-type: disc;
	padding-left: 10px;
}

.accordion-text-wrap ul li{
	width: 100%;
	margin:10px;
}


.accordion-text-wrap ol{
	width: 100%;
	list-style-type: decimal;
	padding-left: 18px;
}

.accordion-text-wrap ol li{
	width: 100%;
	margin: 10px;
}

.accordion-text-wrap　p{
	width: 100%;
	display: block;
}

/* 案件実績スライド */
#project-record{
	width: 100%;
	max-width: 2000px;
	margin:0 auto 0;
/*	background-image: url(../img/transactionlist-background.jpg);
	background-size: cover;
	background-repeat: no-repeat;*/
	/*background-color: var(--color-saphire-blue);*/
	padding: 30px 0px;
}

.ts-slide-area{
	width: 100%;
	margin:0 auto 0;
}

.ts-slide-box{
	width: 100%;
	padding-bottom: 60px;
	position: relative;
}

.ts-slide-item{
	padding: 20px;
}

.ts-slide-item img{
	width: 100%;
	height: auto;
	border:1px solid #ccc;
}

.ts-slide-item img:hover{
	border:1px solid #0067a5;
}

#project-record .ts-slide-box {
  opacity: 0;
  display: none;
  /*transition: opacity .5s ease;*/
}

#project-record .ts-slide-box.slick-initialized {
  opacity: 1;
  display: block;
}

/* ハイライトスライド */
#highlight{
	width: 100%;
	max-width: 2000px;
	padding: 80px 0px;
	margin:0 auto 0;
}

.highlight-slide-box{
	width: 100%;
	background-image: url(../img/highlight_bk.jpg);
	background-size: cover;
	background-position: center top;
	padding: 150px 0px 150px 0!important;
}

.highlight-slide-box li{
	margin-right: 70px;
}



.case-area{
	width: 100%;
	color: var(--color-saphire-blue);
	background-color: rgb(255,266,255,0.8);
	padding: 40px;
	margin-left: 36px;
	transition: all .5s ease;
}

.case-area:hover{
	background-color: rgb(255,266,255,1);
}

.category{
	font-size: 0.875rem;
	line-height: 1.5;
	font-weight: bold;
	margin-bottom: 20px;
}

.case-title{
	width: 100%;
	font-size: 1.5rem;
	line-height: 1.5;
	overflow: hidden;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	/* ブラウザがサポートしていない場合のフェールセーフ */
  	height: 78px;
  	max-height: 78px;
	margin-bottom: 20px;
}

.post-date{
	font-size: 0.875rem;
	line-height: 1.5;	
}

#highlight .highlight-slide-box {
  opacity: 0;
  display: none;
  /*transition: opacity .5s ease;*/
}

#highlight .highlight-slide-box.slick-initialized {
  opacity: 1;
  display: block;
}

/* グローバル拠点 */
#globalbase{
	width: 100%;
	padding-bottom: 60px;
}

.base-wrap{
	width: 85%;
	max-width: 75rem;
	margin:0 auto 0;
}

ul.tab-btn-block{
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  -ms-flex-wrap:wrap;
  -webkit-flex-wrap:wrap;
  flex-wrap:wrap;
  border-bottom: 1px solid var(--color-saphire-blue);
}

ul.tab-btn-block li{
  width: 31.3%;
  margin-right: 3%;
  display: block;
  position: relative;
}

ul.tab-btn-block li:nth-of-type(3n){
  margin-right: 0;
}

.tab-btn{
	width: 100%;
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	color: #ccc;
	font-weight: bold;
	text-align: center;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-bottom: 1px solid var(--color-saphire-blue);
	padding: 20px;
	position: relative;
	top:1px;
	transition: all .3s ease;
	cursor: pointer;
}

.tab-btn:hover{
	color: var(--color-saphire-blue);
	border-top: 1px solid var(--color-saphire-blue);
	border-left: 1px solid var(--color-saphire-blue);
	border-right: 1px solid var(--color-saphire-blue);
}

.tab-btn.active{
	width: 100%;
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	font-weight: bold;
	text-align: center;
	border-top: 1px solid var(--color-saphire-blue);
	border-left: 1px solid var(--color-saphire-blue);
	border-right: 1px solid var(--color-saphire-blue);
	border-bottom: 1px solid #ffffff;
	padding: 20px;
	position: relative;
	top:1px;
}

.inner-panel{
	width: 100%;
	display: none;
}

.inner-panel.active{
	width: 100%;
	display: flex;
	opacity: 1;
}

.tab-inner-content-block{
	width: 100%;
	padding-top: 20px;
}

.bace-link-block{
	width: 20%;
}

ul.base-link-list li{
	border-bottom:1px solid var(--color-saphire-blue);
}

ul.base-link-list li:last-child{
	border-bottom:none;
}

.country-title{
	width: 100%;
	font-size: 0.75rem;
	color: #FFF;
	background: rgba(0,103,165,0.8);
	padding: 5px 10px;
}

.bace-link{
	width: 100%;
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	/*font-weight: 300;*/
	color: var(--color-saphire-blue);
	padding: 10px;
	transition: all .5s ease;
	cursor: pointer;
}

.bace-link:hover{
	background-color: #f5f5fa;
}

.bace-link.active{
	width: 100%;
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	/*font-weight: 300;*/
	color: #fff;
	background-color:var(--color-saphire-blue); 
	padding: 10px;
}


.bace-text-area{
	width: 100%;
	display: none;
}

.bace-text-area.active{
	width: 100%;
	display: block;
	color: #fff;
	background:rgba(0,103,165,0.8);
	padding: 40px 60px;
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.bace-text-area a{
	color: #fff;
	text-decoration: underline;
}

.bace-link-us{
	width: 100%;
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	/*font-weight: 300;*/
	color: var(--color-saphire-blue);
	padding: 10px;
	transition: all .5s ease;
	cursor: pointer;
}

.bace-link-us:hover{
	background-color: #f5f5fa;
}

.bace-link-us.active{
	width: 100%;
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	/*font-weight: 300;*/
	color: #fff;
	background-color:var(--color-saphire-blue); 
	padding: 10px;
}

.bace-text-area-us{
	width: 100%;
	display: none;
}

.bace-text-area-us.active{
	width: 100%;
	display: block;
	color: #fff;
	background:rgba(0,103,165,0.8);
	padding: 40px 60px;
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.bace-text-area-us a{
	color: #fff;
	text-decoration: underline;
}

.bace-link-eu{
    width: 100%;
    display: block;
    font-size: 1rem;
    line-height: 1.5;
    /*font-weight: 300;*/
    color: var(--color-saphire-blue);
    padding: 10px;
    transition: all .5s ease;
    cursor: pointer;
}

.bace-link-eu:hover{
    background-color: #f5f5fa;
}

.bace-link-eu.active{
    width: 100%;
    display: block;
    font-size: 1rem;
    line-height: 1.5;
    /*font-weight: 300;*/
    color: #fff;
    background-color:var(--color-saphire-blue); 
    padding: 10px;
}

.bace-text-area-eu{
    width: 100%;
    display: none;
}

.bace-text-area-eu.active{
    width: 100%;
    display: block;
    color: #fff;
    background:rgba(0,103,165,0.8);
    padding: 40px 60px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.bace-text-area-eu a{
    color: #fff;
    text-decoration: underline;
}


.bace-text-block{
	width: 80%;
	height: 629px;
	overflow: hidden;
	background-image: url(../img/office-module-bg.png);
	background-position: center;
	background-size: 100% auto;
	background-repeat: no-repeat;
	border-left: 1px solid var(--color-saphire-blue);
	position: relative;
}

ul.address-list{
	display: flex;
}

ul.address-list li{
	font-size: 1rem;
	line-height: 1.5;
	/*font-weight: 300;*/
	width: 50%;
}

ul.address-list li p{
	font-size: 1rem;
	line-height: 1.5;
	/*font-weight: 300;*/	
}

.adress-title{
	font-size: 1.2rem;
	line-height: 1.5;
	/*font-weight: bold;*/
	/*font-weight: 300;*/
	margin-bottom: 10px;
}

@media screen and (min-width: 1641px) {
/* メインイメージ */
#main-image{
	width: 100%;
	max-width: 2000px;
	margin:0 auto 0;
	display:-ms-flexbox;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.main-image-wrap{
	width: 42%;
	position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    z-index: 3;
}

.main-image-wide-title{
	display: inline;
	font-size: 2rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	background-color: #fff;
	padding: 40px 60px 40px 200px;
}

.main-image-title{
	display: inline;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #fff;
	font-weight: bold;
	background-color: var(--color-saphire-blue);
	padding: 10px 30px 10px 30px;
}

.main-image-read{
	font-size: 2rem;
	line-height: 1.7;
	color: var(--color-saphire-blue);
	background-color: var(--color-bg-90);
	padding: 30px 30px 30px 30px;
	margin-top: 7px;
}

}

@media screen and (max-width: 1640px) {
/* メインイメージ */
#main-image{
	width: 100%;
	max-width: 2000px;
	margin:0 auto 0;
	display:-ms-flexbox;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.main-image-wrap{
	width: 45%;
	max-width: 45%;
	position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    z-index: 3;
}

.main-image-wide-title{
	display: inline;
	font-size: 2rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	background-color: #fff;
	padding: 40px 60px 40px 200px;
}

.main-image-title{
	display: inline;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #fff;
	font-weight: bold;
	background-color: var(--color-saphire-blue);
	padding: 10px 30px 10px 30px;
}

.main-image-read{
	font-size: 2rem;
	line-height: 1.7;
	color: var(--color-saphire-blue);
	background-color: var(--color-bg-90);
	padding: 30px 30px 30px 30px;
	margin-top: 7px;
}

}

@media screen and (max-width: 1531px) {
/* メインイメージ */
#main-image{
	width: 100%;
	max-width: 2000px;
	margin:0 auto 0;
	display:-ms-flexbox;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.main-image-wrap{
	width: 50%;
	max-width: 50%;
	position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    z-index: 3;
}

.main-image-wide-title{
	display: inline;
	font-size: 2rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	background-color: #fff;
	padding: 40px 60px 40px 200px;
}

.main-image-title{
	display: inline;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #fff;
	font-weight: bold;
	background-color: var(--color-saphire-blue);
	padding: 10px 30px 10px 30px;
}

.main-image-read{
	font-size: 2rem;
	line-height: 1.7;
	color: var(--color-saphire-blue);
	background-color: var(--color-bg-90);
	padding: 30px 30px 30px 30px;
	margin-top: 7px;
}

}

@media screen and (max-width: 1380px) {
/* メインイメージ */
#main-image{
	width: 100%;
	max-width: 2000px;
	margin:0 auto 0;
	display:-ms-flexbox;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.main-image-wrap{
	width: 52%;
	max-width: 52%;
	position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    z-index: 3;
}

.main-image-wide-title{
	display: inline;
	font-size: 2rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	background-color: #fff;
	padding: 40px 60px 40px 200px;
}

.main-image-title{
	display: inline;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #fff;
	font-weight: bold;
	background-color: var(--color-saphire-blue);
	padding: 10px 30px 10px 30px;
}

.main-image-read{
	font-size: 2rem;
	line-height: 1.7;
	color: var(--color-saphire-blue);
	background-color: var(--color-bg-90);
	padding: 30px 30px 30px 30px;
	margin-top: 7px;
}

}

@media screen and (max-width: 1327px) {
/* メインイメージ */
#main-image{
	width: 100%;
	max-width: 2000px;
	margin:0 auto 0;
	display:-ms-flexbox;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.main-image-wrap{
	width: 54%;
	max-width: 54%;
	position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    z-index: 3;
}

.main-image-wide-title{
	display: inline;
	font-size: 2rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	background-color: #fff;
	padding: 40px 60px 40px 200px;
}

.main-image-title{
	display: inline;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #fff;
	font-weight: bold;
	background-color: var(--color-saphire-blue);
	padding: 10px 30px 10px 30px;
}

.main-image-read{
	font-size: 2rem;
	line-height: 1.7;
	color: var(--color-saphire-blue);
	background-color: var(--color-bg-90);
	padding: 30px 30px 30px 30px;
	margin-top: 7px;
}

}

@media screen and (max-width: 1300px) {
/* メインイメージ */
#main-image{
	width: 100%;
	max-width: 2000px;
	margin:0 auto 0;
	display:-ms-flexbox;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.main-image-wrap{
	width: 50%;
	max-width: 50%;
	position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    z-index: 3;
}

.main-image-wide-title{
	display: inline;
	font-size: 1.7rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	background-color: #fff;
	padding: 40px 60px 40px 200px;
}

.main-image-title{
	display: inline;
	font-size: 1.1rem;
	line-height: 1.5;
	color: #fff;
	font-weight: bold;
	background-color: var(--color-saphire-blue);
	padding: 10px 30px 10px 30px;
}

.main-image-read{
	font-size: 1.7rem;
	line-height: 1.7;
	color: var(--color-saphire-blue);
	background-color: var(--color-bg-90);
	padding: 30px 30px 30px 30px;
	margin-top: 7px;
}

}

/*パンクズ*/
#breadcrumb-list{
	width: 85%;
	max-width: 75rem;
	margin:0px auto 0px;
	padding-top: 20px;
}

#breadcrumb-list ul{
	display: flex;
}

#breadcrumb-list li{
	font-size: 0.875rem;
	line-height: 1.5;
}

#breadcrumb-list li::after{
	content: '/';
	margin: 0px 10px;
}

#breadcrumb-list li:last-child::after{
	content:'';
	margin:0;
}

#breadcrumb-list li a{
	color: var(--color-saphire-blue);
}

.c-breadcrumb__item{
  display: inline-block;  /* インライン要素でも幅制限を適用 */
  max-width: 900px;       /* 適切な最大幅を設定 */
  white-space: nowrap;    /* テキストを1行に制限 */
  overflow: hidden;       /* 見切れた部分を隠す */
  text-overflow: ellipsis; /* 省略記号を表示 */
}

#service-dsc-block{
	width: 85%;
	max-width: 75rem;
	height: 420px;
	color: #fff;
	display: flex;
	align-items: center;
	background-image: url(../img/service_dec_block_bk.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	margin:0 auto 0;
}

#service-dsc-block4{
	width: 85%;
	max-width: 75rem;
	height: 420px;
	color: #fff;
	display: flex;
	align-items: center;
	background-image: url(../img/career_company_bk.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	margin:0 auto 0;
}

.service-dsc-block-left-inner{
	width: 50%;
	background:rgba(0,0,0,0.2);
}

ul.service-dsc-menu-2{
	width: 100%;
}

ul.service-dsc-menu-2 li{
	width: 100%;
	height: 210px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-2 li:hover::after {
    content: "→";
/*    height: 1px;
    flex-grow: 1;
    background-color: #FFF;*/
    margin-left: 1.2rem;
    margin-right: 1.2rem;
}


ul.service-dsc-menu-2 li:hover{
	color: var(--color-saphire-blue);
	background-color: rgba(255,255,255,0.2);
}

ul.service-dsc-menu-2 li.active{
	width: 100%;
	height: 210px;
	font-size: 1.2rem;
	color: #FFF;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-2 li.active::before {
    content: "";
    height: 1px;
    flex-grow: 1;
    background-color: #FFF;
    margin-right: 1.2rem;
}

ul.service-dsc-menu-2 li.active::after {
    content: "→";
/*    height: 1px;
    flex-grow: 1;
    background-color: #FFF;*/
    margin-left: 1.2rem;
    margin-right: 1.2rem;
}
 

ul.service-dsc-menu-2 li:nth-of-type(2n){
	width: 100%;
	height: 210px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	background-color: rgba(255,255,255,0.1);
}

ul.service-dsc-menu-3 li{
	width: 100%;
	height: 140px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-3 li:hover::after {
    content: "";
    height: 1px;
    flex-grow: 1;
    background-color: var(--color-saphire-blue);
}
 
ul.service-dsc-menu-3 li:hover::after {
    margin-left: 1.2rem;
}

ul.service-dsc-menu-3 li:hover{
	color: var(--color-saphire-blue);
	background-color: rgba(255,255,255,0.2);
}

ul.service-dsc-menu-3 li.active{
	width: 100%;
	height: 140px;
	font-size: 1.2rem;
	color: var(--color-saphire-blue);
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-3 li.active::after {
    content: "";
    height: 1px;
    flex-grow: 1;
    background-color: var(--color-saphire-blue);
}
 
ul.service-dsc-menu-3 li.active::after {
    margin-left: 1.2rem;
}

ul.service-dsc-menu-3 li:nth-of-type(2n){
	width: 100%;
	height: 140px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	background-color: rgba(255,255,255,0.1);
}

ul.service-dsc-menu-4 li{
	width: 100%;
	height: 105px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-4 li:hover::after {
    content: "→";
    transition: all .5s ease;
    margin-right: 1.2rem;
}
 
ul.service-dsc-menu-4 li:hover::after {
    margin-left: 1.2rem;
    transition: all .5s ease;
}

ul.service-dsc-menu-4 li:hover{
	color: var(--color-saphire-blue);
	background-color: rgba(255,255,255,0.2);
	transition: all .5s ease;
}

ul.service-dsc-menu-4 li.active{
	width: 100%;
	height: 105px;
	font-size: 1.2rem;
	color: #FFF;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-4 li.active::before {
    content: "";
   	height: 1px;
    flex-grow: 1;
    background-color: #FFF;
    margin-right: 1rem;
    transition: all .5s ease;
}

ul.service-dsc-menu-4 li.active::after {
    content: "→";
    margin-left: 1.2rem;
    margin-right: 1.2rem;
    transition: all .5s ease;
}

ul.service-dsc-menu-4 li:nth-of-type(2n){
	width: 100%;
	height: 105px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	background-color: rgba(255,255,255,0.1);
	transition: all .5s ease;
}

ul.service-dsc-menu-6 li{
	width: 100%;
	height: 70px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-6 li:hover::after {
    content: "→";
    transition: all .5s ease;
    margin-right: 1.2rem;
}
 
ul.service-dsc-menu-6 li:hover::after {
    margin-left: 1.2rem;
    transition: all .5s ease;
}

ul.service-dsc-menu-6 li:hover{
	color: var(--color-saphire-blue);
	background-color: rgba(255,255,255,0.2);
	transition: all .5s ease;
}

ul.service-dsc-menu-6 li.active{
	width: 100%;
	height: 70px;
	font-size: 1.2rem;
	color: #FFF;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-6 li.active::before {
    content: "";
   	height: 1px;
    flex-grow: 1;
    background-color: #FFF;
    margin-right: 1rem;
    transition: all .5s ease;
}

ul.service-dsc-menu-6 li.active::after {
    content: "→";
    margin-left: 1.2rem;
    margin-right: 1.2rem;
    transition: all .5s ease;
}

ul.service-dsc-menu-6 li:nth-of-type(2n){
	width: 100%;
	height: 70px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	background-color: rgba(255,255,255,0.1);
	transition: all .5s ease;
}

/*ul.service-dsc-menu-6 li{
	width: 100%;
	height: 70px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-6 li:hover::after {
    content: "";
    height: 1px;
    flex-grow: 1;
    background-color: #fff;
}
 
ul.service-dsc-menu-6 li:hover::after {
    margin-left: 1.2rem;
}

ul.service-dsc-menu-6 li:hover{
	color: #FFF;
	background-color: rgba(255,255,255,0.2);
}

ul.service-dsc-menu-6 li.active{
	width: 100%;
	height: 70px;
	font-size: 1.2rem;
	color: #FFF;
	display: inline-flex;
	align-items: center;
	padding-left: 20px;
	transition: all .5s ease;
}

ul.service-dsc-menu-6 li.active::after {
    content: "";
    height: 1px;
    flex-grow: 1;
    background-color: #FFF;
}
 
ul.service-dsc-menu-6 li.active::after {
    margin-left: 1.2rem;
}

ul.service-dsc-menu-6 li:nth-of-type(2n){
	width: 100%;
	height: 70px;
	font-size: 1.2rem;
	display: inline-flex;
	align-items: center;
	background-color: rgba(255,255,255,0.1);
}*/


.service-dsc-block-right-inner{
	width: 50%;
}

.service-dsc-text-view{
	display: none;
}

.service-dsc-text-view.active{
	display: block;
}

.service2-dsc-text-view{
	display: none;
}

.service2-dsc-text-view.active{
	display: block;
}

.service3-dsc-text-view{
	display: none;
}

.service3-dsc-text-view.active{
	display: block;
}

.service-dsc-text-block{
	height: 420px;
	background-color: rgba(0,103,165,0.8);
	position: relative;
}

.service-dsc-text{
	width: 80%;
	font-size: 1rem;
	line-height: 1.7;
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.sector-block{
	width: 100%;
	height: 320px;
	color: var(--color-saphire-blue);
	background-color: #f5f5fa;
	padding: 20px;
	transition: all .5s ease;
}

.sector-block:hover{
	color: #FFF;
	background-color: var(--color-saphire-blue);
}

.sector-block p{
	font-size: 1rem;
	line-height: 1.7;
}

.sector-block-small{
	width: 100%;
	color: var(--color-saphire-blue);
	background-color: #f5f5fa;
	padding: 20px 20px 10px 20px;
	transition: all .5s ease;
	position: relative;
}

.sector-block-small:hover{
	color: #FFF;
	background-color: var(--color-saphire-blue);
}

.sector-block-small i{
	font-size: 1.5rem;
	position: absolute;
	top:40px;
	right: 20px;
}

.sector-title{
	font-size: 1.5rem;
	line-height: 1.5;
}

.sector-title-en{
	font-size: 0.875rem;
	line-height: 1.5;
}

.sector-read-text{
	font-size: 0.875rem;
	line-height: 1.7;
}

/* 記事 */
#post-area{
	width: 100%;
	margin-top: 90px;
}

.post-wrap{
	width: 85%;
	max-width: 75rem;
	margin:30px auto 60px;
}

/* メンバー */
.member-block{
	display: flex;
}

.member-photo{
	width: 15%;
	margin-right: 2%;
}

.member-photo img{
	width: 100%;
	height: auto;
}

.member-profile{
	width: 85%;
}

.member-profile a{
	color: var(--color-saphire-blue);
}

.member-name{
	font-size: 2rem;
	line-height: 1.5;
	margin-bottom: 5px;
}

.member-post{
	font-size: 1rem;
	line-height: 1.5;
	margin-bottom: 10px;
}

.member-career-block{
	width: 70%;
	font-size: 1rem;
	line-height: 1.7;
	margin:20px 0px 30px 0px;
}

/* 実績ブロック */
.ts-block{
	width: 100%;
	display: flex;
}

.ts-photo{
	width: 20%;
	margin-right: 5%;
}

.ts-photo-line {
  width: fit-content; /* 内容に応じた幅にする */
  max-width: 250px;   /* 最大幅を250pxに制限 */
}

.ts-photo-line img {
  max-width: 100%;    /* コンテナ内で縮小される */
  height: auto;
  border: 1px solid #ddd;
}

.ts-sub-photo {
  width: fit-content; /* 内容に応じた幅にする */
  max-width: 250px;   /* 最大幅を250pxに制限 */
}

.ts-sub-photo img {
  max-width: 100%;    /* コンテナ内で縮小される */
  height: auto;
}

.ts-detail{
	width: 75%;
	font-size: 1.125rem;
	line-height: 1.7;
}

.ts-post{
	width: 100%;
	
}

.ts-post ul{
	width: 100%;
	list-style-type: disc;
	padding-left: 2em;
	margin-bottom:1em;
}

.ts-post ul li{
	width: 100%;
	line-height: 1.5;
	margin:10px 0px;
}


.ts-post ol{
	width: 100%;
	list-style-type: decimal;
	padding-left: 18px;
	margin-bottom: 1em;
}

.ts-post ol li{
	width: 100%;
	margin: 10px 0px;
}

.ts-post p{
	width: 100%;
	margin-bottom: 0.5em;
}

.ts-post strong{
	font-weight: bold;
}

.ts-post a{
	text-decoration: underline;
	color: var(--color-saphire-blue);
}

/* 会社概要 */
.company-wrap{
	width: 85%;
	max-width: 75rem;
	margin:0 auto 0;
}

table.company-table{
	width: 100%;
	border-top:2px solid #525766;
	border-bottom:2px solid #525766;
}

table.company-table tr{
	width: 100%;
	border-bottom:1px solid #ccc;
}

table.company-table th{
	width: 20%;
	font-size: 1rem;
	line-height: 1.7;
	text-align: left;
	padding: 15px;
}

table.company-table td{
	width: 80%;
	font-size: 1rem;
	line-height: 1.7;
	text-align: left;
	padding: 15px;
}

/* 規約 */
#terms-area{
	width: 100%;
	margin-top: 90px;
}

.terms-wrap{
	width: 85%;
	max-width: 75rem;
	font-size: 1rem;
	line-height: 1.7;
	margin:30px auto 60px;
}

.terms-wrap p{
	margin-bottom: 20px;
}

.terms-wrap a{
	color: var(--color-saphire-blue);
	text-decoration: underline;
}

.term-main-title{
	font-size: 1.5rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	margin: 40px 0px 20px 0px;
}

.terms-wrap table{
	width: 95%;
	margin:20px auto 20px;
}

.terms-wrap table th{
	border:1px solid #525766;
	background-color: #f2f2f2;
	text-align: left;
	padding: 5px 10px;
}

.terms-wrap table td{
	border:1px solid #525766;
	text-align: left;
	padding: 10px;
}

.terms-wrap ol{
  counter-reset: item;
  list-style-type: none;
  padding-left: 1em;
}

.terms-wrap ol ol{
  padding-left: 1em;
}

.terms-wrap li{
  text-indent: -1.3em;
  padding-left: 1.3em;
  margin:5px 0px;
}

.terms-wrap li:before {
  counter-increment: item;
  content: counter(item)'.';
  /* 以下は自由に装飾... */
  padding-right: .3em;
  /*color: var(--color-saphire-blue);*/
}

/* フッター */
footer{
	width: 100%;
	color: #fff;
	background-color: #002855;
}

.foot-content{
	width: 85%;
	max-width: 75rem;
	margin:0 auto 0;
}

ul.foot-main-menu-block{
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	padding: 80px 0px 30px 0px;
}

ul.foot-main-menu-block li{
	width: 20%;
	font-size: 1rem;
}

ul.foot-main-menu-block li i{
	font-size: 1.2rem;
}

ul.foot-main-menu-block li:last-child{
	margin-right: 0;
}

ul.foot-main-menu-block li a{
	color: #FFF;
	position: relative;
}

ul.foot-main-menu-block li a::after {
	content: '';
	position: absolute;
	bottom: -5px;
	left: 0;
	z-index: 3;
	background:#fff;
	width: 100%;
	height: 1px;
	transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	transform-origin: right top;
}

ul.foot-main-menu-block li a:hover{
	color: #fff;
}

ul.foot-main-menu-block li a:hover::after {
	transform-origin:left top;
	transform:scale(1, 1);
}

.foot-menu-title{
	font-size:0.875rem;
	border-bottom: 1px solid #fff;
	padding-bottom: 5px;
}

ul.foot-menu-link{
	width: 100%;
	display: block;
	margin-left: 10px;
}

ul.foot-menu-link li{
	width: 100%;
	display: block;
	margin-bottom: 15px;
}

ul.foot-menu-link li a{
	font-size: 0.875rem;
	line-height: 1.5;
}

ul.foot-menu-link li:last-child{
	margin-bottom: 0;
}

ul.foot-menu-link-harf{
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.foot-menu-link-harf li:nth-of-type(1n){
	width: 63%;
	margin-bottom: 10px;
}

ul.foot-menu-link-harf li:nth-of-type(2n){
	width: 37%;
	margin-bottom: 10px;
}

ul.foot-menu-link-harf li a{
	font-size: 0.875rem;
	line-height: 1.5;
	color: #FFF;
}


ul.foot-sub-menu{
	width: 100%;
	font-size: 0.875rem;
	line-height: 1.5;
	display: flex;
	justify-content: center;
	padding: 30px 0px;
}

ul.foot-sub-menu li{
	margin-right: 15px;
}

ul.foot-sub-menu li:last-child{
	margin-right: 0;
}

ul.foot-sub-menu li::after{
	content: '|';
	margin-left: 15px;
}

ul.foot-sub-menu li:last-child::after{
	content: '';
	margin-left: 0;
}

ul.foot-sub-menu li a{
	color: #FFF;
	position: relative;
}

ul.foot-sub-menu li a::after {
	content: '';
	position: absolute;
	bottom: -5px;
	left: 0;
	z-index: 3;
	background:#fff;
	width: 100%;
	height: 1px;
	transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	transform-origin: right top;
}

ul.foot-sub-menu li a:hover{
	color: #fff;
}

ul.foot-sub-menu li a:hover::after {
	transform-origin:left top;
	transform:scale(1, 1);
}


/* メンバートップ */ 
a.contact-text-link{
	color: var(--color-saphire-blue);
}

.member-search-area{
	width: 100%;
	background-color: #f5f5fa;
	padding: 30px;
}

.member-search-block{
	width: 100%;
	display: flex;
	align-items: center;
}

.member-search-input{
	width: 63%;
	margin-right: 5%;
}

.member-search-btn{
	width: 15%;
	margin-right: 2%;
}

.member-reset-btn{
	width: 15%;
}

.member-search-input input{
	width: 100%;
	font-size: 1rem;
	padding: 14px 20px; 
	border:1px solid var(--color-saphire-blue);
}

.member-search-input input:focus{
	outline: none;
}

button.search-btn-white{
	width: 100%;
	display: block;
	font-size: 1rem;
	color:var(--color-saphire-blue);
	background-color:#FFF;
	border:1px solid var(--color-saphire-blue);
	cursor: pointer;
	padding: 10px;
	transition: all .5s ease;
}

button.search-btn-white:hover{
	color: #FFF;
	background-color:var(--color-saphire-blue);
}

button.reset-btn-white{
	width: 100%;
	display: block;
	font-size: 1rem;
	color:#525766;
	background-color:#FFF;
	border:1px solid #525766;
	cursor: pointer;
	padding: 10px;
	transition: all .5s ease;
}

button.reset-btn-white:hover{
	color: #FFF;
	background-color:#525766;
}

/* 実績トップ */
.ts-search-area{
	width: 100%;
	background-color: #f5f5fa;
	padding: 30px;
}

.ts-search-block{
	width: 100%;
	display: flex;
	margin-bottom: 20px;
}

.ts-search-block-center{
	width: 100%;
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}

.ts-search-title{
	width: 20%;
	font-size: 1rem;
	line-height: 1.5;
}

.ts-search-box{
	width: 80%;
}

ul.ts-search-input-list{
	width: 100%;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.ts-search-input-list li{
	margin-right: 20px;
	margin-bottom: 20px;
}

ul.ts-search-input-list li:last-child{
	margin-right: 0px;
}

.chk_label {
  display: inline-block;
  padding:7px 20px;
  background-color: #fff; /* 未チェック時の背景色 */
  cursor: pointer;
  border:1px solid var(--color-saphire-blue);
  border-radius: 25px;
  font-size: 1rem;
  transition: background-color 0.3s ease; /* 背景色の変化をスムーズにする */
}

.chk_label input[type="checkbox"] {
  display: none; /* チェックボックスを隠す */
}

.chk_label:has(input[type="checkbox"]:checked) {
  background-color: var(--color-saphire-blue); /* チェックされた時の背景色 */
  color: #fff; /* チェックされた時のテキスト色 */
}

select.ts_select {
width: 30%;
  background-color: white;
  border: thin solid var(--color-saphire-blue);
  border-radius: 4px;
  display: inline-block;
  font: inherit;
  font-size: 1rem;
  line-height: 1.5em;
  padding: 0.5em 3.5em 0.5em 1em;
  margin: 0;      
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #FFF 50%),
    linear-gradient(135deg, #FFF 50%, transparent 50%),
    linear-gradient(to right, #0067a5, #0067a5);
  background-position:
    calc(100% - 20px) calc(1em + 2px),
    calc(100% - 15px) calc(1em + 2px),
    100% 0;
  background-size:
    5px 5px,
    5px 5px,
    2.5em 2.5em;
  background-repeat: no-repeat;
}

select.ts_select:focus {
  background-image:
    linear-gradient(45deg, white 50%, transparent 50%),
    linear-gradient(135deg, transparent 50%, white 50%),
    linear-gradient(to right, #0067a5, #0067a5);
  background-position:
    calc(100% - 15px) 1em,
    calc(100% - 20px) 1em,
    100% 0;
  background-size:
    5px 5px,
    5px 5px,
    2.5em 2.5em;
  background-repeat: no-repeat;
  border-color: #0067a5;
  outline: 0;
}

.ts-search-box input{
	width: 60%;
	font-size: 1rem;
	padding: 14px 20px; 
	border:1px solid var(--color-saphire-blue);
}

.ts-search-box input:focus{
	outline: none;
}

ul.ts-search-btn-area{
	width: 100%;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;
	margin-top: 30px;
}

ul.ts-search-btn-area li{
	margin-right: 40px;
}

ul.ts-search-btn-area li:last-child{
	margin-right: 0px;
}

button.ts-search-btn{
	width: 200px;
	display: block;
	font-size: 1rem;
	color:var(--color-saphire-blue);
	background-color:#FFF;
	border:1px solid var(--color-saphire-blue);
	cursor: pointer;
	padding: 10px;
	transition: all .5s ease;
}

button.ts-search-btn:hover{
	color: #FFF;
	background-color:var(--color-saphire-blue);
}

input[type="reset"]{
	width: 100px;
	display: block;
	font-size: 1rem;
	color:#525766;
	border:none;
	background-color: transparent;
	cursor: pointer;
	padding: 10px;
	transition: all .5s ease;
}

input[type="reset"]:hover{
	color:var(--color-saphire-blue);
}

.ts-item-area{
	width: 100%;
	position: relative;
	overflow: hidden;
	cursor: pointer;
}

.ts-detail-box{
	width: 100%;
	height: 100vh;
	background-color:rgba(0,0,0,0.5);
}

.ts-image{
	width: 100%;

}

.ts-image img{
	width: 100%;
	height: auto;
	border:1px solid #ddd;
}

.ts-list-text-block{
	width: 100%;
	height: 100vh;
	background-color: rgba(0,103,165,0.7);
	position: absolute;
	top:0;
	left: 0;
	padding: 10px;
	opacity: 0;
	transition: all .5s ease;
}

.ts-list-text-block:hover{
	opacity: 1;
}

.ts-list-text{
	width: 100%;
	font-size: 0.875rem;
	line-height: 1.5;
	color: #fff;
	overflow: hidden;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	/* ブラウザがサポートしていない場合のフェールセーフ */
	max-height: 42px;
	margin-bottom: 5px;
}


/* インサイト */
#insight-slide{
	width: 100%;
	max-width: 2000px;
	height: 536px;
	background-image: url(../img/1920_GettyImages-1042483354_1.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	padding: 120px 0px 80px 0px;
	position: relative;
	margin:0 auto 0;
}

@media screen and (max-width: 1640px) {
	#insight-slide{
		width: 100%;
		max-width: 2000px;
		height: 500px;
		background-image: url(../img/1920_GettyImages-1042483354_1.jpg);
		background-repeat: no-repeat;
		background-size: cover;
		padding: 120px 0px 80px 0px;
		position: relative;
		margin:0 auto 0;
	}
}

@media screen and (max-width: 1400px) {
	#insight-slide{
		width: 100%;
		max-width: 2000px;
		height: 480px;
		background-image: url(../img/1920_GettyImages-1042483354_1.jpg);
		background-repeat: no-repeat;
		background-size: cover;
		padding: 120px 0px 80px 0px;
		position: relative;
		margin:0 auto 0;
	}
}

@media screen and (max-width: 1300px) {
	#insight-slide{
		width: 100%;
		max-width: 2000px;
		height: 450px;
		background-image: url(../img/1920_GettyImages-1042483354_1.jpg);
		background-repeat: no-repeat;
		background-size: cover;
		padding: 120px 0px 80px 0px;
		position: relative;
		margin:0 auto 0;
	}
}

#insight-slide .prev{
  font-size: 42px;
  color: #FFF;
  position: absolute;
  top:50%;
  left: 10px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  z-index: 5;
  transition: all .5s ease;
  opacity: 0.7;
}

#insight-slide .prev:hover{
  opacity: 1;
}

#insight-slide .next{
  font-size: 42px;
  color: #FFF;
  position: absolute;
  top:50%;
  right: 10px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  z-index: 5;
  transition: all .5s ease;
  opacity: 0.7;
}

#insight-slide .next:hover{
  opacity: 1;
}

#insight-slide .insight-slide-box {
  opacity: 0;
  display: none;
  /*transition: opacity .5s ease;*/
}

#insight-slide .insight-slide-box.slick-initialized {
  opacity: 1;
  display: block;
}


#insight-slide .insight-slide-box li{
  transform: scale(0.8);
  opacity: 0.5;
  transition: all .5s ease;
}

#insight-slide .insight-slide-box li.slick-center {
  transform: scale(1);
  opacity: 1;
}

.insight-post-block{
	width: 100%;
	background-color: #FFF;
	overflow: hidden;
	position: relative;
	transition: all .5s ease;
}

.icon-block{
	position: absolute;
	top:10px;
	left: 10px;
	z-index: 5;
}

.insight-post-text{
	width: 100%;
	padding: 10px 20px;
	background-color: rgba(255,255,255,0.8);
	position: absolute;
	bottom:0px;
	left: 0;
	transition: all .5s ease;
}

.insight-post-text:hover{
	background-color: rgba(255,255,255,0.9);
	position: absolute;
	bottom:0px;
	left: 0;	
}

.insight-post-list-text{
	width: 100%;
	padding: 10px;
	background-color: rgba(255,255,255,0.8);
	position: absolute;
	bottom:0;
	left: 0;
	transition: all .5s ease;
}

.insight-post-list-text:hover{
	background-color: rgba(255,255,255,0.9);
	position: absolute;
	bottom:0px;
	left: 0;	
}

.blog-title{
	font-size: 1rem;
	line-height: 1.5;
	font-weight: bold;
	color: var(--color-saphire-blue);
	margin-bottom: 5px;
	overflow: hidden;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	/* ブラウザがサポートしていない場合のフェールセーフ */
	height: 48px;
	max-height: 48px;
}

.news-title{
	width: 88%;
	font-size: 1rem;
	line-height: 1.5;
	color: var(--color-saphire-blue);
	overflow: hidden;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	/* ブラウザがサポートしていない場合のフェールセーフ */
	max-height: 48px;
}

.news-time{
	width: 12%;
	font-size: 1rem;
	line-height: 1.5;
}

.event-title{
	font-size: 1rem;
	line-height: 1.5;
	font-weight: bold;
	color: var(--color-saphire-blue);
	overflow: hidden;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	/* ブラウザがサポートしていない場合のフェールセーフ */
	max-height: 48px;
	margin-bottom: 7px;
}

.post-summary{
	font-size: 0.875rem;
	line-height: 1.5;
	overflow: hidden;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	/* ブラウザがサポートしていない場合のフェールセーフ */
	max-height: 48px;
}


.insight-detail-link{
	font-size: 0.875rem;
	color: var(--color-saphire-blue);
	text-align: right;
}

.insight-detail-link a{
	font-size: 0.875rem;
	color: var(--color-saphire-blue);
	text-align: right;
}

.post-time{
	font-size: 12px;
	line-height: 1.5;
}

ul.insight-top-list{
	width: 100%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

ul.insight-top-list li{
	width: 32%;
	margin-right: 2%;
	margin-bottom: 20px;
	display: block;
}

ul.insight-top-list li:nth-of-type(3n){
	margin-right: 0;
}


/* ニュース */
.news-block{
	width: 100%;
	border-bottom: 1px dotted #ccc;
}

.news-list-wrap{
	width: 100%;
	transition: all .5s ease;
}

.news-list-wrap:hover{
	background-color: #f5f5fa;
}

.news-box{
	width: 95%;
	margin:0 auto 0;
	padding: 15px 0px;
	display: flex;
}

.event-block{
	width: 100%;
	/*margin-bottom: 30px;*/
}

/* イベント */
.event-list-wrap{
	width: 100%;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	transition: all .5s ease;
}

.event-list-wrap:hover{
	background-color: #f5f5fa;
}

.event-imege{
	width: 1%;
}

.event-imege img{
	width: 100%;
	height: auto;
	vertical-align: bottom;
}

.event-text{
	width: 99%;
	padding: 20px 10px 20px 30px;
}

table.event-table{
	width: 100%;
	font-size: 0.875rem;
	line-height: 1.5;
}

table.event-table th{
	width: 10%;
	text-align: left;
	padding: 5px 0px;
	vertical-align: top;
}

table.event-table td{
	width: 90%;
	text-align: left;
	padding: 5px 0px;
}

.freeinput{
	width: 100%;
}

.freeinput ul{
	width: 100%;
	list-style-type: disc;
	padding-left: 10px;
}

.freeinput ul li{
	width: 100%;
	margin: 10px;
}

.freeinput ol{
	width: 100%;
	list-style-type: decimal;
	padding-left: 18px;
}

.freeinput ol li{
	width: 100%;
	margin: 10px;
}

.freeinput strong{
	font-weight: bold;
}

.freeinput a{
	color: var(--color-saphire-blue);
	text-decoration: underline;
}

/* 採用 */
ul.btn-list{
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;	
}

ul.btn-list li{
	margin-right: 40px;
}

ul.btn-list li:last-child{
	margin-right: 0px;
}

ul.btn-list-center{
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;	
}

ul.btn-list-center li{
	margin-right: 40px;
}

ul.btn-list-center li:last-child{
	margin-right: 0px;
}

ul.btn-list-left{
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	justify-content: flex-start;	
}

ul.btn-list-left li{
	margin-right: 40px;
}

ul.btn-list-left li:last-child{
	margin-right: 0px;
}

ul.btn-list-right{
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	justify-content: flex-end;	
}

ul.btn-list-right li{
	margin-right: 40px;
}

ul.btn-list-right li:last-child{
	margin-right: 0px;
}

table.bosyu-table{
	width: 100%;
	border-collapse: separate;
	border-spacing: 10px 5px;
}

table.bosyu-table th{
	width: 20%;
	font-size: 1rem;
	line-height: 1.5;
	color: #FFF;
	font-weight: bold;
	text-align: center;
	vertical-align: middle;
	background-color: var(--color-saphire-blue);
	padding: 10px 0px;
}

table.bosyu-table td{
	width: 80%;
	font-size: 1rem;
	line-height: 1.5;
	border-bottom:1px solid var(--color-saphire-blue);
	padding: 10px 20px;
}
.bosyu-table ul{
	width: 100%;
	list-style-type: disc;
	padding-left: 10px;
}

.bosyu-table ul li{
	width: 100%;
	margin: 10px;
}

.bosyu-table ol{
	width: 100%;
	list-style-type: decimal;
	padding-left: 18px;
}

.bosyu-table ol li{
	width: 100%;
	margin: 10px;
}

#career-dsc-area{
	width: 85%;
	max-width: 75rem;
	height: 420px;
	color: #fff;
	display: flex;
	align-items: center;
	background-image: url(../img/career/career_bk.jpg?=ver1);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: cover;
	margin:0 auto 0;
}

.career-dsc-block{
	width: 100%;
	height: 420px;
	display: flex;
	justify-content: center;
	overflow: hidden;
	position: relative;
}

.career-dsc-block img{
	width: auto;
	height: 100%;
	max-height: 420px;
	display: block;
}

.career-dsc-text{
	width: 100%;
	font-size: 1rem;
	line-height: 1.7;
	background-color: rgba(0,103,165,0.8);
	padding: 20px;
	position: absolute;
	bottom: 0;
	z-index: 3;
}


.interview-q{
	font-size: 1.5rem;
	line-height: 1.5;
	font-weight: bold;
	margin-bottom: 15px;
    display: flex;
}

.interview-q p{
	font-weight: bold;
}

.interview-a{
	font-size: 1.2rem;
	line-height:1.7;
}

ul.interview-box{
	width: 85%;
	max-width: 75rem;
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	/*align-items: center;*/
	justify-content: center;
}

ul.interview-box li{
	width: 47.5%;
	margin-right: 5%;
	margin-bottom: 5%;
}

ul.interview-box li:nth-of-type(2n){
	margin-right: 0;
}

ul.interview-box li:last-child{
	margin-right: 0;
}

.interview-image{
	width: 100%;
	text-align: center;
}

.interview-image img{
	max-width: 100%;
	height: auto;
	vertical-align: top;
}

ul.interview-member-block{
	width: 85%;
	max-width: 75rem;
	color: #FFF;
	background-color: var(--color-saphire-blue);
	margin:0 auto 0;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	justify-content: center;
	margin-bottom: 30px;	
}

ul.interview-member-block li{
	width: 50%;
}

ul.interview-member-block li a{
	color: #FFF;
}

.interview-member-text-area{
	width: 100%;
	font-size: 1rem;
	line-height: 1.7;
	padding: 30px;
}

.interview-member-text-area a{
	color: #FFF;
}

.interview-member-name{
	font-size: 1.7rem;
	line-height: 1.5;
	margin-bottom: 10px;
}

.interview-member{
	width: 100%;
	box-shadow:0 0 5px 0 rgba(0,0,0,0.3);
	position: relative;
}

.interview-member-text{
	width: 100%;
	font-size: 0.75rem;
	line-height: 1.5;
	color: #FFF;
	background-color: rgba(0,103,165,0.8);
	padding: 10px;
	position: absolute;
	left: 0;
	bottom:0;
	z-index: 3;
}

.interview-member-name-text{
	font-size: 1.5rem;
	line-height: 1.5;
}

ul.tokucho-block{
	width: 85%;
	max-width: 75rem;
	margin:0 auto 60px;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	justify-content: center;
}

ul.tokucho-block li{
	width: 30%;
}

ul.tokucho-block li:nth-of-type(3n){
	margin-right: 0;
}

ul.tokucho-block li:last-child{
	margin-right: 0;
}

.tokucho-circle{
	width: 280px;
	height: 280px;
	color: var(--color-saphire-blue);
	margin:0 auto 0;
	border:1px solid var(--color-saphire-blue);
	border-radius: 560px;
	position: relative;
}

.tokucho-circle-text{
	width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.tokucho-circle-text p{
	font-size: 1rem;
	line-height: 1.5;
	text-align: center;
}

.tokucho-circle-text div{
	font-size: 0.75rem;
	line-height: 1.5;
	text-align: center;
}

.tokucho-circle-text span{
	font-size: 2rem;
}

.welfare-box{
	width: 100%;
}

.welfare-title{
	font-size: 1.2rem;
	line-height: 1.5;
	font-weight: bold;
	color: #FFF;
	background-color: var(--color-saphire-blue);
	padding: 10px;
}

.welfare-text{
	width: 100%;
	font-size: 1rem;
	line-height: 1.7;
	padding: 10px;
}

.welfare-text ul{
	width: 100%;
	list-style-type: disc;
	padding-left: 10px;
}

.welfare-text ul li{
	width: 100%;
	margin:10px;
}


.welfare-text ol{
	width: 100%;
	list-style-type: decimal;
	padding-left: 18px;
}

.welfare-text ol li{
	width: 100%;
	margin: 10px;
}

.welfare-text p{
	width: 100%;
	display: block;
}

a.welfare-link{
	width: 100%;
	display: block;
	color: var(--color-saphire-blue);
	text-align: right;
}

.freeimage{
	width: 100%;
	display: flex;
	justify-content: center;
	margin:2em 0px;
}

.freeimage img{
	max-width: 100%;
	height: auto;
}

.career-image{
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	align-items: center;
	position: relative;
}

.color-box1{
	width: 25%;
	height: 90px;
	font-size: 1rem;
	line-height: 1.5;
	text-align: right;
	color: #FFF;
	background-color: #2e63a6;
	/*background-image: linear-gradient(120deg, #FFF 69.6%, #2e63a6 69.6%);*/
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0px 10px;
}

.color-box2{
	width: 25%;
	display: block;
	height: 90px;
	font-size: 1rem;
	line-height: 1.5;
	text-align: right;
	color: #FFF;
	background-color: #5f90c7;
	/*background-image: linear-gradient(120deg, #FFF 61.8%, #5f90c7 61.8%);*/
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0px 10px;
}

.color-box3{
	width: 25%;
	height: 90px;
	font-size: 1rem;
	line-height: 1.5;
	text-align: right;
	color: #FFF;
	background-color: #93b6de;
	/*background-image: linear-gradient(120deg, #FFF 54%, #93b6de 54%);*/
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0px 10px;
}

.color-box4{
	width: 25%;
	height: 90px;
	font-size: 1rem;
	line-height: 1.5;
	text-align: right;
	color: var(--color-saphire-blue);
	background-color: #bfd7f2;
	/*background-image: linear-gradient(120deg, #FFF 46%, #bfd7f2 46%);*/
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0px 10px;
}

.color-box5{
	width: 25%;
	height: 90px;
	font-size: 1rem;
	line-height: 1.5;
	text-align: right;
	color: var(--color-saphire-blue);
	background-color: #e0eefb;
	/*background-image: linear-gradient(120deg, #FFF 38%, #e0eefb 38%);*/
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0px 10px;
}

.color-box5 p{
	text-align: right;
}

.color-box5 span{
	font-size: 12px;
	color: #525766;
	text-align: right;
}

.color-box6{
	width: 25%;
	height: 90px;
	font-size: 1rem;
	line-height: 1.5;
	text-align: right;
	color: var(--color-saphire-blue);
	background-color: #eef2f6;
	/*background-image: linear-gradient(120deg, #FFF 30%, #eef2f6 30%);*/
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0px 10px;
}

.color-box6 p{
	text-align: right;
}

.color-box6 span{
	font-size: 12px;
	color: #525766;
	text-align: right;
}


.career-image-text{
	width: 67%;
	height: 90px;
	font-size: 1rem;
	line-height: 1.7;
	border-bottom:1px solid var(--color-saphire-blue);
	display: flex;
	align-items: center;
	padding: 0px 20px;
	margin-left: 1%;
}

.career-image-bk{
	height: 100%;
	position: absolute;
	top:-1px;
	left: -1px;
	z-index: 4;
}

.career-image-bk img{
	width: auto;
	height: 100%;
}

ul.pagenation{
  width: 100%;
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  -ms-flex-wrap:wrap;
  -webkit-flex-wrap:wrap;
  flex-wrap:wrap;
  align-items: center;
  justify-content: center;
}

ul.pagenation li{
  display: inline-block;
  margin:0px 7px;
}

ul.pagenation li a{
  font-size: 1.125rem;
  line-height: 34px;
  text-align: center;
  width: 36px;
  height: 36px;
  display: inline-block;
  border:1px solid #ccc;
  border-radius: 4px;
}

ul.pagenation li a:hover{
  color: #fff;
  border:1px solid #FFF;
  background-color: var(--color-saphire-blue);
}

ul.pagenation .current{
  display: block;
  font-size: 1.125rem;
  line-height: 34px;
  text-align: center;
  color: #FFF;
  width: 36px;
  height: 36px;
  border:1px solid var(--color-saphire-blue);
  background-color: var(--color-saphire-blue);
  border-radius: 4px;
}

ul.event-tab-block{
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  -ms-flex-wrap:wrap;
  -webkit-flex-wrap:wrap;
  flex-wrap:wrap;
  border-bottom: 1px solid var(--color-saphire-blue);
}

ul.event-tab-block li{
  width: 48.5%;
  margin-right: 3%;
  display: block;
  position: relative;
}

ul.event-tab-block li:nth-of-type(2n){
  margin-right: 0;
}

ul.search-list{
	width: 100%;
	margin-bottom: 60px;
}

ul.search-list li{
	width: 100%;
	border-top: 1px solid #ccc;
}

ul.search-list li:last-child{
	border-bottom: 1px solid #ccc;
}

ul.search-list li a{
	width: 100%;
	display: block;
	color: var(--color-saphire-blue);
	padding:10px 15px;
}

ul.search-list li a:hover{
	background-color: #f5f5fa;
}

#insight-post{
	width: 100%;
	max-width: 60rem;
	margin:0 auto 0;
}

.insightinput{
	width: 100%;
	margin:2em 0;
}

.insightinput ul{
	width: 100%;
	list-style-type: disc;
	padding-left: 10px;
}

.insightinput ul li{
	width: 100%;
	margin: 10px;
}

.insightinput ol{
	width: 100%;
	list-style-type: decimal;
	padding-left: 18px;
}

.insightinput ol li{
	width: 100%;
	margin: 10px;
}

.insightinput p{
	margin-bottom: 0.5em;
}

.insightinput strong{
	font-weight: bold;
}

.insightinput a{
	color: var(--color-saphire-blue);
	text-decoration: underline;
}

ul.contact-tab-block{
  display:-ms-flexbox;
  display:-webkit-flex;
  display: flex;
  -ms-flex-wrap:wrap;
  -webkit-flex-wrap:wrap;
  flex-wrap:wrap;
  border-bottom: 1px solid var(--color-saphire-blue);
}

ul.contact-tab-block li{
	width: 23.5%;
	margin-right: 2%;
	display: block;
	position: relative;
}

ul.contact-tab-block li:nth-of-type(4n){
  margin-right: 0;
}

.contact-form-wrap{
	width: 50%;
}

/* 動画 */
.movie-play-btn{
	font-size: 80px;
	color: #FFF;
	cursor: pointer;
	position: absolute;
	top:40%;
	right: -100px;
	z-index: 3;
	transition: all .5s ease;
}

.movie-play-btn:hover{
	opacity: 0.7;
	transform: scale(0.90);
}

.movie-area{
	display: none;
	width: 100%;
	height: 100%;
	background:rgba(0,0,0,1);
	position: absolute;
	top:0;
	left: 0;
	z-index: 5;
}

.movie-close{
	font-size: 40px;
	color: #FFF;
	cursor: pointer;
	position: absolute;
	top:17%;
	right: 5%;
	z-index: 6;
	transition: all .5s ease;
}

.movie-close:hover{
	opacity: 0.7;
	transform: scale(0.90);
}

.video-area{
	width: 62%;
	position: absolute;
	bottom:0;
	left: 50%;
	transform: translateX(-50%);
}

.video-single-wrap{
	width: 85%;
	max-width: 56rem;
	margin:0 auto 30px;
}

.videomessage{
	font-size: 1rem;
	line-height: 1.7;
}

.videomessage p{
	font-size: 1rem;
	line-height: 1.7;
	margin-bottom: 0.5em;
}