
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+JP:wght@100;200;300;400;500;600;700&family=Zen+Kaku+Gothic+Antique:wght@300;400;500;700;900&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');


/*!
 * ress.css • v4.0.0
 * MIT License
 * github.com/filipelinhares/ress
 */html{box-sizing:border-box;-webkit-text-size-adjust:100%;word-break:normal;-moz-tab-size:4;tab-size:4}*,:after,:before{background-repeat:no-repeat;box-sizing:inherit}:after,:before{text-decoration:inherit;vertical-align:inherit}*{padding:0;margin:0}hr{overflow:visible;height:0;color:inherit}details,main{display:block}summary{display:list-item}small{font-size:80%}[hidden]{display:none}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}a{background-color:transparent}a:active,a:hover{outline-width:0}code,kbd,pre,samp{font-family:monospace,monospace, serif}pre{font-size:1em}b,strong{font-weight:bolder}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-color:inherit;text-indent:0}input{border-radius:0}[disabled]{cursor:default}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}textarea{overflow:auto;resize:vertical}button,input,optgroup,select,textarea{font:inherit}optgroup{font-weight:700}button{overflow:visible}button,select{text-transform:none}[role=button],[type=button],[type=reset],[type=submit],button{cursor:pointer;color:inherit}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button:-moz-focusring{outline:1px dotted ButtonText}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}button,input,select,textarea{background-color:transparent;border-style:none}a:focus,button:focus,input:focus,select:focus,textarea:focus{outline-width:0}select{-moz-appearance:none;-webkit-appearance:none}select::-ms-expand{display:none}select::-ms-value{color:currentColor}legend{border:0;color:inherit;display:table;white-space:normal;max-width:100%}::-webkit-file-upload-button{-webkit-appearance:button;color:inherit;font:inherit}img{border-style:none}progress{vertical-align:baseline}[aria-busy=true]{cursor:progress}[aria-controls]{cursor:pointer}[aria-disabled=true]{cursor:default}

 /*reset*/



*{
    box-sizing: border-box;
    line-height: 1;
    word-break: break-all;
}

img{
    max-width: 100%;
}

a{
    text-decoration: none;
}

html{
font-family: "Zen Kaku Gothic Antique", serif;
font-weight: 400;
font-style: normal;
background-color:#0E151D;
color:#FFFFFF;
font-size: 10px;
}

.fontIBM{
     font-family: "IBM Plex Sans JP", sans-serif;
}

.fontHelvetica {
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}



.fontMontserrat {
    font-family: "Montserrat", sans-serif;
}

.wrap{
overflow: hidden;
}


.header .headerInner{
    position: fixed;
    z-index: 1;
    padding-top: 77px;
    padding-bottom: 0;
    padding-left: 83px;
    padding-right: 83px;
    display: flex;
    width: 100%;
    justify-content: space-between;
}

.header .headerInner .langChange{
    display: flex;
    gap: 10px;
}


.header .headerInner .langChange a{
    color: #FFFFFF;
    font-size: 2.4rem;
    text-decoration: none;
    position: relative;
}

.header .headerInner .langChange a:nth-of-type(1):after{
    content:'/';
    margin-left: 5px;
}


.header .headerInner .langChange a.select{
    font-weight: bold;
    pointer-events: none;
}

.header .headerInner #globalMenu{
    display: flex;
    gap: 74px;
    list-style: none;
}
.header .headerInner #globalMenu li{
    list-style: none;
}

.header .headerInner #globalMenu li a{
    color: #FFFFFF;
    font-size: 2.4rem;
    text-decoration: none;
}

.bg{
    position: fixed;
    z-index: -1;
    background-image: url(../img/mainimage.webp);
    background-size: cover;
    background-repeat: no-repeat;
    width: 100%;
    height: 100%;
    background-position: left center;
}

.mainImage {
    padding-bottom: 65.41%;
    position: relative;
}
.mainImage h1{
    position: absolute;
    z-index: 1;
    right: 83px;
    top:50%;
    transform: translateY(-50%);
}
.mainImage h1 span{
    display: block;
    text-align: right;
}

.mainImage h1 span.name{
    font-size: 9.6rem;
    display: block;
    color:rgba(255,255,255,0.5);

}

.mainImage  h1 span.ja{
    font-size: 4.0rem;
    display: block;
    color:rgba(255,255,255,1);
    margin-top: 8px;
        letter-spacing: 0.27em;
}


.inner{
    padding: 0 80px;
    max-width: 1360px;
    margin: auto;
}

.message{
    background-image: url('../img/message_bg.webp');
    background-size: cover;
    background-repeat:no-repeat;
    background-position:center bottom;
    text-align: center;
}

.message .gradient{
    padding: 90px 0;
    background: #000000;
    background: linear-gradient(180deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 20%, rgba(0, 0, 0, 0) 100%);
}

.message h2{
    font-weight: normal;
    font-size: 3.2rem;
    margin-bottom: 60px;
    line-height: 1.5;
}

.message p{
    font-size: 2.0rem;
    line-height: 2.4;
}


.message ul.snsLink{
    margin-top: 312px;
    display: flex;
    gap: 110px;
    list-style: none;
    justify-content: center;
}

.message ul.snsLink img{
    width: auto;
    height: 35px;
}

.news{
background-color:#0E151D;
padding: 60px 0;
}


.news h2{
    color:rgba(255,255,255,0.5);
    font-size: 3.2rem;
    text-align: center;
    margin-bottom: 50px;
}


.news ul{
    display: flex;
    gap: 95px;
    list-style: none;
    justify-content: center;
}



.news ul li{
    width: 316px;
}


.news ul li .img{
    position: relative;
    width: 100%;
    padding-bottom: 82.5396%;
    overflow: hidden;
}

.news ul li .img img{
    position: absolute;
    left: 50%;
    top:50%;
    width: 100%;
    height: auto;
    transform: translate(-50%,-50%);
    transition: 0.3s;
    transform-origin: center center;
}

.news ul li a.noLink{
    pointer-events: none;
}

.news ul li a.Link:hover .img img{
    transform:translate(-50%,-50%) scale(1.1)  ;
}


.news ul li p.pubdate{
    font-weight: 600;
    color: #FFFFFF;
    font-size:1.8rem;
    margin-top: 24px;
    margin-bottom: 12px;
    line-height: 1.3;
    font-style: italic;
}

.news ul li p.title{
    font-weight: bold;
    font-size: 1.8rem;
    line-height: 1.25;
    color: #FFFFFF;
}


.about{
        background-image:url('../img/about_bg.webp');
    background-size: cover;
    background-repeat: no-repeat;
    background-position:center bottom;
    text-align: center;
}


.about .gradient{
    padding: 90px 0;
    background: #000000;
background: linear-gradient(180deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 20%, rgba(0, 0, 0, 0) 100%);
}



.about h2{
color: rgba(255, 255, 255, 0.5);
    font-size: 3.2rem;
    text-align: center;
    margin-bottom: 50px;
}

.about p.catch{
    font-size: 3.2rem;
    margin-bottom: 60px;
}

.about p{
    font-size: 2.0rem;
    line-height: 2.4;
}

.about ul{
margin: 85px auto 0;
    display: flex;
    max-width: 1170px;
    gap: 70px;
    list-style: none;
    position: relative;
    flex-wrap: wrap;
    justify-content: center;
}

.about ul li{
    width: 480px;
}

.about ul.others li{
    width: calc((100% - 140px) / 3);
}


.about ul.others{
    display: none;
}


.about ul li p{
    margin-top: 15px;
    font-size: 2.0rem;
    line-height: 1.6;
    position: relative;
    text-align: center;
}
.about ul li p:before{
    content:"・";
}



.about a.aboutBtn {
    color: #30363C;
    background-color: #FFFFFF;
    width: fit-content;
    margin: 64px auto 0;
    padding: 14px 74px;
    display: block;
    font-weight: bold;
    border-radius: 20px;
    background-image: url(../img/Btn_arrowDown.svg);
    background-repeat: no-repeat;
    background-size: 7px;
    background-position: left 80% center;
}


.career{
        background-color: #10151B;
    padding: 90px 0 100px;
}

.career h2 {
    color: rgba(255,255,255,0.5);
    font-size: 3.2rem;
    margin-bottom: 50px;
    text-align: center;
}

.career #careerList{
    position: relative;
}

.career #careerList .header{
    border-bottom: 1px solid rgba(255,255,255,0.5);
    color: #fff;
    display: flex;
    font-size: 1.6rem;
    padding-bottom: 16px;
    position: relative;
    width: 100%;
}

.career #careerList .header .term{
    width: 160px;
    padding-left: 36px;
    margin-right: 30px;
}
.career #careerList .header .img{
    width: 100px;
    margin-right: 30px;
}
.career #careerList .header .company{
    width: 250px;
    margin-right: 30px;
}
.career #careerList .header .position{
    width: 240px;
    margin-right: 30px;
}
.career #careerList .header .detail{
    width: calc(100% - 870px);
}


.career #careerList ul.careerBlock{
    display: flex;
    padding: 56px 0;
    position: relative;
    border-bottom: 1px solid rgba(255,255,255,0.5);
    list-style: none;
}

.career #careerList ul.careerBlock.hide{
    display: none;
}

.career #careerList ul.careerBlock li.term{
    width: 160px;
    padding-left: 36px;
    margin-right: 30px;
    font-size: 2.0rem;
    font-weight: bold;    
}

.career #careerList ul.careerBlock li.block{
    width: calc(100% - 190px);
    position: relative;
}
.career #careerList ul.careerBlock li.block .blockInner{
    display: flex;
    list-style: none;
    padding-bottom: 50px;
    margin-bottom: 50px;
    border-bottom: 1px solid rgba(255,255,255,0.5);
}

.career #careerList ul.careerBlock li.block .blockInner:nth-last-of-type(1){
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: none;
}

.career #careerList ul.careerBlock li.block .blockInner .img{
    width: 100px;
    margin-right: 30px;
    position: relative;
}
.career #careerList ul.careerBlock li.block .blockInner .img img{
    width: 100%;
}

.career #careerList ul.careerBlock li.block .blockInner .company{
    width: 250px;
    margin-right: 30px;
    font-size: 1.6rem;
}
.career #careerList ul.careerBlock li.block .blockInner .position{
    width: 240px;
    margin-right: 30px;
    font-size: 1.6rem;
}
.career #careerList ul.careerBlock li.block .blockInner .detail{
    width:calc(100% - 680px);
    font-size: 1.4rem;    
    line-height: 1.5;
}

.career #careerList a.viewMore,
.career a.viewMore{
    display: block;
    background-color: #D9D9D9;
    border-radius: 0 0 20px 20px;
    height: 32px;
    width: 237px;
    margin: auto;
    background-image: url('../img/ViewMoreArrow.svg');
    background-size: 19px 19px;
    background-repeat: no-repeat;
    background-position: center center;
}



.project{
    background: #000000;
    background-image:url('../img/project_bg.webp');
    background-size:  cover;
    background-repeat:no-repeat;
    background-position:center bottom;
    text-align: center;
}
.project .gradient{
    padding: 115px 0 300px;
    background: #000000;
background: linear-gradient(180deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 50%, rgba(0, 0, 0, 0) 100%);
}


.project h2{
    color: rgba(255,255,255,0.5);
    font-size: 3.2rem;
    margin-bottom: 175px;
    text-align: center;
}



.project .custom-scrollbar {
  position: relative;
  height: 4px;
  background: #838486;
  margin: 20px auto;
  width: 100%;
  border-radius: 2px;
}

.project .custom-scrollbar:before{
background: #838486;
    content: "";
    display: block;
    height: 15px;
    left: -13px;
    position: absolute;
    top: 50%;
    width: 15px;
    transform: rotate(45deg) translateY(-50%);
    transform-origin: top;
}

.project .custom-scrollbar:after{
background: #838486;
    content: "";
    display: block;
    height: 15px;
    right: -13px;
    position: absolute;
    top: 50%;
    width: 15px;
    transform: rotate(45deg) translateY(-50%);
    transform-origin: top;
}


.project .custom-scrollbar:before{
    content:"";
    display: block;
}


.project .custom-scrollbar .handle {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 30px;
  height: 30px;
  background: #D9D9D9;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 2px rgba(0,0,0,0.5);
    z-index: 1;
}


.project #projectContainer {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE, Edge Legacy */
    padding: 20px;
    margin-top: 100px;
}
.project #projectContainer::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Opera */
}

.project #projectContainer #projectContent {
      display: flex;
      transition: transform 0.3s ease;
      gap: 50px;
}
.project #projectContainer #projectContent .item {
    flex: 0 0 auto;
    width: 550px;
    display: flex;
    flex-direction: column;
    position: relative;
    background-color: #D9D9D9;
}

.project #projectContainer #projectContent .item .thumb{
width: 100%;
padding-bottom: 72%;
background-size: cover;
}
.project #projectContainer #projectContent .item .detail{
    padding: 32px;
}

.project #projectContainer #projectContent .item .detail h3{
    font-size: 2.3rem;
    line-height: 1.4;
    text-align: left;
    color: #282938;
    margin-bottom: 10px;
    white-space: normal;
}

.project #projectContainer #projectContent .item .detail .text,
.project #projectContainer #projectContent .item .detail .text p{
    font-size: 1.6rem;
    line-height: 1.5;
    text-align: left;
    color: #1C1E53;
    white-space: normal;

}
.project #projectContainer #projectContent .item .detail .text p{
    margin-bottom: 1em;
}








.media-speak{
        background-color: #10151B;
    padding: 75px 0 80px;
}
.media-speak h2{
color: rgba(255, 255, 255, 0.5);
    font-size: 3.2rem;
    margin-bottom: 32px;
    text-align: center;
}

.media-speak h3{
color: rgba(255, 255, 255, 0.5);
    font-size: 3.2rem;
    margin-bottom: 70px;
    text-align: center;
}

.media-speak .books{
    position: relative;
    padding-bottom: 100px;
}

.media-speak .books ul{
    display: flex;
    gap: 150px;
    position: relative;
    flex-wrap: wrap;
    list-style: none;
    padding-bottom: 100px;
}
.media-speak .books ul.more{
    border-bottom: 1px solid #fff;
}


.media-speak .books ul li{
    width: calc(( 100% - 300px ) / 3);
    position: relative;
}
.media-speak .books ul li.hide{
    display: none;
}


.media-speak .books ul li .thumb{
    position: relative;
    background-size: auto 100%;
    background-repeat: no-repeat;
    padding-bottom: 142.176%;
    background-position: center center;
    margin-bottom: 28px;
}

.media-speak .books ul li .detail h4{
    color: #FFFFFF;
    font-size: 2.4rem;
    line-height: 1.1; 
    margin-bottom: 24px;  
}

.media-speak .books ul li .detail .text{
    color:#FFFFFF;
    font-size: 2.0rem;
    line-height: 1.1;
}

.media-speak .books ul li .detail a{
    color: #FFFFFF;
    font-size: 1.2rem;
    display: inline-block;
    width: fit-content;
    border-radius: 20px;
    padding: 8px 15px;
    margin-top: 20px;
    border: solid 1px #FFFFFF;
    font-weight: bold;
    text-decoration: none;
}

.media-speak .books ul li .detail a:hover{
    background-color: #FFFFFF;
    color: #000000;
}


.media-speak .books a.viewMore{
    display: block;
    background-color: #D9D9D9;
    border-radius: 0 0 20px 20px;
    height: 32px;
    width: 237px;
    margin: auto;
    background-image: url('../img/ViewMoreArrow.svg');
    background-size: 19px 19px;
    background-repeat: no-repeat;
    background-position: center center;
}



.media-speak .speaking{
    position: relative;
    padding-top: 77px;
    padding-bottom: 72px;
    background: #000000;
    background: linear-gradient(180deg, rgba(0, 0, 0, 1) 0%, rgba(14, 21, 29, 1) 50%, rgba(14, 21, 29, 1) 100%);
}

.media-speak .speaking .speakingTermList{
    display: flex;
    gap: 50px;
    margin-top: 103px;
    margin-bottom: 103px;
    list-style: none;
    flex-wrap: wrap;
    justify-content: center;

}

.media-speak .speaking .speakingTermList li{
    position: relative;
    width: fit-content;
    
}

.media-speak .speaking .speakingTermList li a{
    display: block;
    color: #8C8B8B;
    font-size: 3.0rem;
    padding: 20px 20px;
    font-weight: bold;
}

.media-speak .speaking .speakingTermList li.select a{
    color: #FFFFFF;
    border-bottom:solid 1px #FFFFFF;
    pointer-events: none;
}

.media-speak .speaking .speakingList{
    display: none;
}

.media-speak .speaking .speakingList.select{
display: block;
}

.media-speak .speaking .speakingList.select ul{
    display: flex;
    gap: 67px;
    position: relative;
    flex-wrap: wrap;
    list-style: none;
    padding-bottom: 67px;
    border-bottom: solid 1px #FFFFFF;
}

.media-speak .speaking .speakingList.select ul li{
width: calc((100% - 134px) / 3);
    position: relative;
}
.media-speak .speaking .speakingList.select ul li.hide{
    display: none;
}

.media-speak .speaking .speakingList.select ul li .thumb{
    position: relative;
    background-size: auto 100%;
    background-repeat: no-repeat;
    padding-bottom: 82.53968%;
    background-position: center center;
    margin-bottom: 28px;
}

.media-speak .speaking .speakingList.select ul li p.date{
    font-weight: 600;
    color: #FFFFFF;
    font-size: 1.8rem;
    margin-top: 24px;
    margin-bottom: 12px;
    line-height: 1.3;
    font-style: italic;
}

.media-speak .speaking .speakingList.select ul li h4{
        font-weight: bold;
    font-size: 2.4rem;
    line-height: 1.25;
    color: #D9d9d9;
    margin-bottom: 24px;
}

.media-speak .speaking .speakingList.select ul li .text{
    font-size:2.0rem;
    line-height:1.5;
    color: #D9D9D9;
}

.media-speak .speaking .speakingList.select ul li .speakingLink{
    margin-top: 20px;
    font-size: 2.0rem;
}

.media-speak .speaking .speakingList.select ul li .speakingLink a{
    color: #D9d9d9;
    font-size: 2.0rem;
}

.media-speak .speaking .speakingList.select ul li .category{
    color: #FFFFFF;
    font-size: 1.0rem;
    display: inline-block;
    width: fit-content;
    border-radius: 20px;
    padding: 8px 15px;
    margin-top: 20px;
    border: solid 1px #FFFFFF;
    font-weight: bold;
}
.media-speak .speaking .speakingList.select ul li .category+.category{
    margin-left: 20px;
}


.media-speak .speaking .speakingList a.viewMore{
    display: block;
    background-color: #D9D9D9;
    border-radius: 0 0 20px 20px;
    height: 32px;
    width: 237px;
    margin: auto;
    background-image: url('../img/ViewMoreArrow.svg');
    background-size: 19px 19px;
    background-repeat: no-repeat;
    background-position: center center;
}

.media-speak .speaking .speakingMessage{
    text-align: center;
    color: #FFFFFF;
    font-size: 2.0rem;
    line-height: 1.5;
    margin-top: 168px;
}


.media-speak .media{
    position: relative;
    padding-top: 104px;
    padding-bottom: 108px;
    background: #000000;
    background: linear-gradient(180deg, rgba(0, 0, 0, 1) 0%, rgba(14, 21, 29, 1) 50%, rgba(14, 21, 29, 1) 100%);
}

.media-speak .media ul{
    display: flex;
    flex-direction: column;
    width: 100%;
}

.media-speak .media ul li{
    display: flex;
    width: 100%;
    gap: 30px;
    padding: 30px 0;
    border-bottom: solid 1px rgba(255,255,255,0.5);
}

.media-speak .media ul li.hide{
    display: none;
}

.media-speak .media ul li .thumbWrap{
    width: 200px;
    position: relative;
}
.media-speak .media ul li .thumbWrap .thumb{
    width: 100%;
    padding-bottom: 82.5%;
    background-size: 100% auto;
    background-position: center center;
}

.media-speak .media ul li .text{
    width: calc(100% - 230px);
    display: flex;
    flex-direction: column;
    gap: 17px;
}
.media-speak .media ul li .text .date-tag{
position: relative;
    display: flex;
    align-items: center;
    gap:45px;
}
.media-speak .media ul li .text .date-tag .pubdate{
        font-weight: 600;
    color: #FFFFFF;
    font-size: 1.8rem;
    line-height: 1.3;
    font-style: italic;
}
.media-speak .media ul li .text .date-tag .category{
    color: #FFFFFF;
    font-size: 1.0rem;
    display: block;
    width: fit-content;
    border-radius: 20px;
    padding: 8px 15px;
    border: solid 1px #FFFFFF;
    font-weight: bold;
}

.media-speak .media ul li .text h4{
    font-weight: bold;
    font-size: 2.4rem;
    line-height: 1.25;
    color: #D9D9D9;
}

.media-speak .media ul li .text .detail{
    font-size: 2.0rem;
    line-height: 1.5;
    color: #D9D9D9;
}

.media-speak .media ul li .text .link{
        font-size: 2.0rem;
    line-height: 1.5;
    color: #D9D9D9;
}
.media-speak .media ul li .text .link a{
    color: #D9D9D9;
}

.media-speak .media a.viewMore{
    display: block;
    background-color: #D9D9D9;
    border-radius: 0 0 20px 20px;
    height: 32px;
    width: 237px;
    margin: auto;
    background-image: url('../img/ViewMoreArrow.svg');
    background-size: 19px 19px;
    background-repeat: no-repeat;
    background-position: center center;
}


.blog{
        background-image:url('../img/blog_bg.webp');
    background-size: cover;
    background-repeat: no-repeat;
    background-position:center bottom;
    text-align: center;
    padding: 83px  0 100px;
    background-color: #10151B;
}


.blog h2{
    font-size: 3.2rem;
    margin-bottom: 113px;
    color: rgba(255, 255, 255, 0.5);    
}

.blog p{
    color: #FFFFFF;
    font-size: 2.0rem;
    line-height: 2.6;
}

.blog p.catch{
    font-size: 3.2rem;
    line-height: 1.3;
    margin-bottom: 32px;    
}


.blog  a.blogBtn{
    color: #30363C;
    background-color: #FFFFFF;
    width: fit-content;
    margin:64px auto 0;
    padding: 14px 60px;
    display: block;
    font-weight: bold;
    border-radius: 20px;
    background-image: url('../img/Btn_arrow.svg');
    background-repeat: no-repeat;
    background-size: 7px;
    background-position: left 80% center;
}

.contact{
    background-color: #10151B;
    padding: 90px 0;
}

.contact h2{
    font-size: 3.2rem;
    margin-bottom: 113px;
    color: rgba(255, 255, 255, 0.5);
    text-align: center;
}
.contact .contactMessage{
    text-align: center;
    margin-bottom: 60px;
}

.contact .contactMessage p{
    color: #FFFFFF;
    font-size: 2.0rem;
    line-height:1.9;
}

.contact  .contactMessage p.catch{
    font-size: 3.2rem;
    line-height: 1.3;
    margin-bottom: 32px;    
}

.contact .formWrap{
    position: relative;
}

.contact .formWrap .block{
    position: relative;
    margin-bottom: 42px;
}

.contact .formWrap .block p.title{
    font-size: 2.0rem;
    line-height: 1.4;
    color: #FFFFFF;
}

.contact .formWrap .block .input{
    margin-top: 12px;
    position: relative;
}

.contact .formWrap .block .input input,
.contact .formWrap .block .input select,
.contact .formWrap .block .input textarea{
    padding: 12px 25px;
    font-size: 2.0rem;
    line-height: 1.4;
    background-color: #2C4664;
    width: 100%;
    color: #FFFFFF;
    position: relative;
    appearance: none;
    -webkit-appearance: none;
}


.contact .formWrap .block .input input::-webkit-date-and-time-value{
    text-align: left;
}

.contact .formWrap .block .input .wpcf7-not-valid-tip,
.contact .wpcf7-response-output{
background-color: rgba(255, 255, 255, 0.9);
    padding: 30px !important;
    color: #FF0000;
    font-size: 14px !important;
    margin-top: 10px !important;
    border: none !important;
    display: none;
}
.contact form[data-status="invalid"]  .formWrap .block .input .wpcf7-not-valid-tip,
.contact form[data-status="invalid"]  .wpcf7-response-output{
    display: block;
}

.contact .screen-reader-response,
.contact .screen-reader-response p[role="status"]{
    display: none!important;
}

.contact .screen-reader-response{
    height: 0!important;
    width: 0!important;
}



/* Chrome, Safari */
.contact .formWrap .block .input input[type="date"]::-webkit-calendar-picker-indicator {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top:0;
    opacity: 0;
/*    display: none;
  -webkit-appearance: none;

  background-color: rgba(255,255,255,0.6);*/
}

.contact .formWrap .block .dateWrap{
    display: flex;
    gap: 96px;
    position: relative;
}
.contact .formWrap .block .dateWrap>.input{
    width: calc((100% - 96px) / 2);
}


.contact .formWrap .block .privacycatch{
    margin-top: 30px;
    font-size: 2.0rem;
}

.contact .formWrap .block .privacyBox{
 margin: 30px 0;
 padding: 30px 0;
 border-top:solid 1px #FFFFFF ;   
 border-bottom:solid 1px #FFFFFF ;   
}

.contact .formWrap .block .privacyBox p{
    font-size: 1.4rem;
    line-height: 1.4;
}

.contact .formWrap input[type="submit"]{
      -webkit-appearance: none;
      display: block;
          color: #30363C;
    background-color: #FFFFFF;
    width: fit-content;
    margin: 64px auto 0;
    padding: 8px 120px;
    display: block;
    border-radius: 20px;
    background-image: url(../img/Btn_arrow.svg);
    background-repeat: no-repeat;
    background-size: 7px;
    background-position: left 80% center;
    font-size: 2.0rem;
}


.footer{
    background-color: #15212B;
    padding: 50px 70px  40px;
}

.footer .footerList{
    display: flex;
    gap:100px;
}

.footer .footerList .siteName{

}



.footer .footerList .siteName span.name{
    font-size: 3.6rem;
    display: block;
    color: rgba(255, 255, 255, 0.5);
    font-weight: bold;
}

.footer .footerList .siteName span.ja{
    font-size: 2.4rem;
    display: block;
    color: rgba(255, 255, 255, 1);
    margin-top: 8px;
    font-weight: bold;
    letter-spacing: 0.27em;
}

.footer .footerList .menuWrap ul#footerMenu{
    list-style: none;
    display: flex;
    gap: 50px;
}

.footer .footerList .menuWrap ul#footerMenu li a{
color: #FFFFFF;
font-size: 2.4rem;
line-height: normal;
text-decoration: none;
}

.footer ul.snsLink{
    margin-top: 230px;
    display: flex;
    gap: 110px;
    list-style: none;
    justify-content: center;
}

.footer ul.snsLink img{
    width: auto;
    height: 35px;
}

.footer p.copy{
    text-align: center;
    font-size: 1.6rem;
    margin-top: 52px;
}

.footer .pagetop {
  position: fixed;
  right: 20px;
  bottom: 30px;
  width: 50px;
  height: 50px;
  background-color: #333;
  border-radius: 50%;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  cursor: pointer;
  transition: opacity 0.3s, transform 0.3s;
  opacity: 0;
  visibility: hidden;
}

.footer .pagetop.show{
    opacity: 1;
    visibility: visible;
}

.footer .pagetop::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-top: 2px solid white;
  border-right: 2px solid white;
  transform: rotate(-45deg);
}




.forSp{
	display: none;
}

.forPc{
	display: block;
}

@media screen and (min-width: 821px){
    .header .headerInner,
    .header.scroll .headerInner #globalMenu li a,
    .header.scroll .headerInner .langChange a{
        transition: all 0.3s ease;
    }
    .header.scroll .headerInner{
    background-color:rgba(14,21,29,0.9);
    padding-top: 30px;
    padding-bottom: 30px;
    }
    .header.scroll .headerInner #globalMenu li a,
    .header.scroll .headerInner .langChange a{
        font-size: 1.6rem;
    }
}

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


.inner{
    padding:0 35px;
}


.menuSupport{
    position: fixed;
    z-index: 9999;
    width: 35px;
    height: 22px;    
    right: 35px;
    top:35px;
}

.menuSupport a.menuToggle{
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
}


.menuSupport a.menuToggle span{
    position: absolute;
    left: 0;
    width: 100%;
    background-color: #FFFFFF;
    height: 3px;
    display: block;
    transition: 0.3s;
}
.menuSupport a.menuToggle span:nth-of-type(1){
    top:0;
}
.menuSupport a.menuToggle span:nth-of-type(2){
    top:50%;
    transform: translateY(-50%);
}
.menuSupport a.menuToggle span:nth-of-type(3){
    bottom:0;
}


.menuSupport a.menuToggle.open span:nth-of-type(1){
    top:50%;
    transform:rotate(45deg) translateY(-50%);
}
.menuSupport a.menuToggle.open span:nth-of-type(2){
    display: none;
}
.menuSupport a.menuToggle.open span:nth-of-type(3){
    bottom:auto;
    top:50%;
    transform:rotate(-45deg) translateY(-50%);
}

.header .headerInner{
    opacity: 0;
    visibility: hidden;
        background-color: #0e151e;
        position: fixed;
        z-index: 8888;
        overflow-y: auto;
        padding: 35px;
        flex-direction: column;
        transition:0.3s;
        gap:50px;
    justify-content: flex-start;
}

.header.show .headerInner{
    opacity: 1;
    visibility: visible;
    height: 100vh;
}


.header .headerInner .siteName span.name {
    color: rgba(255,255,255, .5);
    display: block;
    font-size: 2.6rem;
    font-weight: 700;
}

.header .headerInner .siteName span.ja {
    color: #fff;
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.27em;
}

.header .headerInner #globalMenu{
        flex-direction: column;
        gap: 0px;
}

.header .headerInner #globalMenu li{
        padding-bottom: 20px;
        margin-top: 28px;
        border-bottom: solid 1px #FFFFFF;
}
.header .headerInner #globalMenu li:nth-last-of-type(1){
    border-bottom: none;
}

.header .headerInner #globalMenu li a{
        background-image: url(../img/sp_navArrow.svg);
        display: block;
        background-size: 10px auto;
        background-position: center right 12px;
}

.header .headerInner ul.snsLink{
        display: flex;
        list-style: none;
        justify-content: space-between;
        flex-wrap: wrap;
}

.header .headerInner ul.snsLink img{
    width: auto;
    height: 20px;
}

.footer{
    padding: 44px 35px 54px;
}

.footer .footerList{
    flex-direction: column;
    gap: 20px;
}
.footer .footerList .siteName span.ja{
    margin-top: 15px;
}

.footer .footerList .menuWrap ul#footerMenu{
    gap: 20px;
    flex-direction: column;
}

.footer .footerList .menuWrap ul#footerMenu li a{
    font-size: 1.4rem;
}

.footer ul.snsLink{
    margin-top: 100px;
    gap: 50px;
}

.footer ul.snsLink img{
    height: 20px;
}
.footer p.copy{
    font-size: 1.2rem;
    margin-top: 30px;
}

.bg {
    background-image: url(../img/mainimage_sp.webp?);
}



.mainImage{
    padding-bottom: 216%;
}
.mainImage h1{
        right: 35px;
        transform: translateY(0%);
        top: 208px;
}

.mainImage h1 span.name{
    font-size: 5.2rem;
}
.mainImage h1 span.ja{
    font-size: 3.0rem;
}

.message{
    background-image: url(../img/message_bg.webp);
    background-size: 195% auto;
    background-repeat: no-repeat;
    background-position: center bottom;
    text-align: center;
    background-color: #000000;
}

.message .gradient{
    padding: 72px 0 42px;
}

.message h2{
    font-size: 2.0rem;
    margin-bottom: 30px;
}
.message p{
    font-size: 1.2rem;
    line-height: 2.4;
}

.message ul.snsLink{
    margin-top: 120px;
    gap: 0;
    justify-content: space-between;
}
.message ul.snsLink img{
    height: 23px;
}


.news{
    padding: 50px 0;
}

.news h2{
    font-size: 2.4rem;
    margin-bottom: 50px;
}

.news .newsSlideWrapper{
        overflow-x: auto;
        width: 100vw;
        margin-left: -35px;
        padding-left: 35px;
}

.news .newsSlideWrapper::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Opera */
}

.news ul{
        display: flex;
    gap: 20px;
    list-style: none;
    justify-content: flex-start;
    flex-direction: row;
}

.news ul li {
    width: 316px;
    flex: 0 0 auto;
}

.news ul li p.title{
            font-size: 1.5rem;
}

.about .gradient{
    padding: 50px 0;
}

.about h2{
    font-size: 2.4rem;
    margin-bottom: 40px;
}

.about p{
    font-size: 1.2rem;
    line-height: 2.4;
}

.about p.catch{
    font-size: 2.0rem;
    line-height: 1.5;
    margin-bottom: 30px;
}

.about ul{
    flex-direction: column;
}
.about ul li,
.about ul.others li{
    width: calc(100% - 25px);
    margin: auto;
}


.about ul li p{
    font-size: 1.6rem;
    line-height: 1.2;
}






.career{
    padding: 50px 0;
}

.career h2 {
    font-size: 2.4rem;
    margin-bottom: 50px;
    text-align: center;
}



.career .custom-scrollbar {
  position: relative;
  height: 1px;
  background: #838486;
  margin: 20px auto 70px;
  width: calc(100% - 70px);
  border-radius: 2px;
  
}

.career .custom-scrollbar:before{
background: #838486;
    content: "";
    display: block;
    height: 4px;
    left: -3px;
    position: absolute;
    top: 50%;
    width: 4px;
    transform: rotate(45deg) translateY(-50%);
    transform-origin: top;
}

.career .custom-scrollbar:after{
background: #838486;
    content: "";
    display: block;
    height: 4px;
    right: -3px;
    position: absolute;
    top: 50%;
    width: 4px;
    transform: rotate(45deg) translateY(-50%);
    transform-origin: top;
}


.career .custom-scrollbar:before{
    content:"";
    display: block;
}


.career .custom-scrollbar .handle {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 15px;
  height: 15px;
  background: #D9D9D9;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 2px rgba(0,0,0,0.5);
    z-index: 1;
}


.career #careerList{
        overflow-x: scroll;
        width: calc(100% + 70px);
        margin-left: -35px;
}

.career #careerList .header{
    width: fit-content;
}

.career #careerList .header > *{
        flex: 0 0 auto;
}
.career #careerList .header .detail,
.career #careerList ul.careerBlock li.block .blockInner .detail{
    width: 350px;
    padding-right: 35px;
}

.career #careerList ul.careerBlock,
.career #careerList ul.careerBlock li.block .blockInner{
    width: fit-content;
}


.career #careerList ul.careerBlock > *,
.career #careerList ul.careerBlock li.block .blockInner > *{
        flex: 0 0 auto;
}

.career #careerList::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Opera */
}

.project .gradient{
    padding:50px 0;
}

.project h2 {
    font-size: 2.4rem;
    margin-bottom: 50px;
    text-align: center;
}

.project .custom-scrollbar{
        height: 1px;
        margin: 20px auto 40px;
        width: calc(100% - 70px);
}


.project .custom-scrollbar:before{
background: #838486;
    height: 4px;
    left: -3px;
    width: 4px;
}

.project .custom-scrollbar:after{
    height: 4px;
    right: -3px;
    width: 4px;
}

.project .custom-scrollbar .handle{
    width: 15px;
    height: 15px;
}

.project #projectContainer #projectContent{
    gap: 25px;
}
.project #projectContainer #projectContent .item{
    width: 276px;
}
.project #projectContainer #projectContent .item .detail{
    padding: 15px;
}
.project #projectContainer #projectContent .item .detail h3{
    font-size: 1.8rem;
}
.project #projectContainer #projectContent .item .detail .text,
.project #projectContainer #projectContent .item .detail .text p{
    font-size: 1.2rem;
}
.project #projectContainer{
    margin-top: 0;
    padding-top: 0;
}

.media-speak{
    padding: 40px 0 40px;
}
.media-speak .books{
    padding-bottom: 40px;
}

.media-speak h2{
    font-size: 2.4rem;
    margin-bottom: 24px;
    text-align: center;
}
.media-speak h3{
    font-size: 2.4rem;
    margin-bottom: 40px;
}

.media-speak .books ul{
    gap: 35px;
    padding-bottom: 40px;
}

.media-speak .books ul li {
    width: calc((100% - 35px) / 2);
    position: relative;
}
.media-speak .books ul li .thumb{
    margin-bottom: 20px;
}

.media-speak .books ul li .detail h4{
    font-size: 1.6rem;
}

.media-speak .books ul li .detail .text{
    font-size: 1.2rem;
}

.media-speak .speaking{
    padding-top: 50px;
}


.media-speak .speaking .speakingTermList{
    margin-bottom: 30px;
    margin-top: 0;
    gap: 20px;
}


.media-speak .speaking .speakingTermList li a{
    font-size: 1.5rem;
    padding: 5px;
}

.media-speak .speaking .speakingList.select ul{
    flex-direction: column;
}

.media-speak .speaking .speakingList.select ul li{
    width: 100%;
}
.media-speak .speaking .speakingList.select ul li .thumb{
    margin-bottom: 24px;
}
.media-speak .speaking .speakingList.select ul li p.date{
    margin-top: 0;
}
.media-speak .speaking .speakingList.select ul li h4{
    font-size: 1.5rem;
    line-height: 2;
    margin-bottom: 30px;
}
.media-speak .speaking .speakingList.select ul li .text{
    font-size: 1.2rem;
}
.media-speak .speaking .speakingList.select ul li .speakingLink,
.media-speak .speaking .speakingList.select ul li .speakingLink a{
       font-size: 1.2rem; 
}

.media-speak .speaking .speakingMessage{
    font-size: 1.5rem;
    margin-top: 50px;
}

.media-speak .media{
 padding: 58px 0 43px;   
}

.media .custom-scrollbar {
  position: relative;
  height: 1px;
  background: #838486;
  margin: 20px auto 70px;
  width: calc(100% - 70px);
  border-radius: 2px;
  
}

.media .custom-scrollbar:before{
background: #838486;
    content: "";
    display: block;
    height: 4px;
    left: -3px;
    position: absolute;
    top: 50%;
    width: 4px;
    transform: rotate(45deg) translateY(-50%);
    transform-origin: top;
}

.media .custom-scrollbar:after{
background: #838486;
    content: "";
    display: block;
    height: 4px;
    right: -3px;
    position: absolute;
    top: 50%;
    width: 4px;
    transform: rotate(45deg) translateY(-50%);
    transform-origin: top;
}


.media .custom-scrollbar:before{
    content:"";
    display: block;
}


.media .custom-scrollbar .handle {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 15px;
  height: 15px;
  background: #D9D9D9;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 2px rgba(0,0,0,0.5);
    z-index: 1;
}


.media-speak .media #mediaFlexWrap{
    width: calc(100% + 70px);
    margin-left: -35px;
    overflow-x: auto;
}



.media-speak .media #mediaFlexWrap::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Opera */
}

.media-speak .media ul li{
    width: fit-content;
    flex: 0 0 auto;
}

.media-speak .media ul li:nth-of-type(1){
    border-top: solid 1px rgba(255, 255, 255, 0.5);
}
.media-speak .media ul li .thumbWrap{
    padding-left: 35px;
}

.media-speak .media ul li .text{
    width: 400px;
    flex: 0 0 auto;
    padding-right: 35px;
}

.media-speak .media ul li .text h4{
font-size: 1.5rem;
}
.media-speak .media ul li .text .detail{
font-size: 1.2rem;
}
.media-speak .media ul li .text .link{
font-size: 1.2rem;
}


.blog{
    padding: 30px 0 60px;
}

.blog h2{
        font-size: 2.4rem;
        line-height: 1;
        margin-bottom: 53px;
    }

.blog p.catch{
    font-size: 2.0rem;
    line-height: 1.4;
    margin-bottom: 20px;
}

.blog p{
    font-size: 1.4rem;
    line-height: 2.6;
}

.blog a.blogBtn{
    margin-top: 60px;
}

.contact{
    padding: 50px 0 60px;
}

.contact h2{
        font-size: 2.4rem;
        line-height: 1;
        margin-bottom: 53px;
    }

.contact .contactMessage p.catch{
    font-size: 2.0rem;
    line-height: 1.4;
    margin-bottom: 20px;
}
.contact .contactMessage p{
    font-size: 1.2rem;
    line-height: 1.9;
}

.contact .formWrap .block{
    margin-bottom: 26px;
}
.contact .formWrap .block p.title{
 font-size: 1.4rem;
 line-height: 1.4;   
}

.contact .formWrap .block .input input,
.contact .formWrap .block .input select,
.contact .formWrap .block .input textarea{
    font-size: 1.2rem;
}

.contact .formWrap .block .dateWrap{
    gap: 10px;
    flex-direction: column;
}
.contact .formWrap .block .dateWrap>.input{
    width: 100%;
}

.contact .formWrap .block .privacycatch{
    font-size: 1.4rem;
}
.contact .formWrap .block .privacyBox p{
    font-size: 1.0rem;
}
.contact .formWrap input[type="submit"]{
    width: 100%;
    padding-left: 0;
    padding-right: 0;
    margin-top: 30px;
        background-position: right 10px center;
}

.contact .formWrap .block .input .wpcf7-not-valid-tip,
.contact .wpcf7-response-output{
padding: 10px!important;
}

.contact .formWrap .block .input input[type="date"]{
    height: calc(1.68rem + 24px);
}

.footer .pagetop {
    position: fixed;
    right: 10px;
    bottom: 10px;
    width: 40px;
    height: 40px;
}
.footer .pagetop::before {
    width: 8px;
    height: 8px;
}
.forSp{
    display: block;
}

.forPc{
    display: none;
}
}



/* for animation */

.fadein {
  opacity: 0;
  transition: all 0.8s ease;
}

.fadein.active {
  opacity: 1;
}

/*google reCAPTCHA*/
.grecaptcha-badge{
    display: none!important;
}