:root{
--dark-blue:#344a63;
--blue:#2a4e95;
--light-blue:#7ed8e7;
--grad-top-blue:#84e4eb;
--grad-bottom-blue:#65a4e1;
}

@font-face {
font-family: 'icomoon';
src:  url('fonts/icomoon.eot?2ck8aw');
src:  url('fonts/icomoon.eot?2ck8aw#iefix') format('embedded-opentype'),
url('fonts/icomoon.ttf?2ck8aw') format('truetype'),
url('fonts/icomoon.woff?2ck8aw') format('woff'),
url('fonts/icomoon.svg?2ck8aw#icomoon') format('svg');
font-weight: normal;
font-style: normal;
font-display: block;
}


*{
box-sizing: border-box;
}

html{
overflow-x: hidden;
width: 100%;
font-size:min(0.78125vw, 10px);
font-family: 'Jost', 'Zen Kaku Gothic New', sans-serif;
font-weight: 400;
font-feature-settings: "palt";
font-optical-sizing: auto;
}

body{
position: relative;
color: #000;
width: 100%;
line-height:1.6;
font-size: 1.4rem;
letter-spacing: 0.03em;
font-feature-settings: "palt" 1;
}

p > a,
li > a{
font-weight: 700;
}

br.sp{
display:none;
}

@media screen and (max-width:750px) {

html{
font-size:3.2vw;
}

br.sp{
display:block;
}

}

/**
HEADER
**/

#nishijo-auto{
position: fixed;
z-index: 200;
display: flex;
align-items: center;
padding:2rem;
line-height: 1;
font-size: 2rem;
font-weight: 400;
transition: all 0.3s ease-in-out;
}

#nishijo-auto span{
display: inline-block;
margin-left: 1em;
font-size: 50%;
font-weight: 700;
letter-spacing: 0.1em;
}



#header{
position: sticky;
top: 0;
left: 0;
z-index: 100;
width: 100%;
transition: all 0.3s ease-in-out;
}

#header div{
display: flex;
justify-content:flex-end;
padding: 0 7.5rem 0 2rem;
margin: auto;
}



#header nav{
display: flex;
}

#header ul{
display: flex;
font-size: 1.3rem;
font-weight: 500;
list-style: none;
}


#header li a{
display: inline-block;
padding: 1.808em 0.65em;
line-height: 1;
transition: all 0.3s ease-in-out;
}

#header li a:link,
#header li a:visited{
color: #000;
text-decoration-color: transparent;
}

#header li a:hover{
color:var(--dark-blue);
text-decoration-color:var(--dark-blue);
}


#header address{
padding:0.1em 0 0 0.9em;
line-height: 1.1;
font-size: 1.8rem;
font-weight: 700;
letter-spacing: 0.04em;
}

#header address span{
display: inline-block;
font-size:50%;
font-weight: 400;
text-align: center;
letter-spacing: 0;
}

#header address a{
display: inline-block;
padding: 0 0.16em 0 0.2em;
transition: all 0.3s ease-in-out;
}

#header address a:link,
#header address a:visited{
background-color: var(--grad-top-blue);
color: #000;
text-decoration: none;
}

#header address a:hover{
color: #fff;
}

@media screen and (max-width:750px) {

#nishijo-auto{
padding: 1.3rem 1rem;
font-size: 1.5rem;
}

#header{
opacity: 0;
visibility: hidden;
}

#header ul,
#header address{
overflow: hidden;
height: 4rem;
}

}

/**
UI
**/

#menu-flg{
display: none;
}

#menu-hmb{
position: fixed;
z-index: 200;
right:0;
display: block;
background-color: transparent;
width: 6rem;
height: 6rem;
text-align: center;
cursor: pointer;
transition: all 0.3s ease-in-out;
}

#menu-hmb:hover{
background-color: var(--grad-top-blue);
}

#menu-hmb span{
position: absolute;
left: 50%;
transform: translateX(-50%);
display: inline-block;
font-size: 0.9rem;
transition: all 0.3s ease-in-out;
}

#menu-hmb span:nth-child(1),
#menu-hmb span:nth-child(2){
position: absolute;
left: 50%;
transform: translateX(-50%);
background-color: #000;
width: 2.5rem;
height: 1px;
}

#menu-hmb span:nth-child(1){
top: 34%;
}
#menu-hmb span:nth-child(2){
top: 42%;
}

#menu-hmb span:nth-child(3){
bottom:1.7rem;
}

#menu-hmb:hover span{
background-color: var(--dark-blue);
}

#menu-hmb:hover span:last-child{
background-color: transparent;
color: var(--dark-blue);
}

#menu-flg:checked + #menu-hmb span:nth-child(1){
top:38%;
transform: translateX(-50%) rotate(30deg);
background-color: #fff;
}

#menu-flg:checked + #menu-hmb span:nth-child(2){
top:38%;
transform: translateX(-50%) rotate(-30deg);
background-color: #fff;
}

#menu-flg:checked + #menu-hmb span:nth-child(3){
color: #fff;
}


#menu{
position: fixed;
z-index: 100;
top: 0;
right: 0;
overflow: hidden;
border-radius:0 0 0 100vw;
width: 0;
height: 0;
transition: all 0.3s ease-in-out;
}

#menu::after{
content:"";
position: absolute;
top: 0;
left: 0;
display: block;
background: linear-gradient(var(--grad-top-blue), var(--grad-bottom-blue));
width: 100%;
height: 100%;
opacity: 1;
transition: all 0.3s ease-in-out;
}


#menu-flg:checked + #menu-hmb + #nishijo-auto{
color: #fff;
}

#menu-flg:checked + #menu-hmb + #nishijo-auto + #menu{
border-radius: 0;
width: 100vw;
height: 100vh;
}


#menu-flg:checked + #menu-hmb + #nishijo-auto + #menu::after{
opacity: 1;
}

#menu div{
position: absolute;
z-index: 1;
top: 50%;
left: 50%;
transform: translate(-60%,-50%);
width: 70%;
opacity: 0;
}

#menu ul{
display: flex;
flex-wrap: wrap;
font-size: 2rem;
list-style: none;
}

#menu-flg:checked + #menu-hmb + #nishijo-auto + #menu div{
animation-name: menuULopen;
animation-duration: 0.6s;
opacity: 1;
}
#menu-flg:not(:checked) + #menu-hmb + #nishijo-auto + #menu div{
animation-name: menuULclose;
animation-duration: 0.2s;
opacity: 0;
}

#menu li{
width: calc(100% / 3);
margin-bottom: 2.5rem;
line-height: 1.3;
}


#menu li span{
display: block;
font-size: 0.5em;
}

#menu a{
font-weight: 500;
transition: all 0.3s ease-in-out;
}

#menu a:link,
#menu a:visited{
color: #fff;
text-decoration-color: transparent;
}

#menu a:hover{
text-decoration-color: #fff;
}

#menu address{
color: #fff;
}

#menu address a{
font-size:3rem;
}

#menu address span{
display: inline-block;
margin-right: 0.4em;
font-size: 0.8em;
}




@keyframes menuULopen{
0% {
opacity: 0;
}
100% {
opacity: 1;
}
}
@keyframes menuULclose{
0% {
opacity: 1;
}
100% {
opacity: 0;
}
}




.viewmore{
font-size: 1.4rem;
}

.viewmore a{
position: relative;
display: inline-block;
text-decoration: none;
transition: all 0.3s ease-in-out;
}

.viewmore a:link,
.viewmore a:visited{
color: var(--dark-blue);
border-bottom: 1px solid #ccc;
}

.viewmore a:hover{
color: var(--grad-bottom-blue);
border-bottom-color: var(--grad-bottom-blue);
}

.viewmore a i{
position: absolute;
top: 50%;
right: -4.6rem;
transform: translateY(-50%);
display: inline-block;
background-color: var(--grad-top-blue);
border-radius: 3.6rem;
width: 3.6rem;
height: 3.6rem;
transition: all 0.3s ease-in-out;
}

.viewmore a i::before,
.viewmore a i::after{
content: "";
position: absolute;
}

.viewmore a i::before{
top: calc(50% - 1px);
left: 50%;
transform: translate(-50%);
border-top: 2px solid #fff;
width: 0.8rem;
}

.viewmore a i::after{
top: 50%;
left:calc(50% - 0.1rem);
transform: rotate(45deg);
transform-origin:top right;
border-top: 2px solid #fff;
border-right: 2px solid #fff;
width: 0.6rem;
height: 0.6rem;
}

.viewmore a:hover i{
background-color: var(--grad-bottom-blue);
}

@media screen and (max-width:750px) {

#menu-hmb{
right: 0;
width: 5rem;
height: 4rem;
}

#menu-hmb span:nth-child(1){
top: 30%;
}
#menu-hmb span:nth-child(2){
top: 38%;
}

#menu-hmb span:nth-child(3){
bottom:0.5rem;
}

#menu-flg:checked + #wrap #menu-hmb span:nth-child(1){
top:34%;
}

#menu-flg:checked + #wrap #menu-hmb span:nth-child(2){
top:34%;
}

#menu div{
transform: translate(-50%,-50%);
width: 90%;
}

#menu ul{
font-size: 1.5rem;
}

#menu li{
width: 50%;
margin-bottom: 1.5rem;
}

#menu address a{
font-size: 2rem;
}


}


/**
ARTICLE | MAIN
*/

.contents > header{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
color: var(--dark-blue);
}

.contents > header div:first-child{
width: 45vw;
padding:0 0 0 5rem;
}

.contents h1{
position: relative;
z-index: 1;
margin-bottom: 2em;
line-height: 1;
font-size: 1.6rem;
font-weight: 500;
white-space: nowrap;
}

.contents h1 span{
display: inline-block;
margin-top: 0.1em;
line-height: 1;
font-size: 12rem;
font-weight:700;
}

.contents > header p{
line-height: 2.143;
font-size: 1.6rem;
font-weight: 500;
}

.contents .eyecatch{
width:50vw;
height: 35.7143vw;
filter: drop-shadow(10px 10px 10px rgba(132,228,235,0.9));
}

.contents .eyecatch img{
object-fit: cover;
border-radius:17.85715vw 0 0 17.85715vw;
width: 100%;
height: 100%;
}

.contents section .content{
position: relative;
width: min(88.889vw, 1280px);
margin: auto;
padding: 8.3rem 0;
}

.contents section:nth-of-type(even){
position: relative;
}

.contents section:nth-of-type(even)::after{
content: "";
position: absolute;
z-index: -1;
top: 0;
left: 0;
display: block;
background: linear-gradient(to bottom, var(--grad-top-blue), var(--grad-bottom-blue));
width: 100%;
height: 100%;
opacity: 0.1;
}

.contents .column{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}

.contents .column > div{
width: 50%;
margin-bottom: 4rem;
}

.contents .column > div:nth-of-type(odd){
padding-right:3rem;
}
.contents .column > div:nth-of-type(even){
padding-left:3rem;
}

.contents section .content > h2{
position: relative;
display: flex;
align-items: center;
color: #000;
margin-bottom: 1.5em;
font-size: 2.6rem;
font-weight: 500;
}

.contents section .content > h2::before{
content: "";
display: inline-block;
box-sizing: border-box;
border: 1.15rem solid var(--light-blue);
border-radius: 50%;
width: 4rem;
height: 4rem;
margin-right: 0.6em;
}

.contents h3{
margin-top: 5rem;
margin-bottom: 0.9em;
font-size: 1.6rem;
font-weight: 900;
}

.contents h3 span{
display: inline-block;
background-color:var(--grad-bottom-blue);
color: #fff;
border-radius: 3em;
text-shadow: 0 0 1px rgba(0,0,0,0.4);
padding: 0.8em 1.8em;
}


.contents h3 ~ p:not(:last-child){
margin-bottom:3rem;
}


.contents .column > h3{
width: 100%;
}

.contents h4{
position: relative;
margin:3rem 0 2rem 0;
padding-left: 1.5em;
font-size: 1.6rem;
font-weight: 700;
}

.contents h3 + h4{
margin-top: 4rem;
}

.contents h4::before{
content: "";
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
display: inline-block;
background-color:var(--blue);
border-radius: 50%;
width: 1.3em;
height: 1.3em;
margin-right: 0.3em;
line-height: 1;
}

.contents h2 + p{
margin-bottom: 4rem;
font-size: 1.6rem;
}

.contents p,
.contents ul,
.contents ol,
.contents dl,
.contents table{
font-size: 1.5rem;
}

.contents p,
.contents ul,
.contents ol,
.contents dl{
line-height: 2.143;
font-weight: 500;
}

.contents dt{
font-weight: bold;
}

.contents dd + dt{
margin-top: 0.5em;
}

.contents dd{
padding-left: 1em;
}

.contents ul{
padding-left: 1.8em;
}

.contents table{
width: 100%;
margin-top: 1rem;
}

.contents caption{
padding: 1em 0;
font-weight: bold;
text-align: center;
}

.contents th,
.contents td{
padding: 1em;
}

.contents th{
white-space: nowrap;
}

.contents tr:first-child th,
.contents tr:first-child td{
border-top: 1px solid #ddd;
}

.contents tr th,
.contents tr td{
border-bottom: 1px solid #ddd;
}

.contents h3 + table{
margin-top: 2rem;
}

.contents .content > table{
margin-bottom: 4rem;
}

.contents img{
max-width: 100%;
}

.contents .meta{
margin-bottom: 4rem;
}

.contents .meta strong{
font-size: 1.2em;
}

.contents .meta:last-of-type{
display: flex;
justify-content: space-between;
margin-top: 4rem;
margin-bottom: 0;
}



.contents section .content > .viewmore:last-child{
position:absolute;
top:8.8rem;
right: 4.5rem;
}

@media screen and (max-width:750px) {

.contents > header{
position: relative;
display: block;
padding: 15vw 4vw 0 4vw;
}

.contents > header div:first-child{
width: 100%;
padding:0;
}

.contents h1{
margin-bottom: 80vw;
}

.contents h1 span{
font-size: 3.8rem;
}

.contents > header p{
font-size: 1.3rem;
white-space:unset;
}

.contents .eyecatch{
position: absolute;
z-index: -1;
top: 45vw;
right: 0;
transform: translateY(0);
width: 96vw;
height: 60vw;
}

.contents .eyecatch img{
border-radius: 35vw 0 0 35vw;
}


.contents section .content{
width:92vw;
padding: 4.15rem 0;
}

.contents section .content > h2{
margin-bottom: 2em;
font-size: 1.7rem;
}

.contents section .content > h2::before{
border-width: 0.85rem;
width: 3rem;
height: 3rem;
margin-right: 0.4em;
}

.contents section h2 + p{
font-size: 1.2rem;
}

.contents .column{
display: block;
}

.contents .column > div,
.contents .column > div:first-child,
.contents .column > div:last-child{
width: 100% !important;
}

.contents .column > div:nth-of-type(odd){
padding-right:0;
}
.contents .column > div:nth-of-type(even){
padding-left:0;
}

.contents section h3{
font-size: 1.3rem;
}


.contents section .content > .viewmore:last-child{
top: 9rem;
left: 0;
}

.contents section h2 + .photo{
margin: 0 0 2.2rem 0;
}

.contents section p,
.contents section ul,
.contents section ol,
.contents section dl,
.contents section table{
font-size: 1.1rem;
}

.contents .meta{
display: block;
}

.contents .meta:last-of-type p{
text-align: right;
}


}


/**
PAGE NAV
*/

.wp-pagenavi{
width: 100%;
font-size: 1.2rem;
}



/**
ACCESS
*/

#access{
position: relative;
z-index: 20;
}

#access .content{
display: flex;
flex-direction: row-reverse;
align-items: center;
padding-top: 8.3rem;
}

#access .content > div{
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
width:32.14%;
}

#access h2{
color: #aaa;
line-height: 1.3;
font-size: 1.1rem;
}

#access h2 span{
display: block;
color: var(--dark-blue);
font-size: 4.6rem;
}

#access iframe{
border: none;
width: 67.86%;
height: 34.143vw;
}

#access table{
margin-top: 4rem;
}

#access caption{
color: var(--dark-blue);
margin-bottom: 1rem;
font-size: 2.2rem;
font-weight: 500;
}

#access tr{
display: block;
margin-bottom: 1.1rem;
}

#access th{
display: inline-block;
background-color: var(--dark-blue);
color: #fff;
border-radius: 1em;
padding: 0 0.5em;
font-size: 1.2rem;
font-weight: 500;
}

#access td{
display: block;
color: var(--dark-blue);
font-size: 1.6rem;
}

#access td br{
display: none;
}

@media screen and (max-width:750px) {

#access .content{
flex-wrap: wrap;
width: 92vw;
margin: auto;
padding:4.15rem 0 0 0;
}

#access .content > div{
display: block;
width: 100%;
}

#access table{
margin-top: 1.4rem;
}

#access td br{
display: block;
}

#access iframe{
width: 100vw;
height: 100vw;
margin: 0 -4vw;
}

}





/**
FOOTER CONTACT
**/

#footer-contact{
position: relative;
z-index: 1;
background-image: url('../images/footer-contact-bg.webp');
background-repeat: no-repeat;
background-size: cover;
background-position: center center;
box-shadow: 0 15px 10px rgba(0, 0, 0, 0.16);
color: #fff;
border-radius: 50vw;
width: 87.5714vw;
margin: 9rem auto auto auto;
padding: 7.145vw 13rem;
}

#footer-contact h2{
margin-bottom: 1rem;
line-height: 1.3;
font-size: 1.1rem;
}
#footer-contact h2 span{
display: block;
font-size: 4.6rem;
}

#footer-contact h3{
font-size: 1.1rem;
}

#footer-contact p{
font-size: 1.6rem;
font-weight: 700;
}

#footer-contact > div{
display: flex;
margin-bottom: 1.5rem;
}

#footer-contact > div div{
display: flex;
flex-direction: column;
margin-right: 3rem;
}



#footer-contact .tel{
font-size:2.4rem;
margin-bottom: 0.5rem;
}

#footer-contact .tel a:link,
#footer-contact .tel a:visited{
color: #fff;
text-decoration-color: transparent;
transition:all 0.3s ease-in-out;
letter-spacing: 0.05em;
}

#footer-contact .tel a:hover{
text-decoration-color: #fff;
}

#footer-contact .reserve{
font-size: 1.6rem;
}

#footer-contact .reserve a{
position: relative;
display: inline-block;
vertical-align: middle;
}

#footer-contact .reserve a:link,
#footer-contact .reserve a:visited{
color: #fff;
}

#footer-contact .reserve a i{
position: absolute;
top: 50%;
right: -4.6rem;
transform: translateY(-50%);
display: inline-block;
background-color: var(--grad-top-blue);
border-radius: 3.6rem;
width: 3.6rem;
height: 3.6rem;
transition: all 0.3s ease-in-out;
}

#footer-contact a i::before,
#footer-contact a i::after{
content: "";
position: absolute;
}

#footer-contact a i::before{
top: calc(50% - 1px);
left: 50%;
transform: translate(-50%);
border-top: 2px solid #fff;
width: 0.8rem;
}

#footer-contact a i::after{
top: 50%;
left:calc(50% - 0.1rem);
transform: rotate(45deg);
transform-origin:top right;
border-top: 2px solid #fff;
border-right: 2px solid #fff;
width: 0.6rem;
height: 0.6rem;
}

#footer-contact a:hover i{
background-color: var(--grad-bottom-blue);
}

@media screen and (max-width:750px) {

#footer-contact{
border-radius:0 50vw 0 30vw;
text-shadow:0.4rem 0.4rem 2rem rgba(0,0,0,0.8);
width: 100vw;
padding:18vw 0 18vw 18vw;
}


}


#footer{
background-color:var(--blue);
color: #fff;
}

#footer .content{
display: flex;
flex-wrap: wrap;
max-width: 97rem;
margin: -19rem auto 0 auto;
padding: 27rem 0 8.5rem 0;
}

#footer .content > div{
width: 31rem;
}

#footer h2{
font-size: 2rem;
}

#footer h2 span{
font-size: 0.7rem;
}

#footer address{
font-size: 1.2rem;
}

#footer .sns{
margin: 1rem 0 0 0;
font-size: 1rem;
}

#footer .sns ul{
display: flex;
font-size: 1rem;
list-style: none;
}

#footer .sitemap{
width:calc(100% - 31rem);
padding-top: 0.5rem;
}

#footer .sitemap ul{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
font-size: 1rem;
list-style: none;
}

#footer .sitemap li{
margin: 0 1rem 1rem 0;
}

#footer .sitemap a{
display: inline-block;
border-radius: 5rem;
padding: 0.4em 1.2em;
text-decoration: none;
transition: all 0.3s ease-in-out;
}

#footer .sitemap a:link,
#footer .sitemap a:visited{
background-color: #fff;
color: #000;
}

#footer .sitemap a:hover{
background-color: var(--grad-bottom-blue);
color: #fff;
text-decoration-color: #fff;
}

#footer .sitemap span{
font-size: 0.7rem;
}


#footer .content .bottom{
width: 100%;
}


#footer .sns{
display: flex;
align-items: center;
}

#footer .sns p{
font-size: 1rem;
}

#footer .sns ul{
font-size: 1.8rem;
}

#footer .sns li{
margin-left: 0.4em;
}

#footer .sns ul a{
position: relative;
display: block;
width: 1.8rem;
height: 1.8rem;
}


#footer .sns ul span{
display: inline-block;
overflow: hidden;
width: 1.8rem;
height: 1.8rem;
line-height: 1.8rem;
visibility: hidden;
}

[class^="icon-"], [class*=" icon-"] {
/* use !important to prevent issues with browser extensions that change fonts */
font-family: 'icomoon' !important;
speak: never;
font-style: normal;
font-weight: normal;
font-variant: normal;
text-transform: none;
line-height: 1;

/* Better Font Rendering =========== */
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}

#footer .sns [class^="icon-"]::before,
#footer .sns [class*=" icon-"]::before{
position: absolute;
top: 0;
left: 0;
display: inline-block;
width: 1.8rem;
height: 1.8rem;
transition: all 0.3s ease-in-out;
}

.icon-f:before {
content: "\66";
color: #fff;
}
.icon-x:before {
content: "\78";
color: #fff;
}
.icon-t:before {
content: "\74";
color: #fff;
}
.icon-l:before {
content: "\6c";
color: #fff;
}
.icon-i:before {
content: "\69";
color: #fff;
}


#footer .sns [class^="icon-"]:hover::before,
#footer .sns [class*=" icon-"]:hover::before{
color: var(--grad-bottom-blue);
}

#footer .bottom{
margin-top: 7.7rem;
}

#footer .copyright{
font-size: 0.8rem;
}


@media screen and (max-width:750px) {

#footer .content{
flex-direction: column;
align-items: center;
width: 92vw;
margin: -30vw auto 0 auto;
padding:42vw 0 12vw 0;
}

#footer .content > div{
width: auto;
}

#footer .sitemap{
width: auto;
margin-top: 1.4rem;
}

#footer .sitemap ul{
width: 78vw;
font-size: 0.8rem;
}

#footer .sitemap li{
margin: 0 0 0.8em 0;
}

#footer .sitemap span{
display: none;
}

}