@charset "utf-8";
/* CSS Document */



/*
* "Noto Sans JP" licensed under the SIL Open Font License 1.1
* by https://fonts.google.com/specimen/Noto+Sans+JP
*/
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  src: url("fonts/NS-400.woff2") format("woff2"), url("fonts/NS-400.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  src: url("fonts/NS-700.woff2") format("woff2"), url("fonts/NS-700.woff") format("woff");
  font-display: swap;
}


@font-face {
  font-family: "Montserrat", sans-serif;
  font-style: normal;
  font-weight: 900;
src: url("fonts/Montserrat-Black.woff2") format("woff2"), url("fonts/Montserrat-Black.woff") format("woff");
  font-display: swap;
}




/*--------------------------------------------------------------------------
   reset
---------------------------------------------------------------------------*/

h1,
h2,
h3,
h4,
h5,
h6,
p,
span,
small,
dl,
dt,
dd,
ol,
ul,
li {
	margin: 0;
	font-size: 100%;
}

ul {
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

img {
	vertical-align: top;
}

li {
	list-style-type: none;
	vertical-align: baseline;
}

input,
button,
textarea,
select {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}


/*--------------------------------------
　Base
---------------------------------------*/
*,
*::before,
*::after{
box-sizing: border-box;
}

img{
-webkit-backface-visibility: hidden;
}


body {
position: relative;
font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
font-weight: 400;
font-size:1.4em;
line-height:1.8;
color: #000;
text-align: justify;
}
body::before{
content: "";
position: absolute;
top: 0;
left: 50%;
width: .1rem;
height: 100%;
background:none;
opacity: .1;
}
.bodyInner, .bodyInner2{
position: relative;
}
.bodyInner::before,
.bodyInner::after,
.bodyInner2::before{
content: "";
position: absolute;
top: -1rem;
left: calc(50% - 27.5rem);
width: 55rem;
height: calc(100% + 2rem);
border: none;
opacity: .1;
}
.bodyInner::after{
width: 110rem;
left: calc(50% - 55rem);
}
.bodyInner2::before{
width: 165rem;
left: calc(50% - 82.5rem);
}



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

a {
color: #000;
text-decoration: none;
}

a:hover {
text-decoration: none;
}

p{
position: relative;
text-align: justify;
line-height:2.0;
}

p a{
text-decoration: underline;
}


.fl {
  float: left;
}

.fr {
  float: right;
}

.strong {
  font-weight: bold;
}

.f110 {
  font-size: 110%;
}

.f120 {
  font-size: 120%;
}

.f130 {
  font-size: 130%;
}

.f150 {
  font-size: 150%;
}

.f200 {
  font-size: 200%;
}

.f300 {
  font-size: 300%;
}

/* Micro clearfix */

/* For modern browsers */
.cf:before,.cf:after { content:""; display:table; }
.cf:after { clear:both; }
/* For IE 6/7 (trigger hasLayout) */
.cf { zoom:1; }


.flImg{
float:left;
}
.frImg{
float:right;
}


h1,h2{
position: relative;
font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
font-weight: 700;
padding: 0;
line-height: 1.5;
}
h3,h4,h5,h6{
position: relative;
font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
font-weight: 700;
padding: 0;
line-height: 1.5;
}


.sttl{
position: relative;
margin: 0 0 12px;
font-size:2.4rem;
font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
font-weight: 700;
line-height: 1.5;
}
.catch{
position: relative;
margin: 0 0 12px;
font-size:2.2rem;
font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
font-weight: 700;
line-height: 1.6;
}


.fontS{
font-size: 75%;
}
.fontL{
font-size: 133%;
}

.fontBold{
font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, "Helvetica Neue", Arial, sans-serif;
font-weight: 700;
}


.fontEng{
  font-family: "Montserrat", sans-serif;
  font-weight: 900;
}
.fontBl{
}
.fontGr{
}


html {
font-size: 62.5%;
}



.ulBox,
.liBox{
position: relative;
}




/*------------
600px--common
------------*/

.sp,
.sp_br{
display:none!important;
}
.sp2{
display:none;
}


body{
position: relative;
width: 100%;
min-width:1100px;
}

.forTab{
overflow: hidden;
}


a{
transition: all .2s ease-in-out;
}
a:hover{
opacity: 0.6;
}
a:hover img{
opacity: 1;
}

.mainWrap h1 a, .mainWrap h2 a, .mainWrap h3 a, .mainWrap h4 a, .mainWrap h5 a, .mainWrap h6 a{
text-decoration: none;
}


.areaInner{
position: relative;
width: 110rem;
margin: 0 auto;
}





/*--------------------------------------
　body_PC
---------------------------------------*/
*{
text-underline-offset: 0.15em;
}


/*--------------------------------------
　header_PC
---------------------------------------*/
#header{
position: relative;
z-index: 14;
background: #062d59;
}
#header::before{
content: "";
position: absolute;
z-index: 1;
top: 0;
left: 50%;
width: .1rem;
height: 100%;
background:none;
opacity: .3;
}
#header::after{
}
.headInner, .headInner2{
position: relative;
}
.headInner::before,
.headInner::after,
.headInner2::before{
content: "";
position: absolute;
z-index: 1;
top: -1rem;
left: calc(50% - 27.5rem);
width: 55rem;
height: calc(100% + 2rem);
border: none;
opacity: .3;
}
.headInner::after{
width: 110rem;
left: calc(50% - 55rem);
}
.headInner2::before{
width: 165rem;
left: calc(50% - 82.5rem);
}

.headInner3{
position: relative;
}
.headInner3::before{
content: "";
position: absolute;
top: 0;
right: 0;
width: 52.5rem;
height: 21rem;
background: url("./img/head_bg1.png") 100% 0 no-repeat;
}
.headInner3::after{
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 37rem;
height: 16rem;
background: url("./img/head_bg2.png") 0 100% no-repeat;
background-size: 37rem auto;
}




#header .topArea2{
position: absolute;
z-index: 4;
top: 1.0rem;
right: 2rem;
text-align: right;
font-weight: 700;
font-size:1.2rem;
line-height: 1.8;
color: #fff;
}
#header .siteName{
display: inline-block;
font-weight: 700;
}
#header .siteName a{
color: #fff;
}



#header .logo{
position: relative;
z-index: 5;
padding: .5rem 0 .5rem 1.5rem;
    width: fit-content;
}
#header .logoImg{
width:14.5rem;
}
#header .logo a{
display: block;
}
#header .logo img{
width: 100%;
}

#header .logotext{
        font-size: 1.2rem;
    color: #fff;
    position: relative;
    margin: -1rem 0 auto 0;
    z-index: 1;
	font-weight: 700;
	text-align: center;
}

#header .logotext span{
        font-size: 1rem;
}


/*--------------------------------------
　h1Area_PC
---------------------------------------*/
.h1Area{
position: relative;
z-index: 2;
margin: 0 0 1.5rem;
padding: 0 0 2rem;
}


.h1Area h1{
position: relative;
z-index: 1;
width: 110rem;
margin: 0 auto 2rem;
padding: 2rem 5rem 3.5rem;
text-align: center;
font-size:4.8rem;
color: #fff;
}
.h1Area h1::before{
}
.h1Area h1::after{
}
.h1Area .headNote{
}








/*--------------------------------------
　Main Contents_PC
---------------------------------------*/
#contents {
position: relative;
z-index: 14;
width: 100%;
overflow-x: hidden;
margin: 0 0 0;
padding: 0 0 6rem;
}
#contents::before{
}
.mainWrap {
position: relative;
z-index: 1;
padding: 0 0 5rem;
min-height: 50rem;
}

.mainWrap > .areaInner{
padding: 0 0 2rem;
}

.smappage a br{
display: none;
}


.index a,
.mainWrap a{
display: block;
}
.index p a,.mainWrap p a,
.index li a,.mainWrap li a,
.index td a,.mainWrap td a{
display: inline;
}


/*--------------------------------------
　pankuzu_PC
---------------------------------------*/
#pankuzuWrap{
position: relative;
width: 100%;
margin: 0 0 0;
}
#pankuzu{
width: 100%;
margin: 0 auto .5rem;
padding: 2rem 0 0;
font-size:1.2rem;
color: #666;
}
#pankuzu a{
display: inline;
text-decoration: underline;
color: #666;
}

#pankuzu br{
display: none;
}



/*--------------------------------------
　page-top_PC
---------------------------------------*/
#page-top {
position: fixed;
z-index: 101;
bottom: 2rem;
right: 1rem;
width: 70px;
}

#page-top{
  transition: .3s;
  /*デフォルトで非表示にする*/
  opacity: 0;
  visibility: hidden;
}
/*このクラスが付与されると表示する*/
#page-top.active{
  opacity: 1;
  visibility: visible;
}
/*このクラスが付与されると停止する*/
#page-top.absolute{
}





/*--------------------------------------
　Global Nav
---------------------------------------*/
#gNav_pc{
position: fixed;
top: 0;
right: 2.5rem;
z-index: 10000;


transition: .3s;
/*デフォルトで非表示にする*/
opacity: 0;
visibility: hidden;
}
/*このクラスが付与されると表示する*/
#gNav_pc.active{
opacity: 1;
visibility: visible;
}



/* ハンバーガーメニュー */

#gNav_pc #showRight2{
z-index: 10000;
}

#gNav_pc button{
position: relative;
width: 15rem;
height: 6.4rem;
background: #062d59;
border-radius:0 0 .6rem .6rem;
transition: .3s all;
}


#gNav_pc button span{
position: absolute;
left: 70%;
width: 12%;
height: .2rem;
background-color: #fff;
transition: .3s all;
}
#gNav_pc button span:nth-child(1){
top:34%;
}
#gNav_pc button span:nth-child(2){
top:calc(34% + .7rem);
}
#gNav_pc button span:nth-child(3){
top:calc(34% + 1.4rem);
}


#gNav_pc button.active span:nth-child(1){
  transform: translateY(0.7rem) rotate(-45deg);
}
#gNav_pc button.active span:nth-child(2){
  opacity: 0;
}
#gNav_pc button.active span:nth-child(3){
  transform: translateY(-0.7rem) rotate(45deg);
}

#gNav_pc button::before{
content: "MENU";
position: absolute;
top: 2.3rem;
left: 3.0rem;
line-height: 1;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:1.6rem;
color: #fff;
}



/* 展開内容 */

#gNav_pc .cbp-spmenu {
position: fixed;
margin: 0 0 0;
padding: 19.2rem 0 10rem;

/* TOP用 */
/* 
margin: 9.2rem 0 0;
padding: 10rem 0 10rem;
*/

background: #062d59;

overflow: auto;
-ms-overflow-style: none; /* IE, Edge 対応 */
scrollbar-width: none;/* Firefox 対応 */
}


#gNav_pc .cbp-spmenu #mainMenu2{
position: relative;
z-index: 1;
/*overflow: auto;*/
overflow: visible;
margin: 0 auto;
/*padding: 0 0 200px;*/
height: 100%;
width: 120rem;

display: flex;
flex-wrap: wrap;
/*justify-content: space-between;*/
}
#gNav_pc .cbp-spmenu #mainMenu2::-webkit-scrollbar{
display: none;/* Chrome, Safari 対応 */
}


#gNav_pc .cbp-spmenu #mainMenu2 .gnavBox{
position: relative;
width: 47%;
margin: 0 1.5%;
/*float: left;*/
}
#gNav_pc .cbp-spmenu #mainMenu2 .gnavBox:nth-child(2n){
/*float: right;*/
}



#gNav_pc .cbp-spmenu a {
display: block;
padding: 14px 1.8rem 14px 0;
text-decoration: none;
line-height: 1.3;
cursor: pointer;
color: #fff;
font-size:1.5rem;
}
#gNav_pc .cbp-spmenu .sttl{
margin: 0;
border-bottom: 1px solid rgba(255, 255, 255, .5);
}
#gNav_pc .cbp-spmenu .sttl a{
position: relative;
background: url("./img/arrow_ccl_wt.svg") calc(100% - 0.5rem) 50% no-repeat;
background-size: 2.0rem auto;
font-size:1.6rem;
}

#gNav_pc .cbp-spmenu .sttl.tglMenu{
position: relative;
}

#gNav_pc .cbp-spmenu .sttl.tglMenu a {
background: none;
}
#gNav_pc .cbp-spmenu .sttl.tglMenu a::before {
content: '';
display: inline-block;
width: 1.8rem;
height: .1rem;
background-color: #fff;
position: absolute;
right: 1.5rem;
top: 50%;
transform: translateY(-50%);
transition: opacity .5s;
}
#gNav_pc .cbp-spmenu .sttl.tglMenu a::after {
content: '';
display: inline-block;
width: 1.8rem;
height: .1rem;
background-color: #fff;
position: absolute;
right: 1.5rem;
top: 50%;
transform: translateY(-50%) rotate(-90deg);
transition: transform .5s;
}
#gNav_pc .cbp-spmenu .sttl.open a::before {
opacity: 0;
}
#gNav_pc .cbp-spmenu .sttl.open a::after {
transform: translateY(-50%) rotate(-180deg);
}




#gNav_pc .cbp-spmenu .home a {
background: url("./img/arrow_ccl_wt.svg") calc(100% - 0.5rem) 50% no-repeat;
background-size: 2.0rem auto;
}

#gNav_pc .cbp-spmenu .accChild{
/*position: absolute;*/

width: 100%;
z-index: 1;
}


#gNav_pc .cbp-spmenu li a {
background: url("./img/arrow_ccl_wt.svg") calc(100% - 0.5rem) 50% no-repeat;
background-size: 2.0rem auto;
padding: 1.4rem 5rem 1.4rem 0;
}

#gNav_pc .cbp-spmenu a:hover {
opacity: 0.6;
}
#gNav_pc .cbp-spmenu a:active {
}

/* Orientation-dependent styles for the content of the menu */

#gNav_pc .cbp-spmenu-vertical {
width: 100%;
height: 100%;
top: 0;
z-index: -1;
}
#gNav_pc .cbp-spmenu-vertical a {
/*border-bottom: 1px solid #848484;*/
padding: 22px 4rem 22px 0;
}


/* Vertical menu that slides from the left or right */

#gNav_pc .cbp-spmenu-right {
opacity: 0;
visibility: hidden;
/*right: -100vw;*/
right: 0;
}
#gNav_pc .cbp-spmenu-right.cbp-spmenu-open {
opacity: 1;
visibility: visible;
right: 0;
z-index: 1000;
}


/* Transitions */
#gNav_pc .cbp-spmenu,
#gNav_pc .cbp-spmenu-push {
transition: all 0.5s ease;
}

#gNav_pc .accChild {
display: none;
}

#gNav_pc .cbp-spmenu #mainMenu2 a br{
display: none;
}


body.body-fix{
overflow: hidden;
}


/* logo */
#gNav_pc .cbp-spmenu .logo{
position: relative;
top: -5rem;
width: 25rem;
margin: 0 auto;
}
#gNav_pc .cbp-spmenu .logo a{
display: block;
}
#gNav_pc .cbp-spmenu .logo img{
width: 100%;
}







/*--------------------------------------
　fixNav_PC
---------------------------------------*/

#fixNav{
position: fixed;
z-index: 1000;
top: 0;
right: 20rem;
transition: .3s;

/*width: 22.6rem;*/

/*デフォルトで非表示にする*/
opacity: 0;
visibility: hidden;
}
/*このクラスが付与されると表示する*/
#fixNav.active{
opacity: 1;
visibility: visible;
}
/*このクラスが付与されると停止する*/
#fixNav.absolute{
/*opacity: 0;
visibility: hidden;*/
}



#fixNav{
width: 100%;
display: flex;
justify-content: flex-end;
align-items: flex-end;
}
#fixNav .btn-web{
width: auto;
margin: 0 0 0 0;
}
#fixNav .btn-web a{
display: inline-block;
width: auto;
min-height: 0;
padding: 1.0rem 5.5rem 1.2rem 2.0rem;
border-radius: 0 0 .6rem .6rem;
box-shadow: none;
font-size:1.6rem;
text-align: left;
}
#fixNav .btn-web a .fontS{
display: block;
}
#fixNav .btn-web a::before{
top: 0;
right: 1.8rem;
width: 2.1rem;
height: 100%;
background: url("./img/arrow_out.svg") 0 50% no-repeat;
background-size: 2.1rem auto;
}
#fixNav .btn-web a::after{
top: calc(50% - 1.6rem);
right: 1.5rem;
width: 3.2rem;
height: 3.2rem;
}



/*--------------------------------------
　Footer_PC
---------------------------------------*/

footer{
position: relative;
z-index: 14;
width: 100%;
padding: 0;
background: #062d59;
}

footer .footInner{
width: 110rem;
margin: 0 auto;
padding: 0 0 2rem;
}



footer .footInner .areaL{
width: 37rem;
float: left;
}

footer .noticeArea{
color: #fff;
}
footer .noticeArea p{
font-size:1.2rem;
}
footer .noticeArea p:nth-child(1){
}
footer .noticeArea a{
text-decoration: underline;
color: #fff;
}
footer .noticeArea .botPrg{
padding: .8rem 0 0;
}




footer .footInner .areaR{
width: 68rem;
float: right;
}

footer .footBox{
position: relative;
z-index: 9;
margin: 0 0 40px;
text-align: left;
}


footer .footBox a{
color: #fff;
}

.footBox .sttl{
margin: 0 0 12px;
padding: 0 0 10px;
border-bottom: 1px solid rgba(255, 255, 255, .5);
}
.footBox .sttl a{
position: relative;
display: block;
padding: 4px 0 4px;
font-size:1.8rem;
line-height: 1.3;
}

footer .smap .sttl a{
font-size:1.8rem;
}

.footBox > ul{
padding: 0 0;
}
.footBox li{
display: inline-block;
}

.footBox li ul{
}

.footBox li a{
font-size:1.5rem;
}
.footBox li:after{
content: "　/　";
color: #fff;
}
.footBox li:last-child:after{
content: "";
}


.footBox li.subCat{
display: inline;
margin: 0 20px 0 0;
}
.footBox li.subCat:after{
content: "";
}
.footBox li.subCat > a{
}
.footBox li.subCat > a:after{
}
.footBox ul.subList{
display: inline;
}

.footBox ul.subList > li:first-child::before{
content: "：";
color: #fff;
}
.footBox ul.subList li:after{
content: " / ";
color: #fff;
}
.footBox ul.subList li:last-child::after{
content: "";
}
.footBox ul.subList a{
font-weight: 400;
}

.footBox a br{
display: none;
}


footer .botArea{
position: relative;
min-width: 110rem;
padding: 1.6rem 0 1.2rem;
box-sizing: border-box;
}
footer .botArea .botInner{
}
footer .botArea .copy{
padding: .8rem 2rem 1.2rem;
font-size:1.3rem;
text-align: center;
color: #fff;
}
footer .botArea .copy a{
text-decoration: none;
color: #fff;
}






/* ================== */
/*  PC共通パーツ　*/
/* ================== */
/* p */
.mainWrap p, .index p{
margin: 1.5rem 0;
padding: 0 0;
word-break: break-all;
}

.mainWrap p + p, .index p + p{
margin-top: 3rem;
}

.mainWrap h2{
position: relative;
margin: 7rem 0 3rem;
padding: 1.7rem 2rem 2rem 3.5rem;
background: #18487E;
background: linear-gradient(90deg, rgba(24, 72, 126, 1) 0%, rgba(6, 45, 89, 1) 100%);
font-size:3.4rem;
color: #fff;
}
.mainWrap h2::before{
content: "";
position: absolute;
top: 2rem;
left: 0;
width: .4rem;
height: calc(100% - 4rem);
background: #ffdc00;
}

.mainWrap h2::after{
}



.mainWrap h2 a{
position: relative;
display: block;
padding: 0 6rem 0 0;
background: url("./img/arrow_ccl_wt.svg") 100% calc(50% - 0px) no-repeat;
background-size: 3.0rem auto;
color: #fff;
}
.mainWrap h2 a::before{
}
.mainWrap h2 a::after{
}
.mainWrap h2 a:hover{
}
.mainWrap h2 a:hover::before{
}
.mainWrap h2 a:hover::after{
}




.mainWrap h3{
position: relative;
margin: 4rem 0 3rem;
padding: 1.4rem 1rem 1.7rem 1.0rem;
border-bottom: 1px solid #b2b2b2;
font-size:2.8rem;
}
.mainWrap h3::before{
content: "";
position: absolute;
bottom: -0.2rem;
left: 0;
width: 6.0rem;
height: .4rem;
background: #003e88;
}
.mainWrap h3::after{
}



.mainWrap h3 a{
position: relative;
z-index: 1;
display: block;
padding: 0 6rem 0 0;
background: url("./img/arrow_ccl.svg") 100% calc(50% - 0px) no-repeat;
background-size: 3.0rem auto;
}
.mainWrap h3 a::before{
}
.mainWrap h3 a::after{
}
.mainWrap h3 a:hover{
}
.mainWrap h3 a:hover::before{
}
.mainWrap h3 a:hover::after{
}



.mainWrap h4{
position: relative;
margin: 5rem 0 1rem;
padding: 1rem 1rem 1.5rem 2.8rem;
font-size:2.2rem;
color: #003e88;
}
.mainWrap h4::before{
content: "";
position: absolute;
top: 0;
left: 0;
width: 1.6rem;
height: 100%;
background: url(./img/deco1.svg) 0 45% no-repeat;
background-size: 1.6rem auto;
}

.mainWrap h4 a{
position: relative;
display: inline-block;
padding: 0 3.2rem 0 0;
background: url("./img/arrow_ccl.svg") 100% calc(50% + .2rem) no-repeat;
background-size: 2.5rem auto;
color: #003e88;
}

.mainWrap h5, .mainWrap h6{
position: relative;
margin: 4rem 0 3rem;
padding: 1rem 1rem 1.5rem 1rem;
font-size:2.2rem;
}
.mainWrap h5 a, .mainWrap h6 a{
position: relative;
display: inline-block;
padding: 0 3.2rem 0 0;
background: url("./img/arrow_ccl.svg") 100% calc(50% + .2rem) no-repeat;
background-size: 2.5rem auto;
}




.mainWrap h4 a::before, .mainWrap h5 a::before, .mainWrap h6 a::before{
}
.mainWrap h4 a::after, .mainWrap h5 a::after, .mainWrap h6 a::after{
}
.mainWrap h4 a:hover, .mainWrap h5 a:hover, .mainWrap h6 a:hover{
}
.mainWrap h4 a:hover::before, .mainWrap h5 a:hover::before, .mainWrap h6 a:hover::before{
}
.mainWrap h4 a:hover::after, .mainWrap h5 a:hover::after, .mainWrap h6 a:hover::after{
}




/* ulol */
.mainWrap ul,
.index ul,
#mainVis ul{
margin: 10px 0 10px;
padding:10px 10px 0;
}
.mainWrap ul li,
.index ul li,
#mainVis ul li{
position: relative;
padding:3px 0 3px 20px;
}
.mainWrap ul li::before,
.index ul li::before{
position: absolute;
content: "";
top: 1.2rem;
left: .2rem;
width: 1.0rem;
height: 1.0rem;
background: #003e88;
border-radius:50%;
}

.mainWrap ol {
margin: 20px 0 20px;
padding:10px 10px 0;
}
.mainWrap ol li{
padding:3px 0 3px 22px;
list-style: none;
position: relative;
counter-increment: number;
}

.mainWrap ol li::before{
position: absolute;
display: flex;
align-items: center;
justify-content: center;
top: .9rem;
left: 0;
width: 1.5rem;
height: 1.6rem;
background: #003e88;
text-align: center;
line-height: 1.0;
font-family: Arial, Helvetica, "sans-serif";
font-weight: 700;
font-size:1.3rem;
color: #fff;
}


.mainWrap ol li::before {
content: counter(number);
}


.mainWrap li a,
.index li a{
text-decoration: underline;
}
.mainWrap li a:hover,
.index li a:hover{
text-decoration: none;
}





/* btns */
.btn-internal,
.btn-web,
.btn-tel{
position: relative;
z-index: 1;
display: flex;
align-items: center;
justify-content: center;
margin: 4.5rem auto;
text-align: center;
}
.btn-internal a,
.btn-web a,
.btn-tel a{
position: relative;
top:0;
left: 0;
width: 36rem;
min-height: 7.6rem;
display: flex;
align-items: center;
justify-content: center;
padding: 1.4rem 8.0rem 1.6rem;
box-shadow:.6rem .6rem 0 #a4b0c3;
text-align: center;
line-height: 1.5;
font-size:1.5rem;
font-weight: 700;
color: #003e88;
transition: all .2s ease-in-out;
}
.btn-internal a::before,
.btn-web a::before,
.btn-tel a::before{
content: "";
position: absolute;
z-index: 10;
top: 0;
right: 2.0rem;
width: 2.4rem;
height: 100%;
background: url("./img/arrow_ccl.svg") 0 50% no-repeat;
background-size: 2.4rem auto;
transition: all .2s ease-in-out;
}
.btn-internal a::after,
.btn-web a::after,
.btn-tel a::after{
}



.btn-internal a{
background: #d4e4fc;
}



.btn-web a{
background: #f49105;
box-shadow:.6rem .6rem 0 #c87704;
color: #fff;
}
.btn-web a::before{
right: 2.0rem;
width: 2.3rem;
background: url("./img/arrow_out.svg") 0 50% no-repeat;
background-size: 2.3rem auto;
}


.btn-web.mn a {
       background: #559de7;
    box-shadow: .6rem .6rem 0 #2b6bad;
}


.btn-tel{
display: none;
}
.btn-tel a{
background: #ffe751;
box-shadow:.6rem .6rem 0 #cfbb42;
color: #000;
}
.btn-tel a::before{
content: "";
position: absolute;
top: 0;
right: 2.2rem;
width: 1.8rem;
height: 100%;
background: url(./img/ico_tel.svg) 0 calc(50% - 0rem) no-repeat;
background-size: 1.8rem auto;
}
.btn-tel a:hover{
}






.btn-link{
margin: 2rem 0;
text-align: right;
}
.btn-link a{
position: relative;
display: inline-block;
padding: 4px 3.0rem 5px 0;
background: url("./img/arrow_ccl.svg") 100% calc(50% + .1rem) no-repeat;
background-size: 2.4rem auto;
line-height: 1.5;
text-align: right;
font-weight: 700;
}
.btn-link a::before{
}






/* ================== */
/*  テーブル　　　　　*/
/* ================== */
table {
width: 98%;
margin:5rem auto 7rem;
}
table th {
width: 22%;
padding: 1.6rem 1.5rem;
background: #f5f5f5;
border: 1px solid #b2b2b2;
font-weight: 700;
line-height: 1.6;
text-align:center;
word-break: break-all;
}
table td {
background: #fff;
border: 1px solid #b2b2b2;
padding: 1.6rem 1.5rem;
line-height: 1.6;
word-break: break-all;
}
table a{
text-decoration: underline;
}
table a:hover{
text-decoration: none;
}

table td .caption{
white-space:normal;
}






/* ================== */
/*  PCカスタマイズ共通　*/
/* ================== */
.caption,
.source{
margin: 10px 0 0;
padding: 0 0 4px;
font-size:1.0rem;
line-height: 1.5;
color: #999;
/*overflow: auto;*/
letter-spacing: 0;
text-align: center;
word-break: break-all;

overflow: auto;
white-space: nowrap;
}
/*
.caption{
-ms-overflow-style: none;
scrollbar-width: none;
}
*/
.caption::-webkit-scrollbar{
height: 3px;
}
.caption::-webkit-scrollbar-track{
border-radius: 3px;
background: #eee;
}
.caption::-webkit-scrollbar-thumb{
border-radius: 3px;
background: #bbb;
}

.caption a {
display: inline;
color: #999;
text-decoration: underline;
}
.caption a:hover{
text-decoration: none;
}




.marker{
position: relative;
display: inline;
/*background: linear-gradient(transparent 75%, rgba(247, 243, 139, .8) 0%) no-repeat bottom 0 left; */
border-bottom: 2px solid #ff9500;

font-weight: 700;
line-height: 1;
}
.txt_bold{
font-weight: 700;
color: #003e88;
}


/* float-wrap */

.float-wrap{
margin: 50px 0;
padding: 0 20px;
}
.float-wrap .catch{
margin: 0 0 -1.5rem;
font-size:2.2rem;
}


.float-wrap .flame{
position: relative;
}


.float-wrap img{
width: auto;
}
.float-wrap p{
margin: 10px 0;
padding: 0;
}
.float-wrap ul{
display: inline-block;
margin: 10px 0;
}
.float-wrap .fl{
width: 43rem;
padding: 0 3rem 2rem 0;
text-align: left;
}
.float-wrap .fr{
width: 43rem;
padding: 0 0 2rem 3rem;
text-align: left;
}

.float-wrap .ct{
width: auto;
margin: 0 auto;
padding: 0 0 20px;
text-align: center;
}



/* ================== */
/*  サイトマップ*/
/* ================== */
.smap h2{
margin: 0 0 25px;
}
.smap ul{
margin: 0 0 70px;
}






/* ================== */
/*  追加パーツ*/
/* ================== */



/*--------------------------------------
　mokuji_PC
---------------------------------------*/

.mokuji{
transition: .3s;
/*デフォルトで非表示にする*/
opacity: 1;
/*visibility: hidden;*/
}
/*このクラスが付与されると表示する*/
.mokuji.active{
opacity: 1;
visibility: visible;
}
/*このクラスが付与されると停止する*/
.mokuji.absolute{
}


.mokuji{
position: relative;
margin: 3rem 15rem 8rem;
}
.mokuji .inner{
position: relative;
padding: 1rem 4rem 3rem;
background: #f5f5f5;
}

.mokuji .inner::before{
content: "INDEX";
position: absolute;
top: -1.0rem;
right: 1.2rem;
font-size:4.0rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
color: rgba(0, 62, 136, 0.3);
}

.mokuji .sttl{
margin: 0 0 1rem;
padding: .8rem 0 1.4rem;
border-bottom: 1px solid #b2b2b2;
font-size:2.0rem;
}


.mokuji #toc{
position: relative;
padding: 0 0 2rem;
}

.mokuji #toc ul{
margin:0;
padding:.5rem 0;
}
.mokuji #toc ul li{
position: relative;
margin: 2px 0;
padding: 2px 0 2px 40px;
text-align: left;
line-height: 1.4;
}
.mokuji #toc ul li.chapter-h-two{
counter-increment: count;
}
.mokuji #toc ul li.chapter-h-two::before {
content: counter(count, decimal-leading-zero)".";/*2桁対応*/
position: absolute;
top: 1.0rem;
left: .7rem;
transform: translate(0,-50%);
background: none;
font-weight: 900;
color: #003e88;
}

.mokuji li a{
display: inline-block;
width: auto;
padding: .4rem 0 .6rem;
background: none;
font-weight: 900;
text-decoration: none;
}

.mokuji #toc ul ul{
margin: 0;
padding: 0 0 2px;
}
/*
.mokuji #toc ul li.chapter-h-three {
padding: 0 0 0 6rem;
}
.mokuji #toc ul li.chapter-h-three::after {
content: "";
position: absolute;
top: 0;
left: 4.5rem;
width: 8px;
height: 100%;
background: url("./img/l_deco.png") 0 6px no-repeat;
background-size: 8px auto;
}
.mokuji #toc ul li.chapter-h-three::before {
width: 0;
height: 0;
background: none;
border: none;
}
*/
.mokuji li br{
display: none;
}


/* accordion_grd */
.mokuji .text {
height: 120px;
overflow: hidden;
}
.mokuji .show_more2 {
position: absolute;
bottom: 0;
left: 0px;
width: 100%;
height: 70px;
padding-top: 60px;
text-align: center;
line-height: 70px;
background: linear-gradient(
180deg,
rgb(245, 245, 245, 0) 0%,
rgb(245, 245, 245, 1) 40%
);
border-radius:0 0 15px 15px;
cursor: pointer;
transition: bottom 0.2s;
}
.mokuji .active{
background: none;
/*bottom: -20px;*/
}
.mokuji .show_more2 span{
position: relative;
top: -3rem;
display: inline-block;
width: 14rem;
min-height: 4rem;
padding: .6rem 3rem .8rem;
background: url(./img/plus.svg) 90% calc(50% - 0px) no-repeat #fff;
background-size: 1.4rem auto;
border-radius:9999px;
border: 1px solid #b2b2b2;
text-align: center;
line-height: 1.5;
font-weight: 900;
font-size:1.5rem;
}
.mokuji .active span{
background: url(./img/minus.svg) 90% 50% no-repeat #fff;
background-size: 1.4rem auto;
}






/* ================== */
/*  関連記事　　　　　*/
/* ================== */

#related-article p {
  margin: 0;
}

#related-article.related-article01-frame {
position: relative;
margin: 10rem 10rem 4rem;
padding: 1rem 4rem 2.5rem;
background: #f5f5f5;
}
#related-article.related-article01-frame::before{
content: "ARTICLE";
position: absolute;
top: -1.0rem;
right: 1.2rem;
font-size:4.0rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
color: rgba(0, 62, 136, 0.3);
}



#related-article .related-article01-title {
position: relative;
margin: 0 0 1.5rem;
padding: .8rem 0 1.4rem;
border-bottom: 1px solid #b2b2b2;
line-height: 1.5;
font-size:2.0rem;
font-weight: 900;
}

#related-article .related-article01-title span {
}

#related-article .related-article01-list {
margin: 1.5rem 0 0 0;
padding: 0 0 0;
}

#related-article .related-article01-list p {
margin: 0;
}

#related-article .related-article01-list li {
margin: 2rem 0 0;
padding: 0 0 0 0;
font-size: 100%;
line-height: 1.7;
position: relative;
list-style: none;
}

#related-article .related-article01-list li+li {
margin-top: 10px;
}

#related-article .related-article01-list li::before {
width: 0!important;
height: 0!important;
background: none!important;
border: none!important;
}

#related-article .related-article01-list a {
position: relative;
display: inline-block;
padding: 0 0 0 3.2rem;
text-decoration: none;
}
#related-article .related-article01-list a::before{
content: "";
position: absolute;
top: calc(50% - 1.25rem);
left: 0;
width: 2.5rem;
height: 2.5rem;
background: url("./img/arrow_ccl.svg") 0 50% / 2.5rem auto no-repeat;
transition: all .3s ease-in-out;
transform-origin: 0 50%;
}


#related-article .related-article01-list a:hover {
opacity: 0.6;
}

#related-article .relations-box#related-article .relations-box--column {
display: flex;
gap: 10px;
}

#related-article .relations-box__pic {
flex: 0 0 150px;
}
.is-hidden {
display: none;
}

.related-article01-more {
display: flex;
justify-content: center;
align-items: flex-end;
background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0, #fff 50%);
background-color: transparent;
width: 100%;
height: 25%;
position: absolute;
bottom: -40px;
left: 0;
padding: 2rem 0;
}


.related-article01-more.is-closed {
display: none;
}

.related-article01-btn {
position: relative;
top: -0.5rem;
display: inline-block;
width: 14rem;
min-height: 4rem;
padding: .6rem 3rem .8rem;
background: url(./img/plus.svg) 90% calc(50% - 0px) no-repeat #fff;
background-size: 1.4rem auto;
border-radius:9999px;
border: 1px solid #b2b2b2;
text-align: center;
line-height: 1.5;
font-weight: 900;
font-size:1.5rem;
}
.related-article01-btn:hover {
opacity: 0.6;
}






/* btns_PC */
.btns{
display: flex;
flex-wrap: wrap;
justify-content: center;
align-items:center;
padding: 1rem 6% 2rem;
}
.btns > div{
/*display: flex;*/
width: 38%;
margin: 2rem 1.8rem 1rem;
}
.btns .btn-internal a,
.btns .btn-web a,
.btns .btn-tel a{
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
}
.btns .btn-tel{
display: none;
}




/* check_PC */
.check{
position: relative;
margin: 4rem 0 4rem 4rem;
padding:1.8rem 1rem 2.0rem 6.5rem;
background:#f5f5f5;
font-size:2.2rem;
font-weight: 700;
line-height: 1.5;
}
.check::before{
content: "";
position: absolute;
top: calc(50% - 4.25rem);
left: -4rem;
width: 8.5rem;
height: 8.5rem;
background: url("./img/iconttl_ck.png") 0 0 no-repeat;
background-size: 8.5rem auto;
}

.point{
position: relative;
margin: 4rem 5rem 4rem 9rem;
padding:1.8rem 1rem 2.0rem 6.5rem;
background:#f5f5f5;
font-size:2.2rem;
font-weight: 700;
line-height: 1.5;
}
.point::before{
content: "";
position: absolute;
top: calc(50% - 4.25rem);
left: -4rem;
width: 8.5rem;
height: 8.5rem;
background: url("./img/iconttl_pt.png") 0 0 no-repeat;
background-size: 8.5rem auto;
}


.num{
position: relative;
margin: 4rem 5rem 4rem 9rem;
padding:1.8rem 1rem 2.0rem 6.5rem;
background:#f5f5f5;
font-size:2.2rem;
font-weight: 700;
line-height: 1.5;
}
.num::before{
content: "";
position: absolute;
top: calc(50% - 4.25rem);
left: -4rem;
width: 8.5rem;
height: 8.5rem;
background: url("./img/iconttl_num.png") 0 0 no-repeat;
background-size: 8.5rem auto;
}
.num .fontNum{
position: absolute;
top: calc(50% - 4.25rem);
left: -4rem;
display: flex;
align-items: center;
justify-content: center;
width: 8.5rem;
height: 8.5rem;
font-size:2.4rem;
font-weight: 900;
line-height: 1;
color: #fff;
}





/* sum_PC */
.sum{
position: relative;
margin: 12rem 0 12rem;
padding: 5.5rem 5rem 3rem;
background: #fffade;
overflow: hidden;
}
.sum::before{
content: "SUMMARY";
position: absolute;
z-index: 1;
top: 1.0rem;
right: 1.5rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:5.0rem;
line-height: 1;
color: #e88c0b;
opacity: .25;
}
.sum::after{
content: "";
position: absolute;
top: -6.5rem;
left: -3rem;
width: 16.8rem;
height: 15rem;
background: url(./img/sum_deco.png) 0 0 no-repeat;
    opacity: 0.4;
}

.sum .txtArea{
position: relative;
}
.sum .txtArea::before{
}

.sum .catch{
margin: 0 0 1.5rem;
padding: 0;
font-size:2.4rem;
line-height: 1.7;
}



/* intv_PC */
.intvWrap{
margin: 0 0 6rem;
}
.intv{
position: relative;
margin: 5rem 0 5rem;
padding: 0 0 3.0rem 5rem;
background: #f5f5f5;
}
.intv::before{
content: "INTERVIEW";
position: absolute;
z-index: 1;
top: 1.0rem;
right: 1.5rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:5.0rem;
line-height: 1;
color: #003e88;
opacity: .2;
}

.intv .imgArea{
position: absolute;
z-index: 1;
top: 4.5rem;
right: 5rem;
width: 31.5rem;
}
.intv .imgArea .flame{
margin: 0 0 1.5rem;
}
.intv .imgArea img{
width: 100%;
object-fit: cover;
}


.intv .txtArea{
padding: 6rem 0 0 0;
}
.intv .txtArea .spec{
font-size:1.7rem;
font-weight: 700;
}
.intv .txtArea .spec .boxYw{
display: inline-block;
margin: 0 1rem 0 0;
padding: .2rem 1rem .4rem;
background: #ffe751;
line-height: 1;
color: #003e88;
}
.intv .txtArea .catch{
margin: 0 0 2.5rem;
padding: 1rem 41rem 2.5rem 0;
font-size:2.8rem;
}
.intv .txtArea .catch::before{
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: .1rem;
background: #b2b2b2;
}
.intv .txtArea .catch::after{
content: "";
position: absolute;
bottom: -0.1rem;
left: 0;
width: 6.0rem;
height: .4rem;
background: #003e88;
}

.intv .txtArea .mainTxt{
padding: 0 41rem 0 0;
}
.intv .btn-link{
margin: -1rem 5rem 0 0;
}







/* spv_PC */
.spv{
position: relative;
margin: 13rem 0;
padding: 7rem 10rem 3rem;
background: #062D59;
background: linear-gradient(180deg, rgba(6, 45, 89, 1) 0%, rgba(24, 72, 126, 1) 100%);
color: #fff;
}
.spv::before{
content: "SPONSORED BY";
position: absolute;
z-index: 1;
top: 3.0rem;
left: 0;
width: 100%;
text-align: center;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:5.0rem;
line-height: 1;
color: #fff;
opacity: .15;
}

.spv .inner{
position: relative;
}

.spv .headArea{
position: relative;
}

.spv .boxTtl{
position: absolute;
top: -1.5rem;
left: -5rem;
width: 17rem;
height: 15rem;
padding: 3.0rem 0 0;
background: url("./img/spv_deco.png") 0 0 no-repeat;
background-size: 100% auto;
line-height: 1.3;
text-align: center;
font-size:2.0rem;
font-weight: 700;
}

.spv .sttl{
margin: 0;
padding: 5rem 0 0 38rem;
font-size:2.4rem;
}
.spv .sttl .fontL{
display: block;
font-size:3.6rem;
color: #ffe751;
}

.spv .mainArea{
padding: 1rem 0 1rem;
}

.spv .imgArea{
position: absolute;
top: 6rem;
left: 0;
width: 33rem;
}
.spv .mainArea .flame{
}
.spv .mainArea .flame img{
width: 100%;
object-fit: cover;
}
.spv .mainArea .caption{
color: #fff;
}

.spv .txtArea{
margin: 0 0 0 38rem;
padding: 0 0 0;
}

.spv .btns {
padding: 0 0 2rem;

}
.spv .btns > div {
width: 40%;
}

.spv.lb{
margin: 0;
padding: 10rem 10rem 8rem;
}


.spv .inner.lb{
width: 110rem;
	margin: 0 auto;
}





/* qa_PC */
.qaWrap{
padding: 1rem 0;
}
.qa{
padding: 2rem 0;
}
.qa .sttl{
margin: 0 0 20px;
padding: 0 0 0 5.5rem;
background: none;
border: none;
font-size:2.0rem;
color: #003e88;
}
.qa .sttl::before{
content: "";
position: absolute;
top: 16px;
left: 0;
width: 5rem;
height: .1rem;
background: #b2b2b2;
}

.qa .txtArea{
padding: 0 0 0 5.5rem;
}
.qa .float-wrap{
margin: 0;
padding: 0;
}
.qa .catch{
display: inline;
margin: 0 0 20px;
font-size:2.0rem;
color:#e18400;
}
.qa .catch::before{
content: "A.";
position: absolute;
top: -1rem;
left: -3.5rem;
font-size:3.0rem;
font-weight: 700;
}
.qa .float-wrap .fr{
padding: 0 0 2rem 7rem;
}
.qa .float-wrap .fl{
padding: 0 7rem 2rem 0;
}




/* his_PC */
.his{
position: relative;
margin: 12rem 0 15rem;
background: #e9f1fd;
}
.his::before{
content: "SCHEDULE";
position: absolute;
z-index: 1;
top: 1.0rem;
right: 1.5rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:5.0rem;
line-height: 1;
color: #003e88;
opacity: .2;
}

.his .ulBox{
padding: 7rem 5rem 0 10rem;
}
.his .liBox{
display: flex;
justify-content: space-between;
margin: 0 0 2.5rem;
padding: 0 0 2.0rem;
border-bottom: 1px solid #b2b2b2;
}
.his .liBox:last-child{
border: none;
padding: 0 0 4.0rem;
}
.his .ttlTxt{
width: 18rem;
padding: 0 0 0 1rem;
}
.his .mainTxt{
width: 75rem;
}


.his .sttl{
margin: 0;
font-size:1.6rem;
color: #003e88;
}
.his .catch{
margin: 0;
font-size:2.0rem;
}

.his .mainTxt p{
font-size:1.3rem;
}
.his .mainTxt p:first-child{
margin-top: .3rem;
}


.his .liBox::before{
content: "";
position: absolute;
top: 1.6rem;
left: -5.0rem;
width: 2.3rem;
height: 2.3rem;
background: #8ebeef;
border-radius: 50%;
}
.his .liBox::after{
content: "";
position: absolute;
top: 3.0rem;
left: -3.9rem;
width: .1rem;
height: calc(100% + 2rem);
background: #8ebeef;
}

.his .liBox:last-child::after{
display: none;
width: 0;
height: 0;
background: none;
border: none;
}



/* relIntv_PC */
.relIntv{
position: relative;
margin: 2rem 0 6rem;
}

.relIntv .ulBox{
display: flex;
justify-content: space-between;
}
.relIntv .liBox{
width: calc((100% - 6rem) / 4);
background: #f5f5f5;
}

.relIntv .liBox a{
padding: 1rem 0 4rem;
}

.relIntv .liBox a::before {
content: "MORE";
position: absolute;
bottom: 0;
	top: auto;
right: 0;
display: flex;
align-items: center;
justify-content: center;
width: 100%;
    height: 3rem;
background: url(./img/arrow_wt.svg) calc(100% - .8rem) 50% no-repeat #062d59;
background-size: 1.5rem auto;
font-weight: 700;
color: #fff;
font-size: 1.3rem;
}

.relIntv .imgArea .flame{
width: 100%;
height: 16rem;
}
.relIntv .imgArea .flame img{
width: 100%;
object-fit: cover;
}

.relIntv .txtArea{
padding: 1.5rem 0 2rem;
}
.relIntv .txtArea .btn-internal{
    margin: 2rem auto;
}
.relIntv .liBox .headArea{
position: relative;
display: flex;
align-items: center;
margin: 1rem 0 1.6rem 2rem;
padding: 0 2rem 2.0rem 0;
}
.relIntv .liBox .headArea::before{
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: .1rem;
background: #b2b2b2;
}
.relIntv .liBox .headArea::after{
content: "";
position: absolute;
bottom: -0.1rem;
left: 0;
width: 5.0rem;
height: .4rem;
background: #003e88;
}


.relIntv .liBox .spec{
margin: 0 0 .5rem;
}
.relIntv .liBox .boxYw{
display: inline-block;
padding: .2rem .5rem .4rem;
background: #ffe751;
line-height: 1;
color: #003e88;
font-size:1.4rem;
font-weight: 700;
}
.relIntv .liBox .catch{
margin: 0;
color: #003e88;
font-size:2.0rem;
}


.relIntv .liBox .mainTxt{
margin: 0 2rem;
}




/* msg_PC */
.msg{
position: relative;
margin: 8rem 0 3rem;
padding: 1rem 0 3.0rem;
background: #fffade;
}
.msg::before{
content: "MESSAGE";
position: absolute;
z-index: 1;
top: 1.0rem;
right: 1.5rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:5.0rem;
line-height: 1;
color: #e88c0b;
    opacity: .25;
}

.msg .imgArea{
position: absolute;
z-index: 1;
top: 4.5rem;
left: 5rem;
width: 31.5rem;
}
.msg .imgArea .flame{
margin: 0 0 1.5rem;
}
.msg .imgArea img{
width: 100%;
object-fit: cover;
}

.msg .txtArea{
padding: 5rem 0 0 41rem;
}

.msg .txtArea .catch{
margin: 0 0 2.5rem;
padding: 0 5rem 2.5rem 0;
font-size:2.8rem;
}
.msg .txtArea .catch::before{
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: .1rem;
background: #b2b2b2;
}
.msg .txtArea .catch::after{
content: "";
position: absolute;
bottom: -0.1rem;
left: 0;
width: 6.0rem;
height: .4rem;
background: #003e88;
}

.msg .txtArea .mainTxt{
padding: 0 5rem 0 0;
}







/*--------------------------------------
　about_PC
---------------------------------------*/

.about{
position: relative;
z-index: 15;
width: 100rem;
margin: 7rem auto 10rem;
}
.about::before{
}
.about::after{
content: "ABOUT THIS MEDIA";
position: absolute;
top: -6rem;
left: 0;
width: 100%;
text-align: center;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:5.0rem;
color: #010912;
}


.about .inner{
position: relative;
padding: 4.5rem 5rem 1.5rem;
background: #010912;
}
.about .inner::before{
}

.about .logo{
position: absolute;
top: calc(50% - 4rem);
right: 7rem;
width: 20.5rem;
}
.about .logo .logoImg{
margin: 0 0 .5rem;
}

.about .catch{
margin: 0 0 1.2rem;
	color:#fff;
}
.about .txtArea{
margin: 0 27rem 0 0;
	color:#fff;
}

.about .btn-link {
margin-top: 2.0rem;
	color:#fff;
}


.about .btn-link a{
	color:#fff;
}

/*--------------------------------------
　biggerlink_PC
---------------------------------------*/

.biggerlink{
cursor: pointer;
transition: all .2s ease-in-out;
}
.biggerlink:hover{
opacity: .6;
}
.biggerlink a:hover{
opacity: 1;
}



/* End_PC */







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


/*------------
common--480px
------------*/

html{
}

.mainWrap .catch, .mainWrap .sttl,
.index .catch, .index .sttl{
font-size: 1.8rem;
}

#contents{
position: relative;
z-index: 0;
}



body{
min-width: 320px;
text-align:left;
line-height:1.9;
font-size:1.4em;
word-break: break-all;
overflow-x: hidden;
}

.sp,
.sp_br{
display:block!important;
}

.pc,
.pc_br{
display:none!important;
}

img:not([width]) {
width:100%;
height:auto;
max-width: 100%;
}

a{
text-decoration: none;
}
a:hover,
a:hover img{
opacity: 1;
}


p{
text-align: justify;
line-height:2.0;
}


.areaInner{
width: auto;
margin: 0;
}






/* notice 30px_4% */



/*--------------------------------------
　body_SP
---------------------------------------*/
body {
}
body::before{
content: "";
position: absolute;
top: 0;
left: 50%;
width: .1rem;
height: 100%;
background:none;
opacity: .07;
}
.bodyInner, .bodyInner2{
position: relative;
}
.bodyInner::before,
.bodyInner::after,
.bodyInner2::before{
content: "";
position: absolute;
top: -1rem;
left: 25%;
width: 50%;
height: calc(100% + 2rem);
border: none;
opacity: .07;
}
.bodyInner::after{
display: none;
width: 0;
height: 0;
background: none;
border: none;
}
.bodyInner2::before{
display: none;
width: 0;
height: 0;
background: none;
border: none;
}




/*--------------------------------------
　header_SP
---------------------------------------*/
#header{
position: relative;
z-index: 14;
background: #062d59;
}
#header::before{
content: "";
position: absolute;
top: 0;
left: 50%;
width: .1rem;
height: 100%;
background:#fff;
opacity: .1;
}
#header::after{
}
.headInner, .headInner2{
position: relative;
}
.headInner::before,
.headInner::after,
.headInner2::before{
content: "";
position: absolute;
top: -1rem;
left: 25%;
width: 50%;
height: calc(100% + 2rem);
border: .1rem solid #fff;
opacity: .1;
}
.headInner::after{
display: none;
width: 0;
height: 0;
background: none;
border: none;
}
.headInner2::before{
display: none;
width: 0;
height: 0;
background: none;
border: none;
}

.headInner3{
position: relative;
padding: 0 2% ;
}
.headInner3::before{
content: "";
position: absolute;
top: 0;
right: 0;
width: 21.3rem;
height: 9rem;
background: url("./img/head_bg1_sp.png") 100% 0 no-repeat;
background-size: 21.3rem auto;
}
.headInner3::after{
content: "";
position: absolute;
bottom: 0;
left: auto;
right: 0;
width: 11.6rem;
height: 10rem;
background: url("./img/head_bg2_sp.png") 100% 150% no-repeat;
background-size: 11.6rem auto;
        opacity: 0.3;
}


#header .topArea2{
position: relative;
top: 0;
right: 0;
margin: 0 0 .5rem 14rem;
padding: 1rem 0 1rem 0;
text-align: left;
font-weight: 700;
font-size:1.1rem;
line-height: 1.6;
}
#header .siteName{
display: inline-block;
font-weight: 700;
}
#header .siteName a{
}



#header .logo{
position: absolute;
        top: .8rem;
        left: 1%;
        padding: 0 0 0;
}
#header .logo a{
display: block;
}
#header .logo img{
width: 100%;
}
#header .logoImg{
        width: 11.5rem;
}




/*--------------------------------------
　h1Area_SP
---------------------------------------*/
.h1Area{
position: relative;
z-index: 2;
margin: 0 2% 2rem;
padding: 0 0 5rem;
}

.h1Area h1{
position: relative;
width: auto;
margin: 0 0 1.0rem;
padding: 1.8rem 5% 0;
text-align: center;
font-size:2.5rem;
color: #fff;
}


.h1Area .headNote{
margin: 0 0 2rem;
padding: 0 0;
text-align: center;
font-size:1.1rem;
font-weight: 700;
line-height: 1.6;
color: #fff;
}



/*--------------------------------------
Main Contents_SP
---------------------------------------*/

#contents {
position: relative;
z-index: 14;
width: 100%;
overflow-x: hidden;
margin: 0 0 0;
padding: 0 0 5rem;
border: none;
}

.mainWrap {
position: relative;
z-index: 1;
padding: 0 0 2rem;
min-height: 50rem;
}


.mainWrap > .areaInner{
padding: 0 ;
}









/*--------------------------------------
pankuzu_SP
---------------------------------------*/

#pankuzuWrap{
overflow: auto;
white-space: nowrap;
margin: 0 5% 1.5rem;
padding: 10px 0 0;
position: static;
box-sizing: border-box;
width: auto;
}
#pankuzuWrap::-webkit-scrollbar{
height: 3px;
}
#pankuzuWrap::-webkit-scrollbar-track{
border-radius: 3px;
background: #eee;
}
#pankuzuWrap::-webkit-scrollbar-thumb{
border-radius: 3px;
background: #bbb;
}

#pankuzu{
width: 100%;
margin: 0 auto 10px;
padding: 0 0;
font-size:1.1rem;
}
#pankuzu a{
text-decoration: underline;
}




/*--------------------------------------
　page-top_SP
---------------------------------------*/
#page-top{
position: fixed;
z-index: 101;
bottom: 1rem;
right: 2%;
width: 5.5rem;
}
#page-top{
  transition: .3s;
  /*デフォルトで非表示にする*/
  opacity: 0;
  visibility: hidden;
}
/*このクラスが付与されると表示する*/
#page-top.active{
  opacity: 1;
  visibility: visible;
}
/*このクラスが付与されると表示する*/
#page-top.absolute{
}








/*--------------------------------------
　Global Nav_SP
---------------------------------------*/
#gNav{
position: fixed;
top: 0;
right: 2%;
z-index: 10000;


transition: .3s;
/*デフォルトで非表示にする*/
opacity: 0;
visibility: hidden;
}
/*このクラスが付与されると表示する*/
#gNav.active{
opacity: 1;
visibility: visible;
}


/* ハンバーガーメニュー */

#gNav #showRight{
z-index: 10000;
}

#gNav button{
position: relative;
top: -1px;
width: 9rem;
height: 3.8rem;
background: #062d59;
border-radius:0 0 .5rem .5rem;
transition: all .2s ease-in-out;
}

#gNav button span{
position: absolute;
left: 72%;
width: 15%;
height: 1px;
background-color: #fff;
transition: .3s all;
}
#gNav button span:nth-child(1){
top:34%;
}
#gNav button span:nth-child(2){
top:calc(34% + .5rem);
}
#gNav button span:nth-child(3){
top:calc(34% + 1.0rem);
}



#gNav button.active span:nth-child(1){
  transform: translateY(0.5rem) rotate(-45deg);
}
#gNav button.active span:nth-child(2){
  opacity: 0;
}
#gNav button.active span:nth-child(3){
  transform: translateY(-0.5rem) rotate(45deg);
}

#gNav button::before{
content: "MENU";
position: absolute;
top: 1.4rem;
left: 1.5rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:1.1rem;
line-height: 1;
color: #fff;
}

#gNav button:hover{
opacity: 1;
}




/* 展開内容 */

#gNav .cbp-spmenu {
position: fixed;
margin: 0 0 0;
padding: 5rem 0 0;
background: #062d59;

overflow: auto;
-ms-overflow-style: none; /* IE, Edge 対応 */
scrollbar-width: none;/* Firefox 対応 */
}


#gNav .cbp-spmenu #mainMenu{
position: relative;
z-index: 1;
/*overflow: auto;*/
overflow: visible;
margin: 0 0;
padding: 4rem 0 7rem;
height: 100%;
}

#gNav .cbp-spmenu #mainMenu::-webkit-scrollbar{
display: none;/* Chrome, Safari 対応 */
}

#gNav .cbp-spmenu #mainMenu .gnavBox:first-child{
border-top: 1px solid rgba(255, 255, 255, .5);
}

#gNav .cbp-spmenu a {
display: block;
padding: 14px 10% 14px;
text-decoration: none;
line-height: 1.3;
font-size:1.4rem;
color: #fff;
}
#gNav .cbp-spmenu li a {
padding: 16px 10% 16px;
}
#gNav .cbp-spmenu .sttl{
margin: 0;
font-size:1.6rem;
letter-spacing: 0;
}

#gNav .cbp-spmenu .sttl a {
background: url(./img/arrow_ccl_wt.svg) calc(100% - 1.8rem) 50% no-repeat;
background-size: 1.8rem auto;
}

#gNav .cbp-spmenu .sttl.tglMenu a {
background: none;
}
#gNav .cbp-spmenu .sttl.tglMenu a::before {
content: '';
display: inline-block;
width: 1.6rem;
height: .1rem;
background-color: #fff;
position: absolute;
right: 2rem;
top: 50%;
transform: translateY(-50%);
transition: opacity .5s;
}
#gNav .cbp-spmenu .sttl.tglMenu a::after {
content: '';
display: inline-block;
width: 1.6rem;
height: .1rem;
background-color: #fff;
position: absolute;
right: 2rem;
top: 50%;
transform: translateY(-50%) rotate(-90deg);
transition: transform .5s;
}
#gNav .cbp-spmenu .sttl.open a::before {
opacity: 0;
}
#gNav .cbp-spmenu .sttl.open a::after {
transform: translateY(-50%) rotate(-180deg);
}



#gNav .cbp-spmenu .home a {
background: url(./img/arrow_ccl_wt.svg) calc(100% - 1.8rem) 50% no-repeat;
background-size: 1.8rem auto;
}
#gNav .cbp-spmenu .subList a{
padding: 14px 10% 14px calc(5% + 2em);
font-weight: 400;
}

#gNav .cbp-spmenu li a {
position: relative;
background: url(./img/arrow_ccl_wt.svg) calc(100% - 1.8rem) 50% no-repeat #003e88;
background-size: 1.8rem auto;
padding: 14px 10% 14px calc(5% + 1em);
font-weight: 400;
}

#gNav .cbp-spmenu .subList li a::before {
left: calc(5% + 1em);
}



#gNav .cbp-spmenu a:hover {
opacity: 1;
}
#gNav .cbp-spmenu a:active {
}

/* Orientation-dependent styles for the content of the menu */
#gNav .cbp-spmenu-vertical {
/*width: calc(100% - 100px);*/
width: 100%;
height: 100%;
top: 0;
z-index: -1;
}
#gNav .cbp-spmenu-vertical a {
border-bottom: 1px solid rgba(255, 255, 255, .5);
padding: 16px 11% 16px 5%;
}
#gNav .cbp-spmenu-vertical .home a {
border-bottom: 1px solid rgba(255, 255, 255, .5);
}
#gNav .cbp-spmenu-vertical .smap .home a {
border-top:none;
}



/* Vertical menu that slides from the left or right */
#gNav .cbp-spmenu-right {
opacity: 0;
right: -100%;
/*right: -280px;*/
/*right: 0;*/
}
#gNav .cbp-spmenu-right.cbp-spmenu-open {
opacity: 1;
right: 0;
z-index: 1000;
}


/* Transitions */
#gNav .cbp-spmenu,
#gNav .cbp-spmenu-push {
transition: all 0.3s ease;
}

#gNav .accChild {
display: none;
}



/* logo */
#gNav .cbp-spmenu .logo{
position: relative;
top: 2rem;
width: 14.5rem;
margin: 0 auto;
}
#gNav .cbp-spmenu .logo a{
display: block;
border: none;
padding: 0;
}
#gNav .cbp-spmenu .logo img{
width: 100%;
}








/*--------------------------------------
　fixNav_SP
---------------------------------------*/

#fixNav_sp{
position: fixed;
z-index: 1000;
bottom: 0;
left: 0;
/*width: 26rem;*/

transition: .3s;
/*デフォルトで非表示にする*/
opacity: 0;
visibility: hidden;
}
/*このクラスが付与されると表示する*/
#fixNav_sp.active{
opacity: 1;
visibility: visible;
}
/*このクラスが付与されると停止する*/
#fixNav_sp.absolute{
/*opacity: 0;
visibility: hidden;*/
}




#fixNav_sp{
/*width: 100%;*/
display: flex;
justify-content: flex-start;
align-items: flex-end;
padding: 0 2%;
}
#fixNav_sp .btn-web{
width: 26rem;
margin: 0 0;
}
#fixNav_sp .btn-web a{
display: block;
width: 100%;
min-height: 5.5rem;
padding: .8rem 22% 1.0rem 5%;
border-radius: .5rem .5rem 0 0;
box-shadow: none;
font-size:1.2rem;
text-align: left;
}
#fixNav_sp .btn-web a .fontS{
display: block;
margin: 0 0 .2rem;
font-size:1.0rem;
}
#fixNav_sp .btn-web a::before{
top: 0;
right: 1.6rem;
width: 1.8rem;
height: 100%;
background: url(./img/arrow_out.svg) 0 50% no-repeat;
background-size: 1.8rem auto;
}
#fixNav_sp .btn-web a::after{
top: calc(50% - 1.0rem);
right: 1.0rem;
width: 2.0rem;
height: 2.0rem;
}








/*--------------------------------------
　Footer_SP
---------------------------------------*/

footer{
position: relative;
z-index: 13;
width: 100%;
padding: 0 0 5rem;
background: #062d59;
}


footer .footInner{
width: auto;
margin: 0;
padding: 0 0 0;
}


footer .footInner .areaL{
width: auto;
float: none;
margin: 0 5% 4rem;
}


footer .noticeArea{
color: #fff;
}
footer .noticeArea p{
font-size:1.1rem;
}
footer .noticeArea p:nth-child(1){
}
footer .noticeArea a{
text-decoration: underline;
color: #fff;
}
footer .noticeArea .botPrg{
padding: 1.2rem 0 0;
text-align: center;
}




footer .footInner .areaR{
width: auto;
float: none;
}

footer .footBox{
margin: 0 0 0;
/*z-index: 0;*/
}
.footBox:first-of-type{
border-top: 1px solid rgba(255, 255, 255, .5);

}
.footBox a{
}
.footBox a:hover{
opacity: 1;
}


.footBox .sttl{
margin: 0;
padding: 0;
border: none;
background: none;
}
.footBox .sttl a{
display: block;
padding: 1.2em 10% 1.3em 4%;
font-size: 1.5rem;
border-bottom: 1px solid rgba(255, 255, 255, .5);
text-align: left;
letter-spacing: 0;
}

.footBox .sttl a::before {
content: '';
display: inline-block;
width: 1.6rem;
height: .1rem;
background-color: #fff;
position: absolute;
right: 1.9rem;
top: 50%;
transform: translateY(-50%);
transition: opacity .5s;
}
.footBox .sttl a::after {
content: '';
display: inline-block;
width: 1.6rem;
height: .1rem;
background-color: #fff;
position: absolute;
right: 1.9rem;
top: 50%;
transform: translateY(-50%) rotate(-90deg);
transition: transform .5s;
}


.footBox > ul{
padding: 0;
}
.footBox li{
display: block;
}


.footBox li:after{
content: "";
}

.footBox li a{
display: block;
padding: 1.3em 10% 1.3em 10.5%;
background: url("./img/arrow_ccl_wt.svg") calc(100% - 2.0rem) 50% no-repeat;
background-size: 1.8rem auto;
border-bottom: 1px solid rgba(255, 255, 255, .5);
text-align: left;
font-size:1.3rem;
}
.footBox li li a{
padding: 1.3rem 10% 1.3rem 4.5%;
}
 
 
.footBox li a.ssttl{
display: block;
padding: 1.3em 10% 1.3em 4.5%;
background: url(./img/arrow_ccl_wt.svg) calc(100% - 1.8rem) 50% no-repeat;
background-size: 1.8rem auto;
border-bottom: 1px solid rgba(255, 255, 255, .5);
}

.footBox li.sp a{
padding: 1.3rem 10% 1.3rem 4.5%;
}

/* サイトマップ */
footer .smap .sttl a{
background: url(./img/arrow_ccl_wt.svg) calc(100% - 1.8rem) 50% no-repeat;
background-size: 1.8rem auto;
font-size:1.4rem;
}
footer .smap .sttl a::before,
footer .smap .sttl a::after{
width: 0;
height: 0;
background: none;
border: none;
}



.footBox.accordion .accChild{
display: none;
/*background: #d2ebee;*/
}
.footBox.accordion .accChild a{
padding: 1.1rem 10% 1.2rem 4.5%;
background: url("./img/arrow_ccl_wt.svg") calc(100% - 1.8rem) 50% no-repeat #003e88;
background-size: 1.8rem auto;
border-bottom: 1px solid rgba(255, 255, 255, .5);
}


.footBox.accordion .open a::before {
opacity: 0;
}
.footBox.accordion .open a::after {
transform: translateY(-50%) rotate(-180deg);
}




.footBox li.subCat{
display: block;
margin: 0 0 0 0;
}

.footBox ul.subList{
display: block;
margin: 0 0 0;
}

.footBox ul.subList > li:first-child::before{
content: "";
margin: 0;
}

.footBox ul.subList li:after{
content: "";
}




footer .botArea{
min-width: 0;
padding: 1.5rem 5% 3.0rem;
box-sizing: border-box;
}
footer .botArea .copy{
padding: 0 0;
font-size:1.1rem;
text-align: center;
color: #fff;
}
footer .botArea a{
display: inline-block;
text-decoration: none;
font-size:1.1rem;
color: #fff;
}




/* ================== */
/*  SP共通パーツ　*/
/* ================== */

/* p */
.mainWrap p, .index p{
margin: 1rem 0;
line-height:2.0;
}

.mainWrap p + p, .index p + p{
margin-top: 1.8rem;
}

.mainWrap > .areaInner > p, .index > .areaInner > p{
padding: 0 5%;
}
.mainWrap > .areaInner > .caption{
margin: 0 5%;
}
.mainWrap > .areaInner > .low-center-img-box{
padding: 0 5%;
}
.mainWrap > .areaInner > .low-center-img-box *{
margin-left: 0;
margin-right: 0;
}


.mainWrap h2 {
position: relative;
margin: 4rem 5% 2rem;
padding: 1.5rem 5% 1.7rem;
background: #18487E;
background: linear-gradient(90deg, rgba(24, 72, 126, 1) 0%, rgba(6, 45, 89, 1) 100%);
font-size:2.3rem;
color: #fff;
}
.mainWrap h2::before{
content: "";
position: absolute;
top: 1.5rem;
left: 0;
width: .3rem;
height: calc(100% - 3rem);
background: #ffdc00;
}

.mainWrap h2::after{
}



.mainWrap h2 a{
position: relative;
display: block;
padding: 0 13% 0 0;
background: url("./img/arrow_ccl_wt.svg") 100% calc(50% - 0px) no-repeat;
background-size: 2.4rem auto;
}
.mainWrap h2 a::before{
}





.mainWrap h3{
position: relative;
margin: 3rem 5% 2rem;
padding: 1.2rem 3% 1.2rem 1%;
border-bottom: 1px solid #b2b2b2;
font-size:2.0rem;
}
.mainWrap h3::before{
content: "";
position: absolute;
bottom: -0.2rem;
left: 0;
width: 4.0rem;
height: .3rem;
background: #003e88;
}


.mainWrap h3 a{
position: relative;
z-index: 1;
display: block;
padding: 0 13% 0 0;
background: url("./img/arrow_ccl.svg") 100% calc(50% - 0px) no-repeat;
background-size: 2.4rem auto;
}

.mainWrap h3 a:hover{
}







.mainWrap h4{
position: relative;
margin: 2rem 5%;
padding: 1rem 3% 1rem 4.5%;
font-size:1.8rem;
color: #003e88;
}
.mainWrap h4::before{
content: "";
position: absolute;
top: 0;
left: 0;
width: 1.2rem;
height: 100%;
background: url(./img/deco1.svg) 0 45% no-repeat;
background-size: 1.2rem auto;
}


.mainWrap h4 a{
position: relative;
display: inline-block;
padding: 0 8% 0 0;
background: url("./img/arrow_ccl.svg") 100% calc(50% + .2rem) no-repeat;
background-size: 2.0rem auto;
color: #003e88;
}


.mainWrap h5, .mainWrap h6{
position: relative;
margin: 2rem 5%;
padding: 1rem 3% 1rem 1%;
font-size:1.8rem;
}
.mainWrap h5 a, .mainWrap h6 a{
position: relative;
display: inline-block;
padding: 0 8% 0 0;
background: url("./img/arrow_ccl.svg") 100% calc(50% + .2rem) no-repeat;
background-size: 2.0rem auto;
}








.mainWrap ul{
margin: 1.5em 4% 1.5em;
padding:0.5em 1% 0;
}
.mainWrap ul li{
padding:0 0 .4rem 2.1rem;
}
.mainWrap ul li::before,
.index ul li::before{
position: absolute;
content: "";
top: .8rem;
left: .3rem;
width: 1.0rem;
height: 1.0rem;
}


.mainWrap ol {
margin: 1.5em 4% 2.5em;
padding:0.5em 1% 0;
}
.mainWrap ol li{
padding:0 0 .4rem 2.1rem;
}

.mainWrap ol li::before{
position: absolute;
display: flex;
align-items: center;
justify-content: center;
top: .6rem;
left: 0;
width: 1.5rem;
height: 1.6rem;
letter-spacing: 0;
line-height: 1.0;
font-size:1.1rem;
}







/*  btns*/
.btn-internal,
.btn-web,
.btn-tel{
position: relative;
z-index: 1;
width: 85%;
display: flex;
align-items: center;
justify-content: center;
margin: 2.5rem auto;
text-align: center;
}


.btn-internal a,
.btn-web a,
.btn-tel a{
position: relative;
top:0;
left: 0;
width: 100%;
min-height: 7.5rem;
display: flex;
align-items: center;
justify-content: center;
padding: 1.6rem 15% 1.8rem;
box-shadow:.5rem .5rem 0 #a4b0c3;
text-align: center;
line-height: 1.5;
font-size:1.5rem;
font-weight: 700;
color: #003e88;
transition: all .2s ease-in-out;
}

.btn-internal a::before,
.btn-web a::before,
.btn-tel a::before{
content: "";
position: absolute;
z-index: 10;
top: 0;
right: 1.3rem;
width: 2.4rem;
height: 100%;
background: url("./img/arrow_ccl.svg") 0 50% no-repeat;
background-size: 2.4rem auto;
transition: all .2s ease-in-out;
}
.btn-internal a::after,
.btn-web a::after,
.btn-tel a::after{
}



.btn-internal a{
}


.btn-web a{
box-shadow:.5rem .5rem 0 #c87704;
color: #fff;
}
.btn-web.mn a {
    box-shadow: .5rem .5rem 0 #2b6bad;
}
.btn-web a::before{
right: 1.5rem;
width: 2.2rem;
background: url("./img/arrow_out.svg") 0 50% no-repeat;
background-size: 2.2rem auto;
}





.btn-tel{
display: block;
}
.btn-tel a{
background: #ffe751;
box-shadow:.5rem .5rem 0 #cfbb42;
color: #000;
}
.btn-tel a::before{
content: "";
position: absolute;
top: 0;
right: 1.6rem;
width: 1.8rem;
height: 100%;
background: url(./img/ico_tel.svg) 0 calc(50% - 0rem) no-repeat;
background-size: 1.8rem auto;
}



.btn-link{
margin: .2rem 5%;
text-align: right;
}
.btn-link a{
position: relative;
display: inline-block;
padding: .4rem 8.5% .5rem 0;
background: url("./img/arrow_ccl.svg") 100% calc(50% + .05rem) no-repeat;
background-size: 2.0rem auto;
line-height: 1.5;
text-align: right;
font-weight: 700;
}



/* ================== */
/*  テーブル　　　　　*/
/* ================== */

table{
width: 88%;
margin:4rem auto;
border-bottom: 2px solid #dedede;
}
table th {
width: 100%;
display: block;
padding: 1.5rem 2rem;
border-bottom: none;
line-height: 1.3;
text-align: center;
}
table td {
width: 100%;
display: block;
padding: 1.5rem 2rem;
border-bottom: none;
line-height: 1.4;
text-align: center;
}





/* ================== */
/*  SPカスタマイズ共通　*/
/* ================== */
.caption,
.source{
margin: 0.8em 0 0;
font-size:1.0rem;
line-height: 1.6;
word-break: break-all;
color: #999;
display: block;
}
.caption a:hover{
text-decoration: underline;
}


.marker{
}


/*  float-wrap */

.mainWrap .float-wrap .flame{
position: relative;
}
.mainWrap .float-wrap .caption{
margin-bottom: 5px;
}
.mainWrap .float-wrap{
margin: 2.5em 6%;
padding: 0 1%;
}
.mainWrap .float-wrap .catch{
margin: 0em 0 0.4em;
line-height: 1.7;
}
.mainWrap .float-wrap p{
margin: 1rem 0;
padding: 0;
}
.float-wrap ul{
display: block;
margin: 6px 0;
}
.mainWrap .float-wrap .fl,
.mainWrap .float-wrap .fr,
.mainWrap .float-wrap .ct{
float: none;
padding: 0 0 0.5em;
width: 100%;
width: auto;
text-align: left;
}

.mainWrap .float-wrap .fl.t_small{
width: 40%;
float: left;
padding: 0 5% 0 0;
}
.mainWrap .float-wrap .fr.t_small{
width: 40%;
float: right;
padding: 0 0 0 5%;
}
.mainWrap .float-wrap img {
}






/* ================== */
/*  サイトマップ*/
/* ================== */
.smap h2{
}
.smap ul{
}




/* ================== */
/*  追加パーツ*/
/* ================== */


/*--------------------------------------
　mokuji_SP
---------------------------------------*/

.mokuji{
transition: .3s;
/*デフォルトで非表示にする*/
opacity: 1;
/*visibility: hidden;*/
}
/*このクラスが付与されると表示する*/
.mokuji.active{
opacity: 1;
visibility: visible;
}
/*このクラスが付与されると停止する*/
.mokuji.absolute{
}



.mokuji{
position: relative;
margin: 0 5% 8rem;
}

.mokuji .inner{
position: relative;
padding: 1rem 5% 0;
background: #f5f5f5;
}

.mokuji .inner::before{
content: "INDEX";
position: absolute;
top: -1.0rem;
right: 3%;
font-size:3.0rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
color: rgba(0, 62, 136, 0.3);
}

.mokuji .sttl{
margin: 0 0 .6rem;
padding: .6rem 0 1.6rem;
border-bottom: 1px solid #b2b2b2;
font-size:1.8rem;
}


.mokuji #toc{
position: relative;
padding: 0 0 3rem;
}
.mokuji #toc.open{
z-index: 1;
}
.mokuji #toc ul{
margin:0;
padding:5px 0;
}
.mokuji #toc ul li{
position: relative;
margin: 2px 0;
padding: 2px 0 2px 3rem;
text-align: left;
line-height: 1.4;
}
.mokuji #toc ul li.chapter-h-two{
counter-increment: count;
}
.mokuji #toc ul li.chapter-h-two::before {
content: counter(count, decimal-leading-zero)".";/*2桁対応*/
position: absolute;
top: 1.0rem;
left: 0;
width: 4rem;
transform: translate(0,-50%);
background: none;
font-weight: 700;
color: #003e88;
}

.mokuji li a{
display: inline-block;
width: auto;
padding: 4px 0 6px;
background: none;
font-weight: 700;
text-decoration: none;
}
.mokuji #toc ul ul{
margin: 0;
padding: 0 0 .1rem;
}
.mokuji #toc ul li.chapter-h-three {
padding: 0 0 0 5rem;
}
.mokuji #toc ul li.chapter-h-three::after {
content: "";
position: absolute;
top: 0;
left: 3.5rem;
width: .8rem;
height: 100%;
background: url("./img/l_deco.png") 0 .6rem no-repeat;
background-size: .8rem auto;
}
.mokuji #toc ul li.chapter-h-three::before {
width: 0;
height: 0;
background: none;
border: none;
}

.mokuji li br{
display: none;
}


/* accordion_grd */
.mokuji .text {
height: 14rem;
overflow: hidden;
}
.mokuji .show_more2 {
position: absolute;
bottom: 0;
left: 0px;
width: 100%;
height: 70px;
padding-top: 6.5rem;
text-align: center;
line-height: 6.5rem;
background: linear-gradient(
180deg,
rgb(245, 245, 245, 0) 0%,
rgb(245, 245, 245, 1) 60%
);
cursor: pointer;
transition: bottom 0.2s;
}
.mokuji .active{
background: none;
/*bottom: -20px;*/
}
.mokuji .show_more2 span{
position: relative;
top: -2.5rem;
display: inline-block;
width: 40%;
min-height: 4rem;
padding: .6rem 10% .7rem;
background: url(./img/plus.svg) 90% calc(50% - 1px) no-repeat #fff;
background-size: 1.3rem auto;
border-radius:9999px;
border: 1px solid #b2b2b2;
text-align: center;
line-height: 1.5;
font-weight: 700;
font-size:1.5rem;
}
.mokuji .active span{
background: url(./img/minus.svg) 90% 50% no-repeat #fff;
background-size: 1.3rem auto;
}








/* ================== */
/*  関連記事_SP　　　　　*/
/* ================== */

#related-article p {
  margin: 0;
}

#related-article.related-article01-frame {
position: relative;
margin: 7rem 5% 3rem;
padding: .5rem 5% 2.5rem;
background: #f5f5f5;
}
#related-article.related-article01-frame::before{
content: "ARTICLE";
position: absolute;
top: -1.0rem;
right: 3%;
font-size:3.0rem;
font-family: "Montserrat", sans-serif;
font-weight: 900;
color: rgba(0, 62, 136, 0.3);
}

#related-article .related-article01-title {
position: relative;
margin: 0 0 1.5rem;
padding: .8rem 0 1.4rem;
border-bottom: 1px solid #b2b2b2;
line-height: 1.5;
font-size:1.8rem;
font-weight: 900;
}

#related-article .related-article01-title span {
}

#related-article .related-article01-list {
margin: 1.5rem 0 0 0;
padding: 0 0 0;
}

#related-article .related-article01-list p {
margin: 0;
}

#related-article .related-article01-list li {
margin: 2rem 0 0;
padding: 0 0 0 0;
font-size: 100%;
line-height: 1.7;
position: relative;
list-style: none;
}

#related-article .related-article01-list li+li {
margin-top: 10px;
}

#related-article .related-article01-list li::before {
width: 0!important;
height: 0!important;
background: none!important;
border: none!important;
}

#related-article .related-article01-list a {
position: relative;
display: inline-block;
padding: 0 0 0 2.6rem;
text-decoration: none;
}
#related-article .related-article01-list a::before{
content: "";
position: absolute;
top: calc(50% - 1.0rem);
right: 0;
width: 2.0rem;
height: 2.0rem;
background: url(./img/arrow_ccl.svg) 0 50% / 2.0rem auto no-repeat;
transition: all .3s ease-in-out;
transform-origin: 0 50%;
}


#related-article .related-article01-list a:hover {
opacity: 0.6;
}

#related-article .relations-box#related-article .relations-box--column {
display: flex;
gap: 10px;
}

#related-article .relations-box__pic {
flex: 0 0 150px;
}
.is-hidden {
display: none;
}

.related-article01-more {
display: flex;
justify-content: center;
align-items: flex-end;
background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0, #fff 50%);
background-color: transparent;
width: 100%;
height: 25%;
position: absolute;
bottom: -40px;
left: 0;
padding: 2rem 0;
}


.related-article01-more.is-closed {
display: none;
}

.related-article01-btn {
position: relative;
top: -0.5rem;
display: inline-block;
width: 14rem;
min-height: 4rem;
padding: .6rem 3rem .8rem;
background: url(./img/plus.svg) 90% calc(50% - 0px) no-repeat #fff;
background-size: 1.4rem auto;
border-radius:9999px;
border: 1px solid #b2b2b2;
text-align: center;
line-height: 1.5;
font-weight: 900;
font-size:1.5rem;
}
.related-article01-btn:hover {
opacity: 1;
}





/* btns_SP */
.btns{
display: block;
padding: .5rem 0;
}
.btns > div{
width: 85%;
margin: 2.5rem auto;
}
.btns .btn-internal a,
.btns .btn-web a,
.btns .btn-tel a{
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: auto;
}
.btns .btn-tel{
display: flex;
}



/* check_SP */
.check{
position: relative;
margin: 2rem 0 2rem;
        padding: 1.2rem 5% 1.4rem 22%;
background:#f5f5f5;
font-size:1.8rem;
font-weight: 700;
line-height: 1.5;
}
.check::before{
content: "";
position: absolute;
top: calc(50% - 3rem);
left: 1rem;
width: 6rem;
height: 6rem;
background: url("./img/iconttl_ck.png") 0 0 no-repeat;
background-size: 6rem auto;
}

.point{
position: relative;
margin: 2rem 5% 2rem;
padding:1.2rem 5% 1.4rem 20%;
background:#f5f5f5;
font-size:1.8rem;
font-weight: 700;
line-height: 1.5;
}
.point::before{
content: "";
position: absolute;
top: calc(50% - 3rem);
left: 1rem;
width: 6rem;
height: 6rem;
background: url("./img/iconttl_pt.png") 0 0 no-repeat;
background-size: 6rem auto;
}


.num{
position: relative;
margin: 2rem 5% 2rem;
padding:1.2rem 5% 1.4rem 20%;
background:#f5f5f5;
font-size:1.8rem;
font-weight: 700;
line-height: 1.5;
}
.num::before{
content: "";
position: absolute;
top: calc(50% - 3rem);
left: 1rem;
width: 6rem;
height: 6rem;
background: url("./img/iconttl_num.png") 0 0 no-repeat;
background-size: 6rem auto;
}
.num .fontNum{
position: absolute;
top: calc(50% - 3.2rem);
left: 1rem;
display: flex;
align-items: center;
justify-content: center;
width: 6rem;
height: 6rem;
font-size:1.8rem;
font-weight: 700;
line-height: 1;
color: #fff;
}






/* sum_SP */
.sum{
position: relative;
margin: 6rem 5% 7rem;
padding: 4.8rem 5% 2rem;
background: #fffade;
overflow: hidden;
}
.sum::before{
content: "SUMMARY";
position: absolute;
z-index: 1;
top: .5rem;
right: 3%;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:3.5rem;
line-height: 1;
color: #e88c0b;
opacity: .25;
}
.sum::after{
content: "";
position: absolute;
top: -2.8rem;
left: -0.5rem;
width: 8.5rem;
height: 7.5rem;
background: url(./img/sum_deco.png) 0 0 no-repeat;
background-size: 8.5rem auto;
}

.sum .txtArea{
position: relative;
}
.sum .txtArea::before{
}

.sum .catch{
margin: 0 0 1.5rem;
padding: 0;
font-size:1.8rem;
line-height: 1.7;
}




/* intv_SP */
.intvWrap{
margin: 0 0 3rem;
}
.intv{
position: relative;
margin: 4rem 5% 3rem;
padding: 0 0 2.5rem;
background: #f5f5f5;
}
.intv::before{
content: "INTERVIEW";
position: absolute;
z-index: 1;
top: .5rem;
right: 3%;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:3.5rem;
line-height: 1;
color: #003e88;
opacity: .2;
}

.intv .imgArea{
position: static;
z-index: 1;
top: 4.5rem;
right: 5rem;
width: 24rem;
margin: 0 auto;
}
.intv .imgArea .flame{
margin: 0 0 1.5rem;
}
.intv .imgArea img{
width: 100%;
object-fit: cover;
}


.intv .txtArea{
padding: 6rem 0 0 0;
}
.intv .txtArea .spec{
margin: 0 5%;
font-size:1.5rem;
font-weight: 700;
}
.intv .txtArea .spec .boxYw{
display: inline-block;
margin: 0 1rem 0 0;
padding: .2rem 1rem .4rem;
background: #ffe751;
line-height: 1;
color: #003e88;
}
.intv .txtArea .catch{
margin: 0 0 3.0rem 5%;
padding: 0 5% 1.5rem 0;
font-size:2.0rem;
}
.intv .txtArea .catch::before{
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: .1rem;
background: #b2b2b2;
}
.intv .txtArea .catch::after{
content: "";
position: absolute;
bottom: -0.1rem;
left: 0;
width: 4.0rem;
height: .3rem;
background: #003e88;
}

.intv .txtArea .mainTxt{
padding: 0 5%;
}
.intv .btn-link{
margin: 0 5% 0;
}




/* spv_SP */
.spv{
position: relative;
margin: 6.5rem 5%;
padding: 5rem 5% 2.5rem;
background: #062D59;
background: linear-gradient(180deg, rgba(6, 45, 89, 1) 0%, rgba(24, 72, 126, 1) 100%);
color: #fff;
}
.spv::before{
content: "SPONSORED BY";
position: absolute;
z-index: 1;
top: .8rem;
right: 0;
width: 100%;
padding: 0 3% 0 0;
text-align: right;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:2.5rem;
line-height: 1;
color: #fff;
opacity: .15;
}

.spv .inner{
position: relative;
}

.spv .headArea{
position: relative;
}

.spv .boxTtl{
position: absolute;
top: -7.3rem;
left: -2.8rem;
width: 10rem;
height: 9rem;
padding: 1.6rem 0 0;
background: url("./img/spv_deco.png") 0 0 no-repeat;
background-size: 100% auto;
line-height: 1.3;
text-align: center;
font-size:1.5rem;
font-weight: 700;
}

.spv .sttl{
margin: 0;
padding: 0 0 1rem;
font-size:1.8rem;
}
.spv .sttl .fontL{
display: block;
font-size:2.5rem;
color: #ffe751;
}

.spv .mainArea{
padding: 1rem 0 1rem;
}

.spv .imgArea{
position: static;
width: 100%;
margin: 0 auto;
}
.spv .mainArea .flame{
}
.spv .mainArea .flame img{
width: 100%;
object-fit: cover;
}
.spv .mainArea .caption{
color: #fff;
}

.spv .txtArea{
margin: 0 0 0;
padding: 0 0 0;
}

.spv .btns {
padding: 0 0 2rem;

}
.spv .btns > div {
width: 95%;
margin: .5rem auto 0;
}


.spv.lb{
margin: 0;
padding: 5rem 5% 2.5rem;
}
.spv .inner.lb {
    width: 100%;
    margin: 0 auto;
}


/* qa_SP */
.qaWrap{
padding: 1rem 5%;
}
.qa{
padding: 2rem 0;
}
.qa .sttl{
margin: 0 0 .5rem;
padding: 0 0 0 3rem;
background: none;
border: none;
font-size:1.7rem;
color: #003e88;
}
.qa .sttl::before{
content: "";
position: absolute;
top: 16px;
left: 0;
width: 2.2rem;
height: .1rem;
background: #b2b2b2;
}

.qa .txtArea{
padding: 1rem 0 0;
}
.qa .float-wrap{
margin: 0;
padding: 0;
}
.qa .catch{
display: block;
margin: 0 0 1rem;
padding: 0 0 0 3.5rem;
font-size:1.7rem;
color: #f49105;
}
.qa .catch::before{
content: "A.";
position: absolute;
top: -1rem;
left: 0;
font-size:2.5rem;
font-weight: 700;
}
.qa .float-wrap .fr{
padding: 0 0 0.5em;
}
.qa .float-wrap .fl{
padding: 0 0 1em;
}
.qa .float-img{
margin: 0 5%;
}








/* his_SP */
.his{
position: relative;
margin: 6rem 5% 7.5rem;
background: #e9f1fd;
}
.his::before{
content: "SCHEDULE";
position: absolute;
z-index: 1;
top: .5rem;
right: 3%;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:3.5rem;
line-height: 1;
color: #003e88;
opacity: .2;
}

.his .ulBox{
padding: 3.5rem 5% 0 14%;
}
.his .liBox{
display: block;
margin: 0 0 1.5rem;
padding: 0 0 .8rem;
border-bottom: 1px solid #b2b2b2;
}
.his .liBox:last-child{
border: none;
padding: 0 0 2.0rem;
}
.his .ttlTxt{
width: auto;
padding: 0 0 0;
}
.his .mainTxt{
width: auto;
}


.his .sttl{
margin: 0;
font-size:1.5rem;
color: #003e88;
}
.his .catch{
margin: 0 0 .5rem;
font-size:1.6rem;
}

.his .mainTxt p{
font-size:1.3rem;
}
.his .mainTxt p:first-child{
margin-top: .3rem;
}


.his .liBox::before{
content: "";
position: absolute;
top: .3rem;
left: -3.0rem;
width: 1.8rem;
height: 1.8rem;
background: #8ebeef;
border-radius: 50%;
}
.his .liBox::after{
content: "";
position: absolute;
top: 1.0rem;
left: -2.2rem;
width: .1rem;
height: calc(100% + 2rem);
background: #8ebeef;
}

.his .liBox:last-child::after{
display: none;
width: 0;
height: 0;
background: none;
border: none;
}





/* relIntv_SP */
.relIntv{
position: relative;
margin: 3rem 5% 3rem;
}

.relIntv .ulBox{
display: block;
}
.relIntv .liBox{
width: auto;
margin: 0 0 3rem;
padding: 2rem 0 0;
background: #f5f5f5;
}
.relIntv .liBox a {
padding: 0.8rem 0 3.5rem;
}
.relIntv .liBox a::before {
content: "MORE";
position: absolute;
bottom: 0;
right: 0;
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: 3.0rem;
background: url(./img/arrow_wt.svg) calc(100% - .7rem) 50% no-repeat #062d59;
background-size: 1.2rem auto;
font-size: 1.2rem;
font-weight: 700;
color: #fff;
}
.relIntv .imgArea .flame{
width: 20rem;
height: 12.5rem;
margin: 0 auto 2rem;
}
.relIntv .imgArea .flame img{
width: 100%;
object-fit: cover;
}

.relIntv .txtArea{
padding: 0 0 2rem;
}

.relIntv .liBox .headArea{
position: relative;
display: block;
margin: 0 0 1.4rem 5%;
padding: 0 5% 1.6rem 0;
}
.relIntv .liBox .headArea::before{
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: .1rem;
background: #b2b2b2;
}
.relIntv .liBox .headArea::after{
content: "";
position: absolute;
bottom: -0.1rem;
left: 0;
width: 4.0rem;
height: .3rem;
background: #003e88;
}


.relIntv .liBox .spec{
margin: 0 0 .5rem;
}
.relIntv .liBox .boxYw{
display: inline-block;
padding: .2rem .5rem .4rem;
background: #ffe751;
line-height: 1;
color: #003e88;
font-size:1.5rem;
font-weight: 700;
}
.relIntv .liBox .catch{
margin: 0;
color: #003e88;
font-size:1.8rem;
}

.relIntv .liBox .mainTxt{
margin: 0 5%;
}




/* msg_SP */
.msg{
position: relative;
margin: 4rem 0 2rem;
padding: 6rem 0 3.0rem;
background: #fffdef;
}
.msg::before{
content: "MESSAGE";
position: absolute;
z-index: 1;
top: .5rem;
right: 3%;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:3.5rem;
line-height: 1;
color: #003e88;
opacity: .2;
}

.msg .imgArea{
position: static;
width: 25rem;
margin: 0 auto;
}
.msg .imgArea .flame{
margin: 0 0 1.5rem;
}
.msg .imgArea img{
width: 100%;
object-fit: cover;
}

.msg .txtArea{
padding: 1rem 0 0;
}

.msg .txtArea .catch{
margin: 0 0 1.4rem 5%;
padding: 0 5% 1.6rem 0;
font-size:2.0rem;
}
.msg .txtArea .catch::before{
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: .1rem;
background: #b2b2b2;
}
.msg .txtArea .catch::after{
content: "";
position: absolute;
bottom: -0.1rem;
left: 0;
width: 4.0rem;
height: .3rem;
background: #003e88;
}

.msg .txtArea .mainTxt{
padding: 0 5%;
}





/*--------------------------------------
　about_SP
---------------------------------------*/

.about{
position: relative;
z-index: 15;
width: auto;
margin: 5.5rem 5% 4rem;
}
.about::before{
}
.about::after{
content: "ABOUT THIS MEDIA";
position: absolute;
top: -3.3rem;
left: 0;
width: 100%;
text-align: center;
font-family: "Montserrat", sans-serif;
font-weight: 900;
font-size:2.6rem;
}


.about .inner{
position: relative;
padding: 3.8rem 5% 1.5rem;
}
.about .inner::before {
content: "";
position: absolute;
z-index: -1;
top: 0;
left: -5.5%;
width: 100vw;
height: 50%;
}

.about .logo{
position: static;
width: 14.5rem;
margin: 0 auto 2.5rem;
}
.about .logo .logoImg{
width: 15.0rem;
margin: 0 auto.5rem;
}

.about .catch{
margin: 0 0 1.0rem;
font-size:1.8rem;
}
.about .txtArea{
margin: 0 0 0;
	
}

.about .btn-link {
margin: .5rem 0 .2rem;
}





/*--------------------------------------
　biggerlink_SP
---------------------------------------*/

.biggerlink{
cursor: pointer;
transition: all .2s ease-in-out;
}
.biggerlink:hover{
opacity: 1;
}
.biggerlink a:hover{
opacity: 1;
}



}
/* End_SP */





