@charset "utf-8";

*{
font-size: 13px
}

.pc{
display: none!important;
}

div.loadingWrap img {
width: 60%;
}

/*--------------------nav--------------------*/

nav.nav{
width: 100%;
height: 60px;
position: fixed;
top:0px;
left: 0px;
z-index: 11;
display: flex;
align-items: center;
justify-content: space-between;
padding: 0px 3%;
z-index: 12
}

a.nav_logo{
width: 60%
}

div.nav{
width: 100px;
height: 50px;
display: flex;
align-items: center;
justify-content: center;
position: relative
}

p.nav{
font-family: "Inter", sans-serif;
font-weight: 700;
margin-right: 10px
}

.menu-trigger,
a.menu-trigger span {
display: inline-block;
transition: all .4s;
position: relative;
}

a.menu-trigger {
width: 42px;
height: 19px;
}

a.menu-trigger span {
position: absolute;
left: 0;
width: 100%;
height: 1px;
background:#20529a ;
}

a.menu-trigger span:nth-of-type(1) {
top: 0;
}
a.menu-trigger span:nth-of-type(2) {
width: 30px;
top: 8px;
}
a.menu-trigger span:nth-of-type(3) {
bottom: 0;
}

a.menu-trigger.active span:nth-of-type(1) {
-webkit-transform: translateY(8px) rotate(-45deg);
transform: translateY(8px) rotate(-45deg);
}

a.menu-trigger.active span:nth-of-type(2) {
opacity: 0;
}

a.menu-trigger.active span:nth-of-type(3) {
-webkit-transform: translateY(-8px) rotate(45deg);
transform: translateY(-8px) rotate(45deg);
}

.menuIn{
animation-fill-mode:both;
animation-duration:0.5s; 
animation-name: menuIn;
display: block!important;
}
 
@keyframes menuIn {
0% { opacity: 0;}
100% {opacity: 100;}
}

a.nav_logo{
transition: visibility 0.2s, opacity 0.2s;
}

/*--------------------header--------------------*/

header.header{
width: 100%;
background: url(../img/header/back_mobile.jpg) no-repeat center;
background-size: cover;
padding-top: 60px;

}

header.header::before {
content: '';
position: absolute;
width: 80%;
height: 80px;
background: linear-gradient(103deg, rgba(152, 222, 249, 1) 0%, rgba(0, 177, 245, 1) 100%);
clip-path: polygon(0 0, 100% 0, 0 100%);
top: 0;
left: 0;
z-index: 1;
mix-blend-mode:multiply
}

div.header {
width: 100%;
position: relative;
aspect-ratio: 0.554 / 1!important;
padding: 10px;
background: rgba(30,78,144,0.7);
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
grid-auto-rows: auto;
gap: 10px;
align-content: start;
z-index: 1;
}

div.header > a.header_member { will-change: transform, opacity; }

@media (prefers-reduced-motion: reduce){
 div .header > a.header_member { transition:none !important; animation:none !important; }
}

div.headera.header_member{
display: block;
}

a.image1{
z-index: 3!important
}

a.header_member{
aspect-ratio: 1 / 1;
position: relative;
display: block;
overflow: hidden;
border-radius: 5px;
z-index: 0;
}

a.header_member img{
width: 100%;
height: 100%;
object-fit: cover;
object-position: center top;
transition: transform 0.4s ease;
z-index: 0; 
}

a.header_member::before{
content: "";
position: absolute;
top: 0;
left: -75%; 
width: 50%;
height: 100%;
background: linear-gradient(120deg,rgba(255,255,255,0) 0%, rgba(255,255,255,0.6) 50%, rgba(255,255,255,0) 100%);
transform: skewX(-20deg);
z-index: 1;
pointer-events: none;
opacity: 0; 
}

a.header_member:hover img{
transform: scale(1.1);
}

a.header_member:hover::before{
opacity: 1;
animation: shine 1s ease; 
}

@keyframes shine{
from { left: -75%; }
to { left: 125%; }
}

div.header_logo{
grid-column: 1 / -1; 
grid-row: 3; 
text-align: center;
display: flex;
align-items: center;
justify-content: center;
opacity: 0; 
aspect-ratio: 2.285 / 1;
}

article.header_logo{
width: 100%
}

img.header_logo{
width: 50%;
margin: 0px auto
}

img.header_txt{
width:80%;
margin: 0px auto;
}

div.header_right{
width: 100%;
background: #00a0e6;
position: fixed;
left: 0px;
bottom: 0px;
display: flex;
align-items: center;
z-index: 10
}

a.header_right{
width: calc(100% / 3);
display: block;
height: 100%;
color: #fff;
position: relative;
padding: 6px 0px
}

p.header_right_icon{
width: 30px;
height: 30px;
border-radius: 15px;
border:solid 1px #fff;
display: flex;
align-items: center;
justify-content: center;
margin: 0px auto 5px auto;
}

p.mail{
background: #21aaea
}

p.line{
background: #fff
}

img.header_right_icon{
width: 18px;
}

h6.header_right{
font-size: 10px;
white-space: nowrap;
color: #fff
}

a.mail,a.tell,a.line{
text-align: center;
}

a.tell{
background: #006c9f
}

a.line{
background: #00b900
}

span.header_right{
display: none
}

a.header_right_icon{
width: 30px;
height: 30px;
border-radius:15px;
display: flex;
align-items: center;
justify-content: center;
margin: 0px auto 15px auto
}

/*--------------------menu--------------------*/

menu.menu{
width: 100%;
height: 100%;
position: fixed;
background: #efefef;
left:0px;
top:0px;
z-index: 10;
display: none
}

a.menu_logo{
display: none
}

div.menu_link{
width: 80%;
position: absolute;
top:50%;
left: 50%;
transform: translate(-50%,-50%)
}

a.menu{
font-weight: 600;
text-transform: uppercase;
display: block;
white-space: nowrap;
align-items: center;
border-bottom: solid 1px #dcdcdc;
padding: 15px 0px;
background: url(../../img/icon/arrow_kon.png) no-repeat center right;
background-size: 12px;
color: #20529a
}

a.menu:after{
content: '';
width: 1px;
height: 18px;
background: #444;
margin-left: 20px
}

a.menu:last-of-type:after{
background: none;
}

/*--------------------survey--------------------*/

section#survey{
padding: 30px 4%;
background: url(../img/survey/parts1.png) no-repeat left top,url(../img/survey/parts2.png) no-repeat right top,url(../img/survey/parts3.png) no-repeat right bottom,#f2faff;
background-size: 30% auto, 15% auto, 25% auto;
}

div.survey_image{
margin-bottom: 30px
}

div.survey_image img{
margin-bottom: 20px
}

h3.survey_image{
font-size: 12px;
}

article.survey{
width: 100%
}

h6.notera{
font-family: 'Notera';
font-size:50px;
font-weight: 200;
}

h4.section{
font-size: 12px;
font-weight: 600;
margin-bottom: 5px
}

h5.section{
font-size: 22px;
font-family: "Inter", sans-serif;
font-optical-sizing: auto;
font-weight: 700;
font-style: normal;
margin-bottom: 10px
}

h2.section{
font-size: 28px;
white-space: nowrap;
font-weight: 600;
line-height: 1.3;
margin-bottom: 30px
}

p.section{
line-height: 2;
font-size: 14px
}

/*--------------------message--------------------*/

section#message{
padding: 30px 4%;
background: url(../img/message/back_mobile.jpg) no-repeat center;
background-size: cover;
position: relative;
color: #fff;
}

section#message:before{
content: '';
width: 100%;
height: 100%;
background: rgba(0,160,230,0.9);
position: absolute;
top:0px;
left: 0px;
z-index: 0
}

article.message{
width: 100%;
position: relative;
z-index: 1
}

div.message_right{
position: relative;
}

p.message_image{
border-radius: 10px;
overflow: hidden;
margin-top: 30px;
margin-bottom: 30px
}


div.message_txt{
display: flex;
align-items: start
}

p.tel_image{
width:40%;
aspect-ratio: 2 / 2.5;
border-radius: 10px;
overflow: hidden;
position: relative;
top:-40px
}

article.message_txt{
position: relative;
width: 60%;
}

article.message_txt h6.notera{
font-size: 42px;
position: absolute;
line-height: 100%;
text-align: right;
transform: rotate(-5deg);
white-space: nowrap;
top:-80px;
right: 0px
}

h4.message{
font-size:16px;
margin-bottom: 30px
}

p.message_txt{
width: 100%;
padding-left: 15px;
font-size: 10px;
font-family: "Montserrat", sans-serif;
font-weight: 400;
font-style: normal;
line-height: 1.5
}

/*--------------------about--------------------*/

section#about{
position: relative;
padding: 30px 4% 0px 4%
}

h3.about{
font-size: 70px;
margin: 0px auto 30px auto;
position: relative;
font-family: "Inter", sans-serif;
font-optical-sizing: auto;
font-weight: 700;
font-style: normal;
position: relative;
top:-50px
}

i.about{
position: absolute;
font-family: 'Notera';
text-align: right;
color: #00a0e6;
font-size: 22px;
transform: rotate(-10deg) ;
font-weight: 200;
}

div.about{
margin: 0px 0px 0px auto
}

p.about{
line-height: 1.8;
font-size: 14px;
margin-bottom: 30px
}

div.about_link{
width: 80%;
margin: 0px auto;

}

a.about_link{
width: 100%;
background: #20529a;
border-radius: 5px;
height: 50px;
color: #fff;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 20px;
position: relative;
font-weight: 600;
text-align: center;
line-height: 1.2;
}

a.about_link:after{
content: "";
position: absolute;
width: 14px;
height: 14px;
background: url(../img/icon/triangle_w.png)  no-repeat center;
background-size: cover;
top:50%;
transform: translateY(-50%);
right: 10px
}



/*--------------------member--------------------*/

section#member{
padding: 30px 4%
}

div.member{
}

div.member_image{
margin-bottom: 15px;
border-radius: 15px;
overflow: hidden
}

article.member{
padding-top: 40px
}

ul.member{
width: 100%;
margin: 0px auto 30px auto;
display: flex;
align-items: center;
flex-wrap: nowrap;
gap: 10px;
overflow-x: auto;
padding-bottom: 15px
}

li.member{
color: #00a0e6;
flex-shrink: 0;
border:solid 1px #00a0e6;
width: max-content;
height: 40px;
padding: 0px 20px;
border-radius: 20px;
display: flex;
align-items: center;
justify-content: center
}

li.selected{
background: #00a0e6;
color: #fff;
font-weight: 600
}

div.member_post{
display: flex;
align-items: start;
gap: 20px;
overflow-x: auto;
padding-bottom: 20px;
}

a.member_post{
width: 240px;
display: block;
flex-shrink: 0;
aspect-ratio: 2 / 2.5;
border-radius: 15px;
overflow: hidden;
position: relative
}

img.member_post{
width: 100%;
height: 100%;
object-fit: cover;
object-position: top center
}

h4.position{
width: max-content;
height: 26px;
left: 15px;
top:15px;
line-height: 26px;
padding: 0px 20px;
border-radius: 15px;
position: absolute;
background: #fff;
color:#00a0e6
}

article.member_post{
width: max-content;
position: absolute;
left: 15px;
bottom: 15px
}

h3.member_post{
width: max-content;
border-radius: 5px;
font-size: 13px;
padding: 3px 10px;
color: #fff;
background: #00a0e6;
margin-bottom: 10px
}

h4.member_post{
color: #fff;
font-size: 14px
}

h3.member_right{
font-size:14px;
color: #fff;
text-shadow: 1px 1px 2px #999;
line-height: 100%;
transform: skew(-5deg);
font-family: "Inter", sans-serif
}

h4.number{
font-size:25px;
color: #fff;
text-shadow: 1px 1px 2px #999;
margin-bottom: 15px;
transform: skew(-5deg);
font-family: "Inter", sans-serif
}

/*--------------------footer--------------------*/

footer.footer{
background: #00a0e6;
color: #fff;
font-weight: 600;
padding-top: 40px;
}

footer.footer a:hover{
cursor: pointer;
text-decoration: underline
}

a.follow{
width: 160px;
display: block;
position: fixed;
bottom: 20px;
right: 3%;
z-index: 99;
}

a.follow_exception{
bottom: 70px;
}

p.totop{
width: 40px;
height: 50px;
border:solid 2px #dcdcdc;
border-radius: 5px;
background: #fff;
position:absolute;
right: 2%;
top:-68px
}

p.totop img{
width: 50%;
position: absolute;
top:50%;
left: 50%;
transform: translate(-50%,-50%);
opacity: 0.7
}

ul.footer_inner{
width:92%; 
margin: 0px auto 30px auto;
display: block;
position: relative
}

li.footer_left{
display: block
}

li.footer_center{
display: block
}

li.footer_right{
display: block
}

img.footer_logo{
width: 60%;
margin: 0px auto 30px auto
}

div.footer_sns{
display: flex;
align-items: center;
gap: 30px;
justify-content: center;
margin-bottom: 20px;
}

a.footer_sns{
width: 26px
}

p.address{
font-size:12px;
margin-bottom: 20px
}

a.google_map{
display: block;
color: #727272;
text-decoration: underline;
font-weight: 500;
display: flex;
line-height: 2;
}

a.footer_google_map{
color: #fff
}

a.footer_google_map{
color: #fff!important;
margin-top: 10px
}

a.footer_google_map:after{
content: "";
width: 14px;
left: 14px;
background: url(../../img/icon/maps-icon.png) no-repeat center!important;
background-size: 100%!important;
margin-left: 5px
}

div.footer_other{
display: flex;
align-items: center;
gap: 50px;
border-top:solid 1px #fff;
border-bottom:solid 1px #fff;
padding: 15px 0px;
margin-bottom: 30px
}

p.footer_link{
margin-bottom: 10px
}

a.footer_other,a.footer_sub {
color: #fff
}

ul.footer_link{
width: 100%;
margin-bottom: 30px
}

a.footer_link{
display: block;
color: #fff;
margin-bottom: 15px
}

a.footer_right{
width: 80%;
margin: 0px auto 20px auto;
display: block;
background: #fff;
color: #20529a;
font-weight: 600;
padding: 15px 0px;
text-align: center;
border-radius: 5px;
display: flex;
justify-content: center;
align-items: center
}

span.footer_right{
display: block;
margin-right: 10px;
font-weight: 300
}

p.copy{
font-size:10px;
text-align: center;
background: #fff;
color: #000;
padding: 20px 0px 30px 0px;
letter-spacing: 0em
}

p.exception{
padding-bottom: 80px;
}