﻿@charset "utf-8";

/* ----------------------------------------------------------------------------
	top
---------------------------------------------------------------------------- */
#topMain { background:url(../img/top/p_top.jpg) no-repeat center center; background-size: cover; width: 100%; padding-top: 36.8vw; position: relative;}
#topMain .pcTxt { width:860px; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); }
#topMain .spTxt { display: none;}

@media screen and ( max-width:1260px ){
    #topMain { padding-top: 40vw;}
    #topMain .pcTxt { width:788px; }
}
@media screen and ( max-width:980px ){
    #topMain { padding-top: 48vw;}
}
@media screen and ( max-width:860px ){
    #topMain { padding-top: 60vw;}
    #topMain .pcTxt { width:96%; }
}
@media screen and ( max-width:760px ){
    #topMain { padding-top: 54vw;}
}
@media screen and ( max-width:450px ){
    #topMain { padding-top: 106vw; background-size: 110% 110%;}
    #topMain .pcTxt { display: none; }
    #topMain .spTxt { display: block; position: absolute; left: 50%; transform: translate(-50%, 0);}
    #topMain .spTxt01 { width: 114%; top: -2%;}
    #topMain .spTxt02 { width: 80%; bottom: 2%;}
}

.contents { max-width: 1160px; padding-top: 0; padding-bottom: 0;}
.linkBtn { text-align: center; font-size: 1.5rem;}
.linkBtn a { width: 100%; max-width:246px; line-height: 1.0; padding: 0.95em; padding-left: 1.7em; color: inherit; text-decoration: none; border: #999 1px solid; display: -webkit-inline-flex; display: inline-flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; position: relative; transition: background 0.1s ease-out;}
.linkBtn a:after { content: ""; display: block;width: 0;height: 0;border-style: solid;border-width: 4px 0 4px 5px;border-color: transparent transparent transparent #993146; position: absolute; left: 14px; top: 50%; transform: translate( 0, -50%);}
.pc .linkBtn a:hover { background: #F0F0F2; }

#importantBoxWrap { background: #333; color: #fff; padding: 18px 20px; }
#importantBox { display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; padding: 0; }
#importantBox .ttl { background: #7B172C; font-size: 1.5rem; line-height: 1.0; padding: 1em 2.0em; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; margin-right: 30px; white-space:nowrap;}
#importantBox ul { padding: 0.5em 0;}
#importantBox li { font-size: 1.6rem; line-height: 1.3; margin-bottom: 0.95em; position: relative; padding-left: 16px;}
#importantBox li p { display: inline; line-height: 1.3; margin-right: 2em; }
#importantBox li:last-child { margin-bottom: 0;}
#importantBox li:before { content: ""; display: block; width: 0;height: 0;border-style: solid;border-width: 3.5px 0 3.5px 5px;border-color: transparent transparent transparent #B5B5B5; position: absolute; left: 0; top: 0.57em;transform: translate(0, -50%);}
#importantBox li span { opacity: 0.6; font-size: 1.4rem; display: inline-block;}
#importantBox li a { color: #fff; text-decoration: none; line-height: 1.3;}

@media screen and ( max-width:980px ){
    #importantBoxWrap { padding: 16px 20px; }
}
@media screen and ( max-width:700px ){
    #importantBoxWrap { padding: 12px 10px 20px; }
    #importantBox { -webkit-flex-direction: column; flex-direction: column; -webkit-align-items:flex-start; align-items:flex-start; }
    #importantBox .ttl { width: 100%; padding: 0.5em 2.0em; margin: 0 auto 1.2em; font-size: 1.4rem; }
    #importantBox ul { padding: 0;}
    #importantBox li { font-size: 1.5rem;}
    #importantBox li:before { left: 5px; top: 0.57em;}
    #importantBox li p { margin-right: 1.4em; }
    #importantBox li span { font-size: 1.2rem;}
}


h2.pageTtl { font-size: 3.2rem; font-weight: bold; letter-spacing: 0.8px; text-align: center;}
h2.pageTtl p { color: #A41936; font-size: 1.3rem; line-height: 1.3; display: block; font-weight: 600; margin-top: 1em;}
h2.pageTtl span { position: relative; display: inline-block; padding: 0 14px;}
h2.pageTtl span:before, h2.pageTtl span:after { content: ""; width: 14px; height: 1px; display: block; position: absolute; left: 0; top: 50%;transform: translate(-100%, 0); background: #A41936;}
h2.pageTtl span:after {  left: auto; right: 2px; transform: translate(100%, 0);}

@media screen and ( max-width:700px ){
    h2.pageTtl p { margin-top: 0.8em;}
}
@media screen and ( max-width:500px ){
    h2.pageTtl { font-size: 2.8rem; letter-spacing: 0.8px;}
    h2.pageTtl p { margin-top: 0.5em;}
}


#newsWrap { margin-top: 62px;}
#newsWrap h2.pageTtl { font-size: 2.8rem; text-align: left; display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; padding: 0 2px;}
#newsWrap h2.pageTtl p { margin: 0; margin-left: 38px;}
#newsList { margin: 30px auto 35px; border-top: #C2C2C2 1px solid;}
#newsList li { font-size: 1.5rem; padding-bottom: 1px; position: relative;}
#newsList li:before { content: ""; width: 100%; height: 1px; background:#C2C2C2; position: absolute; left: 0; bottom: 0;}
#newsList li a, #newsList li.noLink, #newsPage #newsList li div { display: -webkit-flex; display: flex; -webkit-align-items: flex-start; align-items: flex-start; padding:1em; }
#newsList li a { text-decoration: none; color: inherit; transition: background 0.1s ease-out; }
.pc #newsList li a:hover { background: #F0F0F2;}
p.date { display: -webkit-inline-flex; display: inline-flex; -webkit-align-items: center; align-items: center; font-size: 1.4rem; color: #858585; width: 16.5em; flex-shrink: 0;}
p.date span:not(.type) { margin-right: 2em;}
p.date .type { color: #fff; font-size: 1.2rem; line-height: 1.0; width: 8em; text-align: center; padding: 0.4em; border-radius: 3px;}
p.date .type.unko { background: #4B7296;}
p.date .type.osirase { background: #58917F;}
p.date .type.event { background: #B79745;}
#newsList .ttl { line-height: 1.4; }
#newsWrap .linkBtn a { padding: 0.84em;}

@media screen and ( max-width:980px ){
    #newsWrap { margin-top: 6.4%;}
    #newsList { margin: 3.4% auto 4%;}
    p.date span:not(.type) { margin-right: 1.8em;}
    p.date { width: 16em; }
}
@media screen and ( max-width:700px ){
    #newsWrap { margin-top: 7%;}
    #newsList { margin: 4% auto 6%;}
    #newsList li { font-size: 1.4rem; }
    #newsList li a, #newsList li.noLink, #newsList li div { -webkit-flex-direction: column; flex-direction: column; padding: 0.8em 0.5em;}
    p.date { width: 100%; margin-bottom: 0.4em;}
    p.date span:not(.type) { margin-right: 1.4em;}
    #newsList .ttl { line-height: 1.3; }
}
@media screen and ( max-width:400px ){
    #newsWrap { margin-top: 9%;}
    #newsWrap h2.pageTtl { font-size: 2.5rem;}
    #newsWrap h2.pageTtl p { font-size: 1.2rem; margin-left: 30px;}
    #newsList { margin: 6% auto 8%;}
}


#bigBtnList { max-width: 1108px; margin: 68px auto -22px; position: relative; z-index: 10; display: -webkit-flex; display: flex; -webkit-justify-content:space-between; justify-content:space-between; }
#bigBtnList li { width: 31.6%; font-size: 2.4rem; position: relative;}
#bigBtnList li:after { content: ""; width: 104%; height:32%; background: url(../img/top/btn_shadow.svg) no-repeat center bottom; background-size: cover; position:absolute; z-index: -1; left: 50%; bottom: -18px; transform: translate(-50%, 0%);}
#bigBtnList li a { text-decoration: none; background: #2E3240; color: #fff; display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; padding: 1.5em 0 1.4em; overflow: hidden; transition: background 0.2s ease-out,  transform 0.2s ease-out; }
.pc #bigBtnList li a:hover { background: #592335; transform: translate( 0, 3px);}
#bigBtnList li strong { font-weight: normal; position: relative;}
#bigBtnList li strong:before { content: ""; display: block; width: 200%; height: 2px; background:#83142B; position: absolute; left: -14px; top: 50%; transform: translate(-100%, -50%);}
#bigBtnList li strong:after { content: ""; display: block; width: 200%; height: 2px; background:#83142B; position: absolute; right: -14px; top: 50%; transform: translate(100%, -50%);}
#bigBtnList li span { font-size: 1.1rem; opacity: 0.6; letter-spacing: 1px; display: block; margin-top: 0.9em;}

@media screen and ( max-width:980px ){
    #bigBtnList { margin: 7.5% auto -22px; padding: 0 10px;}
    #bigBtnList li { width: 32.6%; font-size: 2.3rem;}
    #bigBtnList li:after { width: 102%; height:28%;  bottom: -16px;}
    .ie #bigBtnList li:after { height: 34%;}
    #bigBtnList li a { padding: 1.4em 0 1.3em; }
}
@media screen and ( max-width:700px ){
    #bigBtnList { margin: 7.5% auto -22px; padding: 0 4px;}
    #bigBtnList li { width: 32.8%; font-size: 2.2rem;}
    #bigBtnList li:after { width: 102%; height:24%;  bottom: -12px;}
    #bigBtnList li a { padding: 1.2em 0 1.1em; }
    #bigBtnList li strong:before { left: -10px;}
    #bigBtnList li strong:after { right: -10px;}
    #bigBtnList li span { font-size: 1.0rem;}
}
@media screen and ( max-width:530px ){
    #bigBtnList { margin: 11.5% auto -22px; padding: 0 16px; display: -webkit-flex-direction: column; flex-direction: column;}
    #bigBtnList li { width: 100%; margin-bottom: 2.5%; font-size: 2.1rem;}
    #bigBtnList li:after { width: 102%; height: 30%; bottom: -5vw;}
    #bigBtnList li a { padding: 1em 0 0.9em; }
}


#fukuokaArea { width: 100%; height:38vw; min-height: 550px; margin-bottom: -1px; color: #fff; background: url(../img/top/fukuoka.jpg) no-repeat center bottom; background-size: cover; position: relative;}
#fukuokaArea div { width: 100%; padding: 130px 40px 0;}
#fukuokaArea .fukuokaTxt01 { width: 600px;}
#fukuokaArea .fukuokaTxt01SP { display: none;}
#fukuokaArea .fukuokaTxt02 { width: 520px; margin: 58px 0 60px 30px;}
#fukuokaArea .teikyo { font-size: 1.1rem; position: absolute; right: 8px; bottom: 9px; opacity: 0.8; letter-spacing: 0.6px;}
#fukuokaArea .linkBtn { margin: 0; position: relative; z-index: 10;}
#fukuokaArea .linkBtn a { font-size: 1.3rem; font-weight: 300; letter-spacing: 0.5px; border-color: #fff; max-width:200px; padding-left: 20px; }
#fukuokaArea .linkBtn a:after { border-color: transparent transparent transparent #fff;}
#fukuokaArea .linkBtn a:before { content:""; display: block; width: 100.5%; height: 104%; background: #7EA6D8; opacity: 0.84; position: absolute; left: 4px; top: 4px; z-index: -1; transition: transform 0.1s ease-out; }
.pc #fukuokaArea .linkBtn a:hover { background: none;}
.pc #fukuokaArea .linkBtn a:hover:before {transform: translate(-4px, -4px);}

@media screen and ( max-width:980px ){
    #fukuokaArea { height:52vw; min-height: 0;}
    #fukuokaArea div { padding-top: 12.6%;}
    #fukuokaArea .fukuokaTxt02 { margin: 40px 0 38px 30px;}
    #fukuokaArea .linkBtn { width: 70%; margin-right: auto;}
}
@media screen and ( max-width:800px ){
    #fukuokaArea { height:68vw;}
    #fukuokaArea div { padding-top: 15%;}
    #fukuokaArea .fukuokaTxt01 { width: 82%;}
    #fukuokaArea .fukuokaTxt02 { width: 68%; margin: 7% 0 8.6% 30px;}
    #fukuokaArea .linkBtn { width: 70%; margin-right: auto;}
}
@media screen and ( max-width:650px ){
    #fukuokaArea { height:74vw;}
    #fukuokaArea div { padding: 18% 20px 0;}
    #fukuokaArea .fukuokaTxt01 { width: 100%;}
    #fukuokaArea .fukuokaTxt02 { width: 92%; margin: 8% 0 7% 20px;}
}
@media screen and ( max-width:530px ){
    #fukuokaArea div { padding: 17% 20px 0;}
}
@media screen and ( max-width:450px ){
    #fukuokaArea { height:99vw;}
    #fukuokaArea div { padding: 16% 20px 0;}
    #fukuokaArea .fukuokaTxt01 { display: none;}
    #fukuokaArea .fukuokaTxt01SP { display: block; width: 80%; max-width: 320px;}
    #fukuokaArea .fukuokaTxt02 { width: 99%; margin: 10% 0 11% 0;}
    #fukuokaArea .linkBtn a { max-width:174px; font-weight: 400; }
}


#serviceBox { background: #333; background : -webkit-linear-gradient(0deg, rgba(23, 23, 23, 1) 0%, rgba(51, 51, 51, 1) 30%, rgba(51, 51, 51, 1) 70%, rgba(23, 23, 23, 1) 100%);
  background : -webkit-gradient(linear,0% 50% ,100% 50% ,color-stop(0,rgba(23, 23, 23, 1) ),color-stop(0.3,rgba(51, 51, 51, 1) ),color-stop(0.7,rgba(51, 51, 51, 1) ),color-stop(1,rgba(23, 23, 23, 1) ));
  background : linear-gradient(90deg, rgba(23, 23, 23, 1) 0%, rgba(51, 51, 51, 1) 30%, rgba(51, 51, 51, 1) 70%, rgba(23, 23, 23, 1) 100%); color: #fff; padding: 66px 0 44px; }
#serviceBox h2 span { color: #fff;}
#serviceBox h2 span:before, #serviceBox h2 span:after { background: #fff;}
#serviceBox ul { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; margin-top: 64px;}
#serviceBox li { width: 25%; /*padding-top: 20%;*/ display: -webkit-flex; display: flex; overflow: hidden;}
#serviceBox li a { display: -webkit-flex; display: flex; color: inherit; text-decoration: none; padding-top: 80%; position: relative;}
#serviceBox li div { width: 100%; background: rgba(0, 0, 0, 0.5); font-size: 1.4rem; padding: 0 1.5em 2.6em; position: relative; z-index: 10;}
#serviceBox li h3 { font-size: 2.5rem; margin-top: 1.6em;}
#serviceBox li h3 span:not(.nowrap) { display: block; font-size: 1.1rem; letter-spacing: 1px; margin: 0.8em 0 0;}
#serviceBox li div p { line-height: 1.5; text-align: left; margin-top: 1.9em;}

/*#serviceBox li:nth-child(1) { background:#333; position: relative;}
#serviceBox li:nth-child(1):before { content:""; width: 100%; padding-top: 80%; box-sizing: border-box; position: absolute; left: 0; top: 0; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; background: url(../img/top/g_logo.svg?1204) no-repeat center center; background-size: 60%;}*/
#serviceBox li a:before { content: ""; display: block; position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: 0;}
#serviceBox li:nth-child(1) h3 { letter-spacing: -3px;}
#serviceBox li:nth-child(1) a:before { background:url(../img/top/p_info.jpg) no-repeat center center; background-size: cover;}
#serviceBox li:nth-child(2) {  transform: translate( 0, -30px);}
#serviceBox li:nth-child(2) a:before { background:url(../img/top/p_hotel.jpg) no-repeat center center; background-size: cover;}
#serviceBox li:nth-child(3) a:before { background:url(../img/top/p_spa.jpg) no-repeat center center; background-size: cover;}
#serviceBox li:nth-child(4) { transform: translate( 0, -30px);}
#serviceBox li:nth-child(4) a:before { background:url(../img/top/p_bar.jpg) no-repeat center center; background-size: cover;}

#serviceBox .linkBtn { margin-top: 40px;}

.pc #serviceBox li a:before { transition: 0.2s all ease-out; transform:scale(1);-webkit-backface-visibility:hidden;backface-visibility:hidden;}
.pc #serviceBox li a:hover:before { transform:scale(1.06); }
.pc #serviceBox .linkBtn a:hover { background: rgba(131, 20, 43, 0.5);}


@media screen and ( max-width:1100px ){
    #serviceBox li div { padding: 0 1.3em 2.2em;}
}
@media screen and ( max-width:990px ){
    #serviceBox ul { -webkit-flex-wrap: wrap; flex-wrap: wrap; margin-top: 44px;}
    #serviceBox li { width: 50%; /*padding-top: 20%;*/ transform: translate( 0, 0) !important; }
    #serviceBox li a { padding-top: 40%;}
    #serviceBox li h3 { font-size: 2.5rem; margin-top: 1.3em;}
    #serviceBox li div { padding: 0 1.8em 1.5em;}
    #serviceBox li div p { margin-top: 1.7em;}
    
    #serviceBox li:nth-child(1):before { padding-top: 40%; background-size: 50%;}
}
@media screen and ( max-width:850px ){
    #serviceBox { padding: 8% 0 5%; }
}
@media screen and ( max-width:700px ){
    #serviceBox li { /*padding-top: 25%;*/ }
    #serviceBox li a { padding-top: 50%;}
    #serviceBox li h3 { font-size: 2.4rem; margin-top: 0.9em;}
    #serviceBox li h3 span:not(.nowrap) { font-size: 1.0rem; margin: 0.7em 0 0;}
    #serviceBox li div { padding: 0 1.4em 1.1em;}
    #serviceBox li div p { margin-top: 1.4em; }
    #serviceBox .linkBtn { margin-top: 6%;}
    
    #serviceBox li:nth-child(1) a:before { background-size: 120%; background-position: center bottom;}
}
@media screen and ( max-width:600px ){
    #serviceBox li h3 { font-size: 2.2rem;}
    #serviceBox li div { font-size: 1.3rem;}
}
@media screen and ( max-width:480px ){
    #serviceBox { padding: 12% 0 7%; }
    #serviceBox ul { margin-top: 8%;}
    #serviceBox li { width: 100%; /*padding-top: 36%;*/ }
    #serviceBox li a { padding-top: 36%;}
    #serviceBox .linkBtn { margin-top: 8.5%;}
    
    #serviceBox li:nth-child(1) a:before { background-size: 140%;}
}


#mapArea { margin: 70px auto 80px; }
#mapArea .gMap { margin: 38px 0 30px;}
#mapArea iframe { width: 100%; height: 40vw; max-height: 450px; min-height: 400px;  -webkit-filter: grayscale(0.95) contrast(0.9); filter: grayscale(0.95) contrast(0.9);}
@media screen and ( max-width:1220px ){
    #mapArea { margin: 5.4% auto 6%; }
    #mapArea .gMap { margin: 3.5% 0 3.2%;}
}
@media screen and ( max-width:900px ){
    #mapArea { margin: 6% auto 7%; }
}
@media screen and ( max-width:600px ){
    #mapArea { margin: 8% auto 10%; }
    #mapArea .gMap { margin: 5% 0 5.5%;}
}
@media screen and ( max-width:480px ){
    #mapArea { margin: 11% auto 12%; }
    #mapArea .gMap { margin: 7% 0 6%;}
}



#csBnr { width: 100%; max-width: 990px; margin: 45px auto 0; padding: 0 15px;}
#csBnr a { display: block; height: 96px; background: url(../img/top/cs_bg.jpg) no-repeat center top -130px; background-size: cover; border: #fff 3px solid; position: relative; overflow: hidden;}
.pc #csBnr a:hover,
.pc #wcBnr a:hover { opacity: 0.8;}
#csBnr a:before { content: ""; display: block; width: 200px; height: 1px; background: #fff; position: absolute; right: 140px; top: 50%; transform: rotate(-38deg);}
#csBnr .txt { width: 600px;  height: 30px; background: url(../img/top/cs_txt.svg) no-repeat; background-size: contain; position: absolute; left: 26px; top: 22px;}
#csBnr .txt img { display: none;}
#csBnr .view,
#wcBnr .view { background:#A41936; box-shadow : -1px 1px 2px rgba(0, 0, 0, 0.3); width: 230px; height: 64px; position: absolute; right: 0; top: 50%; z-index: 10; transform: translate(0%, -50%); display: -webkit-flex; display: flex; wrap; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
#csBnr .view img,
#wcBnr .view img { width: 108px;}
#csBnr .view:before,
#wcBnr .view:before { content: ""; display: block; width: 17px; height: 9px; background: url(../img/icon_blank.svg) no-repeat; position: absolute; left: 7px;top: 7px;}
#csBnr .view:after,
#wcBnr .view:after { content: ""; display: block; width: 8px; height: 14px; background: url(../img/top/cs_arrow.svg) no-repeat; position: absolute; right: 12px; top: 50%; transform: translate(0%, -50%);}

#wcBnr { width: 100%; max-width: 990px; margin: 20px auto 0; padding: 0 15px;}
#wcBnr a { display: block; height: 96px; background: url(../img/top/wc_bg.jpg) repeat center top -130px; border: #fff 3px solid; position: relative; overflow: hidden;}
#wcBnr .txt { width: 600px;  height: 58px; background: url(../img/top/wc_txt.svg) no-repeat; background-size: contain; position: absolute; left: 26px; top: 17px; -webkit-backface-visibility:hidden; backface-visibility:hidden;}
#wcBnr .txt img { display: none;}

@media screen and ( max-width: 920px ){
    #csBnr .txt { width: 480px; height: 24px; left: 20px;}
    #csBnr .view,
    #wcBnr .view { width: 200px; height: 56px; }
    #csBnr a:before,
    #wcBnr a:before { right: 110px; transform: rotate(-45deg);}
    #wcBnr .txt { width: 480px; height: 46px; left: 20px; top: 22px;}
}
@media screen and ( max-width: 760px ){
    #csBnr { width: 82%; margin: 10% auto 4%; padding: 0;}
    #csBnr a { height: auto; padding-top: 56%; background: url(../img/top/cs_bg.jpg) no-repeat center top -130px;}
    #csBnr a:before { width: 100%; right: 0; top: auto; bottom: 0; transform: translate(20%, 0) rotate(-45deg);}
    #csBnr .txt { width: 88%; height: auto; background: none; left: 6%; top: 14%; transform: translate( 0, 0);}
    #csBnr .txt img { display: inline-block;}
    #csBnr .view,
    #wcBnr .view { width: 54%; height: 24%; position: absolute; right: 0; top: auto; bottom: 4%; z-index: 10; transform: translate( 0, 0); padding: 0 14%;}
    #csBnr .view img,
    #wcBnr .view img { width: 100%;}
    #csBnr .view:before,
    #wcBnr .view:before { width: 14px; height: 7px; left: 7px; top: 6px;}
    #csBnr .view:after,
    #wcBnr .view:after { width: 6px; height: 11px; right: 12px;}
  
    #wcBnr { width: 82%; margin: 6% auto 4%; padding: 0;}
    #wcBnr a { height: auto; padding-top: 56%;}
    #wcBnr a:before { width: 100%; right: 0; top: auto; bottom: 0; transform: translate(20%, 0) rotate(-45deg);}
    #wcBnr .txt { width: 88%; height: auto; background: none; left: 6%; top: 12%; transform: translate( 0, 0);}
    #wcBnr .txt img { display: inline-block;}
}

/*TOPページ資料ダウンロード*/

/*追加リセット*/

figure{
	margin: 0;
}

/*バナー・モーダル用記述*/

.dl-banner {
    position: absolute;
    width: 435px;
    right: 0;
    top: 250px;
    z-index: 99;
    background: rgba(255, 255, 255, 1);
    display: flex;
    justify-content: space-between;
    padding: 20px 40px 20px 10px;
    transition: 0.3s;
    border-radius: 6px 0 0 6px;
	overflow: hidden;
}
.dl-banner.in-banner {
    top: 65px;
}

.dl-banner--second {
    top: 500px;
    background: #004d86;
    padding: 28px 40px 20px 10px;
}
.dl-banner--second.in-banner--second {
    top: 320px;
}
.dl-banner--second:before {
	content: "";
	background: url("../../images/bd_gold.png") no-repeat;
	background-size: cover;
	width: 100%;
	height: 8px;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}

@media screen and (min-width: 1600px) {
    .dl-banner {
        right: 0px;
        padding: 20px 40px 20px 20px;
    }

    .dlOpenBtn {
        display: none;
    }
}

.dl-banner img {
    width: 100%;
    margin: 0 auto;
}

.dl-banner.is-close {
    right: -392px;
}

.dlOpenBtn {
    position: relative;
    padding-right: 10px;
    transition: 0.3s;
    text-align: center;
    cursor: pointer;
    border: none;
    background: transparent;
}

.dlOpenBtn:before {
    content: "";
    background: url(../../images/arrow_r.png) no-repeat;
    background-size: contain;
    width: 12px;
    height: 21px;
    display: block;
    position: absolute;
    top: 100px;
    left: 6px;
}

.dl-banner.is-close .dlOpenBtn:before {
    background: url("../../images/arrow_l.png") no-repeat;
    background-size: contain;
}
.dl-banner--second .dlOpenBtn:before {
    content: "";
    background: url("../../images/arrow_r_2.png") no-repeat;
    background-size: contain;
}

.dl-banner--second.is-close .dlOpenBtn:before {
    background: url("../../images/arrow_l_2.png") no-repeat;
    background-size: contain;
}

.dlOpenIcon {
    transition: 0.3s;
    position: relative;
    top: 60px;
    width: 25px;
    display: inline-block;
}

.dlOpenIcon img {
    width: 100%;
    height: auto;
}

.dl-banner .dlOpenIcon {
    opacity: 0;
}
.dl-banner.is-close .dlOpenIcon {
    opacity: 1;
}

.dlBnImg {
    margin-bottom: 20px;
}
#dl-banner2 .dlBnImg {
    margin-bottom: 0px;
}

.dl-banner__btn {
    width: 120px;
    display: inline-block;
    border: none;
    background: transparent;
	cursor: pointer;
	transition: 0.3s;
}
.dl-banner__btn:hover {
	opacity: 0.8;
}
#openDlPreview2 {
    position: absolute;
    width: 130px;
    top: 186px;
    left: 207px;
}

.dl-modal[aria-hidden="true"] {
    display: none;
}

.dl-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
}

.dl-modal img {
    width: 100%;
    height: auto;
}

.dl-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .5);
}

.dl-modal__panel {
    position: relative;
    max-width: 445px;
    margin: 0 auto;
    background: #fff;
    padding: 40px;
    box-sizing: border-box;
    border-radius: 6px;
    box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.5);
    text-align: left;
    top: 70px;
}
.in-modal__panel {
    top: 65px;
}

#dlModalTitle,
#dlModalTitle2 {
    padding: 0;
    margin-bottom: 20px;
}

.dlModalTxt {
    text-align: center;
    font-size: 1.4rem;
    font-weight: bold;
    margin-bottom: 20px;
}

.formW {
    margin-bottom: 10px;
}

.formW2 {
    margin-bottom: 30px;
}

.formTxt {
    font-size: 14px;
    margin-bottom: 5px;
    letter-spacing: 0.1em;
}

.input1 {
    width: 100%;
    border-radius: 5px;
    border: 1px solid rgba(0, 0, 0, 0.2);
    background: #fafafb;
    box-sizing: border-box;
    padding: 10px 15px;
}

.formLink {
    text-decoration: underline;
}

.submitW {
    text-align: center;
}

#dlForm button,
#dlForm2 button {
    border: none;
    background: transparent;
}

.submitW button {
    width: 155px;
    display: inline-block;
}

.closeW {
    position: absolute;
    top: 15px;
    right: 15px;
    width: 20px;
}

@media screen and (max-width: 1023px) {
    .dl-banner {
        width: 270px;
        box-sizing: border-box;
        top: 105px;
        right: 0px;
    }
    .dl-banner.is-close {
        right: -230px;
    }

    .dl-banner--second {
        top: 290px;
    }
.dl-banner.in-banner {
    top: 40px;
    position: fixed;
}
.dl-banner--second.in-banner--second {
    top: 218px;
    position: fixed;
}
    .dl-modal__panel {
        max-width: 90%;
        padding: 40px 20px;
        top: 70px;
    }
    .dlOpenBtn:before {
        top: 70px;
    }

    .dlOpenIcon {
        top: 30px;
    }
#openDlPreview2 {
    left: 131px;
    top: 107px;
    width: 95px;
}
}

/*資料一部プレビュー*/

.previewModal {
  display: block;
  width: 100%;
  background: #fff;
}

.previewModal__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 20px;
}

.previewModal__title {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 20px;
  text-align: center;
}

.previewModal__pages p {
  margin-bottom: 20px;
}

.previewModal__pages img {
  width: 100%;
  height: auto;
  display: block;
}

.previewModal__btn {
  margin-top: 30px;
  text-align: center;
}

.previewModal__btn button {
  display: inline-block;
  min-width: 240px;
  padding: 16px 24px;
  border: 0;
  cursor: pointer;
	background: inherit;
}

#colorbox,
#cboxOverlay {
  z-index: 99999 !important;
}

@media screen and (max-width: 1023px) {
  .previewModal__inner {
    padding: 14px;
  }

  .previewModal__title {
    font-size: 18px;
    margin-bottom: 14px;
  }
.previewModal__title img {
    width: 100%;
    height: auto;
}
  .previewModal__pages p {
    margin-bottom: 12px;
  }

  .previewModal__btn {
    margin-top: 20px;
  }

  .previewModal__btn button {
    width: 100%;
    min-width: 0;
  }
}

/*横長バナー追加*/

.newBnWrap {
    max-width: 1160px;
    padding-top: 0;
    padding-bottom: 0;
    margin: 30px auto;
}
#openDlPreview2Bn{
	margin-bottom: 30px;
	display: block;
}
@media screen and ( max-width:860px ){
	.newBnWrap {
		max-width: 90%;
	}
}

.mobility_bn img {
    width: 100%;
    height: auto;
}
