@charset "UTF-8";

/* ////////////////////////////////////////////////////////////////////
///// 全ページ共通CSS ///////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// */

/* ==================================================
FONT SETTING
================================================== */
html {
    font-size: 2.81vw;
}

@media screen and (min-width:641px) {
    html {
        font-size: 1.41vw;
    }
}

@media screen and (min-width:961px) {
    html {
        font-size: 1.15vw;
    }
}

body {
    /*ゴシック系*/
    font-family: YuGothic, 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    /*明朝系
    font-family: "游明朝", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;*/
    font-weight: 400;
    font-style: normal;
    background: #FFF4F6;
    font-size: 1rem;
    line-height: 1.5;
    -ms-font-feature-settings: "normal";
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

.enGothic {
    font-family: 'Dosis', sans-serif;
    font-weight: 600;
    font-style: normal;
}

.itaric {
    font-style: italic;
}

p {
    line-height: 1.7;
    letter-spacing: 0;
}

.pagerTxt,
.mbTitle {
    line-height: .9;
    letter-spacing: -.05em;
}

.StrongTitle {
    font-size: 10.94vw;
    line-height: 1.1;
}
.enStrongTitle {
    font-size: 14.22vw;
    line-height: 1.1;
}

.MainTitle {
    font-size: 7.81vw;
    line-height: 1.1;
}
.enMainTitle {
    font-size: 9.38vw;
    line-height: 1.1;
}
.SubTitle {
    font-size: 4.69vw;
    line-height: 1.2;
}
.enSubTitle {
    font-size: 5.63vw;
    line-height: 1.2;
}
.btnLine.mainBtn .LTxt{
    font-size: calc(3.75vw * 1.2);
}
.LTxt {
    font-size: 3.75vw;
    line-height: 1.2;
    letter-spacing: .1em;
}
#ftr .STxt{font-size: 3.2vw;
}

.MTxt {
    font-size: 2.81vw;
    line-height: 1.8;
}



.menuBlk .MTxt,
.STxt{
    font-size: 2.19vw;
    line-height: 1.2;
    letter-spacing: .05em;
}

.calendarTxt{
    font-size: 8px;
}
.fs400 {
    font-size: 400%;
}

.fs300 {
    font-size: 300%;
}

.fs200 {
    font-size: 200%;
}

.fs180 {
    font-size: 180%;
}

.fs160 {
    font-size: 160%;
}

.fs150 {
    font-size: 150%;
}

.fs140 {
    font-size: 140%;
}

.fs130 {
    font-size: 130%;
}

.fs120 {
    font-size: 120%;
}

.fs110 {
    font-size: 110%;
}

.fs90 {
    font-size: 90%;
}

.fs80 {
    font-size: 80%;
}

.fs70 {
    font-size: 70%;
}

.fs60 {
    font-size: 60%;
}

.fs50 {
    font-size: 50%;
}

.fwBold {
    font-weight: 700;
}

.fsItalic {
    font-style: italic;
}

@media screen and (min-width:641px) {
    .StrongTitle {
        font-size: 6.25vw;
    }
    .enStrongTitle {
        font-size: 8.13vw;
    }
    .MainTitle {
        font-size: 4.69vw;
    }
    .enMainTitle {
        font-size: 5.63vw;
    }
    .SubTitle {
        font-size: 2.81vw;
    }
    .enSubTitle {
        font-size: 3.38vw;
    }
    .btnLine.mainBtn .LTxt{
        font-size: calc(2.03vw * 1.2);
    }
    .teamAtoZ .LTxt {
        font-size: 2.81vw;
    }    
    .LTxt {
        font-size: 2.03vw;
    }
    .MTxt {
        font-size: 1.56vw;
    }
    #ftr .STxt,
    .menuBlk .MTxt,
    .STxt {
        font-size: 1.25vw;
    }
    .calendarTxt{
        font-size: 7px;
    }
}

@media screen and (min-width:961px) {
    .StrongTitle {
        font-size: 4.69vw;
    }
    .enStrongTitle {
        font-size: 6.1vw;
    }
    .MainTitle {
        font-size: 3.65vw;
    }
    .enMainTitle {
        font-size: 4.38vw;
    }
    .SubTitle {
        font-size: 2.19vw;
    }
    .enSubTitle {
        font-size: 2.63vw;
    }
    .btnLine.mainBtn .LTxt,
    .LTxt {
        font-size: 1.46vw;
    }
    .teamAtoZ .LTxt {
        font-size: 2.19vw;
    }
    .menuBlk .MTxt,
    .MTxt {
        font-size: 1.15vw;
    }
    .STxt {
        font-size: .94vw;
    }
    #ftr .STxt{
        font-size: .85vw;

    }
}
@media screen and (min-width:1366px) {
    .StrongTitle {
        font-size: 64px;
    }
    .enStrongTitle {
        font-size: 83px;
    }
    .MainTitle {
        font-size: 50px;
    }
    .enMainTitle {
        font-size: 60px;
    }
    .SubTitle {
        font-size: 30px;
    }
    .enSubTitle {
        font-size: 36px;
    }
    .btnLine.mainBtn .LTxt,
    .LTxt {
        font-size: 20px;
    }
    .teamAtoZ .LTxt {
        font-size: 30px;
    }    
    .menuBlk .MTxt,
    .MTxt {
        font-size: 16px;
    }
    .STxt {
        font-size: 13px;
    }
}
@media screen and (max-width: 640px) {
    .memberListsB .memberList .memberProf .name {
        font-size: 3.9vw;
    }
}

/* ==================================================
margin / padding
================================================== */
.SMgn{
    margin-top: 1.11rem !important;
}
.MMgn{
    margin-top: 2.78rem !important;
}
.MsMgn{
    /* MMgnより少しちいさい */
    margin-top: 2.22rem !important;
}
.LMgn{
    margin-top: 5.56rem !important;
}
.LsMgn{
    /* LMgnより少しちいさい */
    margin-top: 4.44rem !important;
}
.MPdnB{
    padding-bottom: 2.78rem !important;
}
.MsPdnB{
    padding-bottom: 2.22rem !important;
}
.LPdnB{
    padding-bottom: 5.56rem !important;
}
.LsPdnB{
    /* LMgnより少しちいさい */
    padding-bottom: 4.44rem !important;
}
.MPdnT{
    padding-top: 2.78rem !important;
}
.MsPdnT{
    padding-top: 2.22rem !important;
}
.LPdnT{
    padding-top: 5.56rem !important;
}
.LsPdnT{
    padding-top: 4.44rem !important;
}
@media screen and (min-width:961px) {
    .SMgn{
        margin-top: 1.25rem !important;
    }
    .MMgn{
        margin-top: 3.13rem !important;
    }
    .MsMgn{
        /* MMgnより少しちいさい */
        margin-top: 2.5rem !important;
    }
    .LMgn{
        margin-top: 6.25rem !important;
    }
    .LsMgn{
        /* LMgnより少しちいさい */
        margin-top: 5rem !important;
    }
    .MPdnB{
        padding-bottom: 3.13rem !important;
    }
    .MsPdnB{
        padding-bottom: 2.5rem !important;
    }
    .LPdnB{
        padding-bottom: 6.25rem !important;
    }
    .LsPdnB{
        padding-bottom: 5rem !important;
    }
    .MPdnT{
        padding-top: 3.13rem !important;
    }
    .MsPdnT{
        padding-top: 2.5rem !important;
    }
    .LPdnT{
        padding-top: 6.25rem !important;
    }
    .LsPdnT{
        padding-top: 5rem !important;
    }
}
@media screen and (min-width:1366px) {
    .SMgn{
        margin-top: 20px !important;
    }
    .MMgn{
        margin-top: 50px !important;
    }
    .MsMgn{
        /* MMgnより少しちいさい */
        margin-top: 40px !important;
    }
    .LMgn{
        margin-top: 100px !important;
    }
    .LsMgn{
        /* LMgnより少しちいさい */
        margin-top: 80px !important;
    }
    .MPdnB{
        padding-bottom: 50px !important;
    }
    .MsPdnB{
        padding-bottom: 40px !important;
    }
    .LPdnB{
        padding-bottom: 100px !important;
    }
    .LsPdnB{
        padding-bottom: 80px !important;
    }
    .MPdnT{
        padding-top: 50px !important;
    }
    .MsPdnT{
        padding-top: 40px !important;
    }
    .LPdnT{
        padding-top: 100px !important;
    }
    .LsPdnT{
        padding-top: 80px !important;
    }
}
/* ==================================================
font line height
================================================== */
.nowloading .spinner {
    width: auto;
    height: auto;
}

/* ==================================================
link
================================================== */

a:link {
    color: #333333;
    text-decoration: none;
}

a:visited {
    color: #333333;
    text-decoration: none;
}

a:active {
    color: #333333;
    text-decoration: none;
}

.weakColor a:link {
    color: #888888;
    text-decoration: underline;
}

.weakColor a:visited {
    color: #888888;
    text-decoration: underline;
}

.weakColor a:active {
    color: #888888;
    text-decoration: underline;
}

.tagList li a:link,
.tagList li a:visited,
.tagList li a:active {
    text-decoration: none;
}

.bnrmenuLists li a:link,
.bnrmenuLists li a:visited,
.bnrmenuLists li a:active {
    border-bottom: 2px solid #333333;
}

.cArrow a:active,
.cArrow a:visited,
.cArrow a:link{
    color: #F676A6;
    text-decoration: none;
}

/* ==================================================
color
================================================== */

body {
    color: #231815;
}

.mainColor {
    color: #231815;
}

.titColor {
    color: #231815;
}

.weakColor {
    color: #808080;
}

.backClr {
    color: #ffffff;
}

.attention {
    color: #a80028;
}

.clrWh {
    color: #fff;
}

.clrPink {
    color: #F676A6;
}
.clrGray {
    color: #999;
}
.clrGld {
    color: #E5BD2A;
}

.teamATxt {
    color: #F676A6;
}

.teamKTxt {
    color: #77B800;
}

.teamBTxt {
    color: #34B6E4;
}

.team4Txt {
    color: #F3E800;
}

.team8Txt {
    color: #062C79;
}

.researchStudentTxt {
    color: #2ab2bc;
}

.bgWh {
    background: #FFFFFF;
}
.bgPink {
    background: #F676A6;
}

.bgLpink {
    background: #FEF9FA;
}

.bgXlpink {
    background: #FFFAFB;
}
.bgGld {
    background: #E5BD2A;
}

.topConts {
    background: #FFF4F6;
}

.teamA {
    background: #F676A6;
    opacity:.5;
}

.teamK {
    background: #77B800;
    opacity:.5;
}

.teamB {
    background: #34B6E4;
    opacity:.5;
}

.team4 {
    background: #F3E800;
    opacity:.5;
}

.team8 {
    background: #062C79;
    opacity:.5;
}

.teamAtoZ {
    background: #F676A6;
    opacity:.5;
}

.team0 {
    background: #F596B4;
    opacity:.5;
}

/* ==================================================
common
================================================== */
.new::after {}

svg {
    fill: #000;
}

input {
    -webkit-appearance: none;
}

.scrollArrow span {
    width: 1px;
}

.slideIn {
    -webkit-transition: all 2.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 2.8s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.nowPage {
    position: relative;
}

.nowPage::after {
    content: "";
    display: none;
    background: #000;
    width: 70%;
    height: 1px;
    position: absolute;
    bottom: 5px;
    left: 8vw;
}

@media screen and (min-width:641px) {
    .nowPage::after {
        left: 4vw;
    }
}

@media screen and (min-width:961px) {
    .nowPage::after {
        bottom: -5px;
        left: 50%;
        width: 80%;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0);
    }
}

@media screen and (min-width:1281px) {
    .menuOnline {
        display: none;
    }
}

/* ==================================================
BtnSet
================================================== */
.BtnCenter {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: .8s all ease-in;
    transition: .8s all ease-in;
    text-align: center;
}

.BtnCenter svg {
    height: 1.2em;
    width: 1.2em;
    margin: 0 10px 0 0;
}

.BtnCenter a {
    padding: 1.3em .5em;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    z-index: 10;
    width: 100%;
    text-align: center;
    margin: 0 auto;
    text-decoration: none;
}

.BtnCenter a figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}



.kadoRBtn {
    border-radius: 6px;
}

.roundBtn {
    border-radius: 4em;
}
.btnLine,
.btnBeta {
    overflow: hidden;
    position: relative;
    display: inline-block;
}

.btnLine.mainBtn {
    background: rgba(255, 255, 255, 1);
    border: 1.25vw solid #F2E2E9;
    min-width: 70vw;
    max-width: 90vw;
}
.btnLine.mainBtn a {
    padding: 1em 2em 1.1em;
    color: #F676A6;
}

.btnLine.mainBtn input{
    color: #F676A6;
    background: none;
    border: none;
}
.btnBeta.subBtn {
    background: #F676A6;
    max-width: 80vw;
}
.btnBeta.subBtn.cancel {
    background: #FABAD2;
}

.btnBeta.subBtn a{
    padding: 1.1em 2em 1.2em;
    color: #ffffff;
}
.btnBeta.sBtn {
    background: #F676A6;
    max-width: 80vw;
}

.btnBeta.sBtn a{
    padding: .2em 1em .3em;
    color: #ffffff;
}

.btnBeta.subBtn svg{
    fill: #ffffff;
}

.mainBtn p,
.subBtn p{
    position: relative;
    padding: 0;
    display: inline-block;
    line-height: 1;
    width: 100%;
}

.recBtn {
    text-align: right;
    padding:  0 2em 0 0;
}

.recBtn p {
    text-align: right;
    margin: 0 0 0 auto;
}

.recBtn p a {
    text-decoration: none;
    text-align: right;
    padding: 0;
    color: #F676A6;
}

@media screen and (min-width:641px) {
    .btnLine.mainBtn {
        border: .63vw solid #F2E2E9;
    }
}

@media screen and (min-width:961px) {
    .btnLine.mainBtn {
        border: .42vw solid #F2E2E9;
    }
    .btnLine.mainBtn a {
        padding: 1.4em 2em 1.5em;
    }
    .btnBeta.subBtn a{
        padding: 1.3em 1em 1.4em;
    }
    .btnBeta.sBtn a{
        padding: .4em 1em .5em;
    }
}
@media screen and (min-width:1366px) {
    .btnLine.mainBtn {
        border: 4px solid #F2E2E9;
    }
}

.btnArea .btnLists {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 30px 0 0;
}

.btnArea .btnLists .btnList {
    width: 49%;
    margin: 0 0 10px;
}

@media screen and (min-width:641px) {
    .btnArea .btnLists .btnList {
        width: 24%;
        margin: 0;
    }
}

.btnArea .btnLists .btnList a {
    background: #F676A6;
    border-radius: 10px;
    color: #fff;
    display: block;
    padding: 15px;
}

/* ==================================================
nowloading
================================================== */
.double-bounce1,
.double-bounce2 {
    background-color: #292929;
}

button.nl {
    height: 60px;
    width: 40px;
    background: rgba(255, 255, 255, .4);
    border-radius: 50%;
    border-top: 2px solid #0081c3;
    border-right: 2px solid transparent;
    border-bottom: none;
    border-left: none;
    -webkit-animation: spinner5 700ms linear infinite;
    animation: spinner5 700ms linear infinite;
}

@-webkit-keyframes spinner5 {
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes spinner5 {
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.loadingSet {
    display: none;
    width: 90%;
    position: fixed;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.loadingSet p img {
    max-width: 80px;
    width: 30%;
    height: auto;
}

.loadingSet figure {
    width: 100%;
    margin: 20px auto 0;
}

.loadingSet figure svg {
    width: 140px;
    height: 32px;
    fill: #dc042a;
}

.loadingSet figure figcaption {
    line-height: 1.5;
    margin: 5px auto 0;
    text-align: center;
    font-weight: bold;
}

.nowloading .loadingSet {
    display: block;
}

/* ==================================================
header
================================================== */
#hdr {
    height: 60px;
    text-align: center;
    position: fixed;
    z-index: 1020;
}

#glbMenu {
    position: fixed;
    width: 100%;
    left: 0;
    top: 0;
    z-index: 15;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    background: rgba(255, 255, 255, .65);
}

.navion #glbMenu {
    top: 0%;
}

#hdr .logoSct {
    width: auto;
    height: 60px;
    left: 50px;
    top: 0;
    position: fixed;
    z-index: -1;
}

.navion #glbMenu .logoSct {
    display: block;
}

.navion #glbMenu .logoSct {}

#hdr .logoSct a {
    width: auto;
    height: 100%;
    margin: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: inline-block;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

#hdr .logoSct h1 {
    display: grid;
    height: 100%;
    align-items: center;
    margin: 0;
}

#hdr .logoSct h1 svg {
    width: 20.0vw;
    height: 6.56vw;
    max-width: 128.4048px;
    max-height: 35px;
    display: block;
    fill: rgba(245, 118, 163, 1);
}

#glbMenu .logoSct .lsTxtBlk {
    text-align: left;
    margin: 1em 0 0;
    padding: 0 0 0 3vw;
}

#hdr .menuSet {
    position: absolute;
    top: 60px;
    background: #fff;
}

#hdr .menuSet .menuLists .menuList:last-child {
    border-right: none;
}

.noMain #glbMenu .logoSct h1 svg,
.scrolledMenu #glbMenu .logoSct h1 svg {}

#glbMenu .sideSct {
    background: #F676A6;
}

.navion #glbMenu .sideSct {
    background: none;
}

#glbMenu .sideSct::after {
    content: "";
    display: none;
    position: absolute;
    left: 0;
    top: 0;
    height: 60px;
    width: 100%;
    z-index: -1;
}

.noMain #glbMenu .sideSct::after,
.scrolledMenu #glbMenu .sideSct::after {
    opacity: 1;
    -webkit-transition: .8s ease opacity;
    transition: .8s ease opacity;
}

#glbMenu .hamburger {
    margin: 0;
    z-index: 12;
}

.navion .menuBtn,
.closeBtn {
    display: none;
}

.navion .closeBtn,
.navioff .menuBtn {
    display: block;
}

#glbMenu .gNavBlk {
    width: 100%;
    height: 100vh;
    background: #FAE0E6;
    position: fixed;
    top: 0;
    right: -100vw;
    opacity: 0;
    z-index: -1;
    overflow-y: auto;
    text-align: center;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 7vh 0 0;
}

.navion #glbMenu .gNavBlk {
    right: 0;
    opacity: 1;
    -webkit-transition: .3s opacity ease;
    transition: .3s opacity ease;
}

#glbMenu .navTit {
    padding: 0 0 0 2vw;
    position: relative;
    margin: 0 0 1em;
}

#glbMenu .navTit::before {
    content: "";
    border-top: 1px solid #AAAAAA;
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 1.5vw;
}

#glbMenu .gNavBlk .menuSet {
    width: 100%;
    text-align: left;
    padding: 0 5vw;
    margin: 0 auto;
}

#glbMenu .gNavBlk .menuSet .menuLists {
    margin: 0 auto;
    padding: 0;
}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList {
    width: 48%;
    letter-spacing: .1em;
    padding: 0;
    margin: 0 0 2vw;
    border-radius: 2vw;
}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList svg {
    width: 4em;
    height: 1.3em;
}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList a {
    width: 100%;
    height: 100%;
    padding: 1.2em 1em;
}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList .menuBlk {}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList .menuBlk figcaption {
    letter-spacing: -.01em;
    margin: 0 auto;
}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList .menuBlk svg {
    fill: #fff;
    width: 10vw;
    height: 7vw;
    margin: 0;
}

/*submenu*/
#glbMenu .gNavBlk .subMenuArea {
    padding: 0 5vw 10vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: wrap;
    flex-flow: wrap;
}

#glbMenu .gNavBlk .subMenuArea a {
    color: inherit;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet {
    width: 50%;
    margin: 10vw 0 0;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet .smTit {
    letter-spacing: 0;
    margin: 0 0 5vw;
    text-align: left;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists {
    padding: 0;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList {
    padding: 0 0 .8em;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList + .subMenuList {}



#glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet {
    width: 100%;
    text-align: left;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsLists {
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: space-between;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList {
    width: 49%;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList a {
    width: 100%;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglImg {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    padding: 4vw 0 4vw 2vw;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglImg img {
    width: auto;
    height: 10vw;
}

#glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglTxt {
    padding: 0 2vw;
    word-break: break-all;
}


#glbMenu .gNavBlk .snsArea {
    padding: 10vw 0;
}

#glbMenu .gNavBlk .snsArea .snsTit {}

#glbMenu .gNavBlk .snsLists {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: center;
    padding: 0;
    margin: 4vw 0 0;
}

#glbMenu .gNavBlk .snsLists .snsList {
    margin: 0 2vw;
}

#glbMenu .gNavBlk .snsLists .snsList svg {
    width: 7vw;
    height: 7vw;
    fill: #fff;
    max-width: 28px;
    max-height: 28px;
}

#glbMenu .gNavBlk .snsLists .snsList img {
    width: 7vw;
    height: 7vw;
    fill: #fff;
    max-width: 28px;
    max-height: 28px;
}

#glbMenu .gNavBlk .subMenuLists {
    text-align: left;
    padding: 8rem 0;
}

#glbMenu .gNavBlk .subMenuLists .subMenuList {
    padding: .6em 0;
}

/* 211207追加 */
#glbMenu .contactSct {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin: 0 2px 0 0;
    padding: 0 1.8em;
}

.navion #glbMenu .contactSct {
    z-index: -1;
}

#glbMenu .contactSct .contactBlk {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0;
}

#glbMenu .contactSct .contactBlk figcaption {
    text-align: center;
    line-height: 1.5;
}

/* //211207追加 */



@media screen and (min-width:641px) {

    #glbMenu .gNavBlk {
        width: 100%;
    }

    #glbMenu .contactSct {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        margin: 0 2px 0 0;
        padding: 0 2.5em;
    }

    .navion #glbMenu .contactSct {
        z-index: -1;
    }

    #glbMenu .contactSct svg {
        width: 4vw;
        height: 4vw;
        max-width: 40px;
        max-height: 40px;
        fill: #ffffff;
    }

    #glbMenu .contactSct .contactBlk {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        padding: 0;
    }

    #glbMenu .contactSct .contactBlk figcaption {
        text-align: left;
        line-height: 1.5;
        margin: 0 0 0 1em;
    }

    #glbMenu .sideSct::after {
        height: 72px;
    }

    #glbMenu .gNavBlk .menuSet {
        width: 100%;
        text-align: left;
        padding: 0 5vw;
        margin: 0 auto;
    }


    #glbMenu .gNavBlk .menuSet .menuLists {}

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList {
        width: calc((100% - 8vw)/ 5);
        letter-spacing: .1em;
        padding: 0;
        margin: 0 0 2vw;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList svg {
        width: 4em;
        height: 1.3em;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList a {
        width: 100%;
        height: 100%;
        padding: 2vw 0 2.4vw;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList .menuBlk {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-flow: column;
        flex-flow: column;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList .menuBlk figcaption {
        margin: 0 auto;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList .menuBlk svg {
        width: 9vw;
        height: 7vw;
        margin: 0 auto .5em;
        max-width: 60px;
        max-height: 54.75px;
    }

    /*submenu*/
    #glbMenu .gNavBlk .subMenuArea {
        padding: 0 5vw 10vw;
        -ms-flex-flow: wrap;
        flex-flow: wrap;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    #glbMenu .gNavBlk .subMenuArea a {
        color: inherit;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet {
        margin: 8vw 0 0;
    }
    #glbMenu .gNavBlk .subMenuArea .subMenuSet .smTit {
        margin: 0 0 4vw;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists {
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList {
    }
    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList + .subMenuList {}

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet {
    }
    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsLists {
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList {
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList a {
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglImg {
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglImg img {
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglTxt {
    }


    #glbMenu .gNavBlk .snsArea {
        padding: 3vw 0 2.5vw;
        margin: 0;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    #glbMenu .gNavBlk .snsArea .snsTit {
        margin: 0 6vw .1em 0;
    }

    #glbMenu .gNavBlk .snsLists {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: center;
        padding: 0;
        margin: 0;
    }
    #glbMenu .gNavBlk .snsLists .snsList {
        margin: 0 1.5vw;
    }
    #glbMenu .gNavBlk .snsLists .snsList svg {
    }

    #glbMenu .gNavBlk .subMenuLists {
        text-align: left;
        padding: 8rem 0;
    }

    #glbMenu .gNavBlk .subMenuLists .subMenuList {
        padding: .6em 0;
    }
}

@media screen and (min-width:961px) {
    #hdr {}

    #glbMenu .hamburger {}

    #glbMenu .sideSct {}

    #glbMenu .navTit {
        padding: 0 0 0 1.5vw;
    }

    #glbMenu .navTit::before {
        width: 1vw;
    }

    #glbMenu .sideSct::after {
        height: 80px;
    }

    #glbMenu .gNavBlk .menuSet {
        width: 100%;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList {
        padding: 3vw;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList {
        padding: 0;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList svg {
        width: 4em;
        height: 1.3em;
    }

    /*submenu*/
    #glbMenu .gNavBlk .subMenuArea {
        padding: 2vw 5vw 8vw;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }
    #glbMenu .gNavBlk .subMenuArea .subMenuSet {
        width: 28%;
        margin: 0;
    }
    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet{
        width: 35%;
        margin: 0 auto 0 0;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .smTit {
        letter-spacing: 0;
        margin: 0 0 3vw;
        text-align: left;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists {
        padding: 0;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList {
        padding: 0 0 .8em;
        width: 100%;
    }


    #glbMenu .gNavBlk .subMenuArea .subMenuSet:nth-of-type(1) {
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet:nth-of-type(2) {
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet:nth-of-type(3) {
        -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
        order: 3;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.smTit {
        letter-spacing: .1em;
    }


    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists {}

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList {}

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList + .subMenuList {}

    #glbMenu .gNavBlk .igSet {
        text-align: left;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList {
        width: 100%;
        margin: 0 0 2vw;
    }
    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList a {
        width: 100%;
    }
    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglImg {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        width: 100%;
        background: #fff;
        border-radius: 6rem;
        padding: 2em 2vw;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: space-between;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglImg img {
        width: auto;
        height: 7vw;
        max-height: 60px;
        margin: 0 auto;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglTxt {
        padding: 0;
        word-break: break-all;
        margin: 0 10% 0 0;
        width: 50%;
    }

    #glbMenu .gNavBlk .snsLists .snsList {
        margin: 0 2vw 0 0;
    }


    #glbMenu .gNavBlk .snsLists .snsList svg {}

    #glbMenu .gNavBlk .subMenuLists {
        padding: 8rem 0;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    #glbMenu .gNavBlk .subMenuLists .subMenuList {
        padding: 0 0;
        margin: 0 2em 0 0;
    }
    #glbMenu .gNavBlk .snsLists .snsList {
        margin: 0 1vw;
    }
}

@media screen and (min-width:1366px) {
    #hdr {}

    #glbMenu .hamburger {}

    #glbMenu .logoSct {
        top: 12px;
    }

    #glbMenu .sideSct {}

    #glbMenu .navTit {
        padding: 0 0 0 1.5vw;
    }

    #glbMenu .navTit::before {
        width: 1vw;
    }

    #glbMenu .sideSct::after {
        height: 80px;
    }

    #glbMenu .gNavBlk .menuSet {
        width: 100%;
        padding: 0 10vw;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList {
        padding: 3vw;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList {
        padding: 0;
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList a {
    }

    #glbMenu .gNavBlk .menuSet .menuLists > .menuList svg {
    }


    /*submenu*/
    #glbMenu .gNavBlk .subMenuArea {
        padding: 2vw 10vw 8vw;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet {}

    #glbMenu .gNavBlk .subMenuArea .subMenuSet {
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.smTit {
        letter-spacing: .1em;
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists {}

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList {}

    #glbMenu .gNavBlk .subMenuArea .subMenuSet .subMenuLists .subMenuList + .subMenuList {}



    #glbMenu .gNavBlk .igSet {
        text-align: left;
    }

    #glbMenu .gNavBlk .igSet .igsList {
        width: 6vw;
    }

    #glbMenu .gNavBlk .igSet .igsList a {
        width: 100%;
    }

    #glbMenu .gNavBlk .snsLists .snsList {
        margin: 0 2vw 0 0;
    }


    #glbMenu .gNavBlk .snsLists .snsList svg {}

    #glbMenu .gNavBlk .subMenuLists {
        padding: 8rem 0;

    }

    #glbMenu .gNavBlk .subMenuLists .subMenuList {
        padding: 0;
        margin: 0 2em 0 0;
    }


    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet {
    }

    #glbMenu .gNavBlk .subMenuArea .subMenuSet.igSet .igsList .iglImg {
        padding: 2em 1em;
    }

}

/* ==================================================
humberger-menu animation
================================================== */

.hamburger {
    width: 70px;
    height: 50px;
}

.menu-trigger {
    position: relative;
    width: 100%;
    height: 100%;
}

.menu-trigger,
.menu-trigger span {
    display: inline-block;
    -webkit-transition: all .4s;
    transition: all .4s;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.menu-trigger span {
    position: absolute;
    left: 30%;
    width: calc(100% / 2.5);
    height: 3px;
    border-radius: 3px;
    background-color: #fff;
}

.scrolledMenu .menu-trigger span,
.noMain .menu-trigger span {
    background-color: #fff;
}

.menu-trigger span:nth-of-type(1) {
    top: calc(50% - 11.5px);
}

.menu-trigger span:nth-of-type(2) {
    top: calc(50% - 1.5px);
}

.menu-trigger span:nth-of-type(3) {
    bottom: calc(50% - 11.5px);
}

.menu-trigger span:nth-of-type(1) {
    -webkit-animation: menu-bar01 .75s forwards;
    animation: menu-bar01 .75s forwards;
}

@-webkit-keyframes menu-bar01 {
    0% {
        -webkit-transform: translateY(4px) rotate(45deg);
        transform: translateY(4px) rotate(45deg);
    }

    50% {
        -webkit-transform: translateY(-4px) rotate(0);
        transform: translateY(-4px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }
}

@keyframes menu-bar01 {
    0% {
        -webkit-transform: translateY(4px) rotate(45deg);
        transform: translateY(4px) rotate(45deg);
    }

    50% {
        -webkit-transform: translateY(-4px) rotate(0);
        transform: translateY(-4px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }
}

.menu-trigger span:nth-of-type(2) {
    -webkit-transition: all .25s .25s;
    transition: all .25s .25s;
    opacity: 1;
}

.menu-trigger span:nth-of-type(3) {
    -webkit-animation: menu-bar02 .75s forwards;
    animation: menu-bar02 .75s forwards;
}

@-webkit-keyframes menu-bar02 {
    0% {
        -webkit-transform: translateY(-4px) rotate(-45deg);
        transform: translateY(-4px) rotate(-45deg);
    }

    50% {
        -webkit-transform: translateY(4px) rotate(0);
        transform: translateY(4px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }
}

@keyframes menu-bar02 {
    0% {
        -webkit-transform: translateY(-4px) rotate(-45deg);
        transform: translateY(-4px) rotate(-45deg);
    }

    50% {
        -webkit-transform: translateY(4px) rotate(0);
        transform: translateY(4px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }
}

.navion .menu-trigger span:nth-of-type(1) {
    -webkit-animation: active-menu-bar01 .75s forwards;
    animation: active-menu-bar01 .75s forwards;
}

@-webkit-keyframes active-menu-bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(-4px) rotate(0);
        transform: translateY(-4px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(10px) rotate(45deg);
        transform: translateY(10px) rotate(45deg);
    }
}

@keyframes active-menu-bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(-4px) rotate(0);
        transform: translateY(-4px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(10px) rotate(45deg);
        transform: translateY(10px) rotate(45deg);
    }
}

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

.navion .menu-trigger span:nth-of-type(3) {
    -webkit-animation: active-menu-bar02 .75s forwards;
    animation: active-menu-bar02 .75s forwards;
}

@-webkit-keyframes active-menu-bar02 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(4px) rotate(0);
        transform: translateY(4px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(-10px) rotate(-45deg);
        transform: translateY(-10px) rotate(-45deg);
    }
}

@keyframes active-menu-bar02 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(4px) rotate(0);
        transform: translateY(4px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(-10px) rotate(-45deg);
        transform: translateY(-10px) rotate(-45deg);
    }
}

@media screen and (min-width:641px) {
    .hamburger {
        width: 110px;
        height: 70px;
    }
}

@media screen and (min-width:961px) {
    .hamburger {
        margin: 0 auto;
    }

    .menu-trigger span {
        height: 4px;
        border-radius: 4px;
    }

    .menu-trigger span:nth-of-type(1) {
        top: calc(50% - 14px);
    }

    .menu-trigger span:nth-of-type(2) {
        top: calc(50% - 2px);
    }

    .menu-trigger span:nth-of-type(3) {
        bottom: calc(50% - 14px);
    }

    .navion .menu-trigger span:nth-of-type(1) {
        -webkit-animation: active-menu-bar03 .75s forwards;
        animation: active-menu-bar03 .75s forwards;
    }

    @-webkit-keyframes active-menu-bar03 {
        0% {
            -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
        }

        50% {
            -webkit-transform: translateY(-6px) rotate(0);
            transform: translateY(-6px) rotate(0);
        }

        100% {
            -webkit-transform: translateY(12px) rotate(45deg);
            transform: translateY(12px) rotate(45deg);
        }
    }

    @keyframes active-menu-bar03 {
        0% {
            -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
        }

        50% {
            -webkit-transform: translateY(-6px) rotate(0);
            transform: translateY(-6px) rotate(0);
        }

        100% {
            -webkit-transform: translateY(12px) rotate(45deg);
            transform: translateY(12px) rotate(45deg);
        }
    }
    .navion .menu-trigger span:nth-of-type(3) {
        -webkit-animation: active-menu-bar04 .75s forwards;
        animation: active-menu-bar04 .75s forwards;
    }
    @-webkit-keyframes active-menu-bar04 {
        0% {
            -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
        }

        50% {
            -webkit-transform: translateY(6px) rotate(0);
            transform: translateY(6px) rotate(0);
        }

        100% {
            -webkit-transform: translateY(-12px) rotate(-45deg);
            transform: translateY(-12px) rotate(-45deg);
        }
    }
    @keyframes active-menu-bar04 {
        0% {
            -webkit-transform: translateY(0) rotate(0);
            transform: translateY(0) rotate(0);
        }

        50% {
            -webkit-transform: translateY(6px) rotate(0);
            transform: translateY(6px) rotate(0);
        }

        100% {
            -webkit-transform: translateY(-12px) rotate(-45deg);
            transform: translateY(-12px) rotate(-45deg);
        }
    }

}

/* ==================================================
  2024.11.追加
================================================== */

.clrWhite {
    color: #fff;
}

.noMain .topConts {
    padding-top: 111px !important;
}

.ml0 {
    margin-left: 0 !important; 
}

.mt0 {
    margin-top: 0 !important;
}

@media screen and (min-width: 641px) {
    .sp_only {
        display: none;
    }

    .noMain .topConts {
        padding-top: 80px !important;
    }
}

@media screen and (max-width: 640px) {
    .pc_only {
        display: none;
    }
}

@media screen and (min-width: 961px) {
    .pcLg_only {
        display: none;
    }
}

/* ヘッダー  */
#hdr {
    width: 100%;
    left: 0;
    top: 0;
    background: #fff;
    position: fixed;
    border-bottom: 1px solid #F676A6;
}

#hdr .menuSet {
    padding: 0;
}

#hdr .menuSet .menuLists .menuList {
    width: 33.3333%;
    border-radius: 0;
    border-bottom: 1px solid #F676A6;
    border-right: 1px solid #F676A6;
    margin: 0;
}

#hdr .menuSet .menuLists > .menuList a {
    padding: 10px 12%;
}

#hdr .menuSet .menuLists > .menuList .menuBlk figcaption {
    width: auto;
    text-align: left;
    margin-left: 6%;
    font-size: 1rem;
}

#hdr .menuSet .menuLists > .menuList .menuBlk svg {
    fill: #F676A6;
    width: 20px;
    height: 23px;
    margin: 0;
}

#hdr .menuSet .menuLists > .menuList .menuBlk svg.iconProf {
    fill: none;
    stroke: #F676A6;
    stroke-width: 44;
    stroke-miterlimit: 10;
}

#hdr .menuBlk .icon__wrapper {
    width: 4vw;
    height: 4vw;
}

#hdr .nav__menulist .menuSet .menuLists > .menuList a {
    padding: 1.2em 1em;
}

#hdr .nav__menulist .menuSet .menuLists > .menuList .menuBlk {
    flex-flow: inherit;
    justify-content: start;
    align-items: center;
}

#hdr .nav__menulist .menuSet .menuList:first-child {
    border-right: none;
}

#hdr .nav__menulist .menuSet .menuLists > .menuList .menuBlk svg {
    width: 5vw;
    height: 5vw;
    margin: 0;
}

#hdr .nav__menulist .menuSet {
    position: relative;
    top: 0;
}

#hdr .nav__menulist .menuSet .menuLists .menuList {
    position: relative;
    width: 100%;
    border-right: none;
}

#hdr .menu_right {
    position: fixed;
    top: 0;
    right: 0;
}

#hdr .menu_right .menu_rightList {
    display: flex;
    align-items: center;
    justify-content: end;
    height: 60px;
    margin: 0;
}

#hdr .menu_right .menu_rightList .menu_rightLists {
    padding-right: 8px;
    line-height: 1;
    margin-top: 0;
}

#hdr .menu_right .menu_rightList .menu_rightLists svg {
    fill: #F676A6;
    width: 20px;
}

#hdr .menu_right .menu_rightList .menu_rightLists figcaption {
    color: #626262;
    font-size: .7rem;
}

#hdr .logoSct.logoNav {
    position: relative;
    right: 0;
    left: 0;
}

#hdr .input-hidden {
    display: none;
}

.hamburgerMenu__switch {
    cursor: pointer;
    position: absolute;
    left: 8px;
    top: 0;
    z-index: 9999;
    width: 25px;
    height: 60px;
}

#hamburgerMenu:checked ~ .hamburgerMenu__switch {
    position: fixed;
}

.hamburgerMenu__switchLine, .hamburgerMenu__switchLine:first-child, .hamburgerMenu__switchLine:last-child {
    width: 100%;
    height: 3px;
    background: #F676A6;
    position: absolute;
    left: 50%;
    transition: .3s;
    content: "";
    top: 50%;
    box-sizing: border-box;
}

.hamburgerMenu__switchLine {
    transform: translate(-50%, -50%);
}

.hamburgerMenu__switchLine:first-child {
    transform: translate(-50%, -300%);
}

.hamburgerMenu__switchLine:last-child {
    transform: translate(-50%, 200%);
}

#hamburgerMenu:checked ~ .hamburgerMenu__switch .hamburgerMenu__switchLine {
    width: 0;
}

#hamburgerMenu:checked ~ .hamburgerMenu__switch .hamburgerMenu__switchLine:first-child {
    transform: rotate(45deg) translate(-40%, 325%);
    width: 100%;
}

#hamburgerMenu:checked ~ .hamburgerMenu__switch .hamburgerMenu__switchLine:last-child {
    transform: rotate(-45deg) translate(-40%, -325%);
    width: 100%;
}

#hdr .navMenu {
    position: fixed;
    height: 100%;
    background: #fff;
    padding: 3px 0 2em;
    z-index: 9998;
    transition: .3s;
    overflow-y: scroll;
    top: 0;
    right: 100%;
    width: 80%;
}

#hdr .navMenu .btnBeta.subBtn {
    border: 1px solid #F676A6;
    background: #fff;
    width: 90%;
    margin: 8px auto 0;
    min-width: auto;
}

#hdr .navMenu .btnBeta.subBtn:nth-child(3) {
    margin-top: 20px;
}

#hdr .navMenu .btnBeta.subBtn a {
    color: #F676A6;
}

#hdr .navMenu .btnBeta.subBtn:last-child a {
    padding: 17px 10px;
}

#hdr .navMenu .btnBeta.subBtn a p {
    line-height: 1.2;
    letter-spacing: 1px;
    font-size: 12px;
}

#hdr .nav__menulist {
    list-style: none;
}

#hdr .nav__menulist li a {
    text-decoration: none;
    color: #333; 
    display: block;
    padding: .5em 0;
}

#hamburgerMenu:checked ~ .navMenu {
    right: 20%;
}

#hamburgerMenu:checked ~ .hamburgerMenu__cover {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 9997;
    background: rgba(3,3,3,.7);
    display: block;
}

#hdr .navMenu .accordion_area {
    margin-top: 10px;
    width:100%;
}

#hdr .navMenu .accordion_box {
    margin: 0 auto;
    width: 100%;
}

#hdr .navMenu .ac_answer {
    display:none;
}

#hdr .navMenu .active {
    border-radius: 0;
    overflow: hidden;
}

#hdr .navMenu .ac_question {
    display: block;
    position: relative;
    cursor: pointer;
    background: #F676A6;
    color: #fff;
    padding: 14px;
    border-bottom: 1px solid #fff;
    font-size: 1.1rem;
    font-weight: bold;
    text-align: left;
    letter-spacing: 1px;
}

.ac_question::before {
    content: '';
    position: absolute;
    width: 3.8%;
    height: 1px;
    border-bottom: solid #FFF;
    border-bottom-width: 2px;
    margin: auto;
    top: 0;
    bottom: 0;
    right: 6.2%;
    transform: rotate(0deg);
    transition: all .4s;
    z-index: 5;
}

.ac_question::after {
    content: '';
    position: absolute;
    width: 3.8%;
    height: 1px;
    border-bottom: solid #FFF;
    border-bottom-width: 2px;
    margin: auto;
    top: 0;
    bottom: 0;
    right: 6.2%;
    transform: rotate(90deg);
    transition: all .4s;
    z-index: 5;
}

.active::before {
    transform: rotate(360deg);
    transition: all .4s;
}

.active::after {
    transform: rotate(360deg);
    transition: all .4s;
}

/* 共通ボタン */
body.home a {
    text-decoration: none;
}

body.home .mainBtn p, body.home .subBtn p {
    letter-spacing: 1px;
}

body.home .subBtn {
    background: #fff;
    width: 90%;
    margin: 16px auto 0;
}

body.home .subBtn a, #hdr .navMenu .btnBeta.subBtn a {
    line-height: 0;
    padding: 10px;
    position: relative;
    display: inline-block;
}

body.home .subBtn a::before, #hdr .navMenu .btnBeta.subBtn a::before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 2px;
    border-right: solid 2px;
    transform: rotate(45deg);
    position: absolute;
    top: 0;
    right: 18px;
    bottom: 0;
    margin: auto;
}

body.home .subBtn a p {
    font-size: 12px;
}

@media screen and (min-width: 641px) {

    #hdr .logoSct {
        right: 60%;
        left: 0;
        max-width: 300px;
    }

    #hdr .menuSet .menuLists > .menuList .menuBlk .icon__wrapper {
        width: 24px;
        height: 24px;
        display: grid;
        align-items: center;
    }

    #hdr .navMenu .logoSct {
        max-width: none;
    }

    #hdr .menu_right .menu_rightList .menu_rightLists {
        padding-right: 12px;
    }

    #hdr .nav__menulist .menuSet .menuLists > .menuList .menuBlk svg {
        width: 24px;
        height: 24px;
    }

    #hdr .navMenu{
        width: 40%;
    }

    #hamburgerMenu:checked ~ .navMenu{
        right: 60%;
    }
}

@media screen and (min-width: 769px) {

    #hdr .menu_right .menu_rightList .menu_rightLists .menuBlk{
        display: flex;
        align-items: center;
    }

    #hdr .menu_right .menu_rightList .menu_rightLists figcaption {
        margin-left: 8px;
    }

    #hdr .menu_right .menu_rightList .menu_rightLists {
        padding-right: 20px;
    }

    .hamburgerMenu__switch {
        left: 20px;
    }
}

@media screen and (min-width: 961px) {

    body.home .subBtn a p {
        font-size: 13px;
    }

    #hdr .menuSet .menuLists > .menuList .menuBlk figcaption {
        font-size: 15px;
    }

    #hdr .menu_right .menu_rightList .menu_rightLists figcaption {
        font-size: 12px;
    }

    #hdr .navMenu{
        width: 30%;
    }

    #hdr .navMenu .btnBeta.subBtn a p {
        font-size: 15px;
    }

    #hdr .nav__menulist .menuSet .menuLists > .menuList a {
        padding: 20px 1em;
    }

    #hdr .navMenu .ac_question {
        font-size: 15px;
    }

    .ac_question::before, .ac_question::after {
        width: 15px
    }

    #hamburgerMenu:checked ~ .navMenu{
        right: 70%;
    }
}

@media screen and (min-width: 1281px) {
    
    body.home .menuSet .menuLists > .menuList a {
        padding: 1.2em 1em;
    }
}

/* ==================================================
  2024.12.追加
================================================== */

#disco .discoLists {
    align-items: start;
}

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

    #members .profileArea .profileSet .shareList {
        flex-wrap: wrap;
        align-items: center;
        justify-content: start;
    }

    #members .profileArea .profileSet .shareList li {
        padding: 0;
        margin-top: 8px;
        width: 20%;
    }

    #members .profileArea .profileSet .shareList li.svgTiktok svg {
        max-width: 64px;
        max-height: 57px;
        margin-left: 10px;
    }

    #members .profileArea .profileSet .shareList li img {
        max-width: 50px;
        max-height: 50px;
    }

    .guideBlk .slideContents {
        width: 100%;
    }
}

@media screen and (min-width: 641px) {
    .guideBlk .slideContents {
        width: 50%;
    }
}


.theater-Page.swiper-pagination span {
    width: 22px;
    height: 5px;
    border-radius: 0;
    margin: 0 0.5em;
}

.theater-Page.swiper-pagination span.swiper-pagination-bullet-active {
    width: 22px;
    height: 5px;
    border-radius: 0;
}


/* ==================================================
footer
================================================== */
.home #ftr {
}

#ftr {
    margin: 0 auto;
    position: relative;
    border-top: 1px solid #F676A6;
    background-color: #fff;
}

#ftr .gNavBlk .snsArea {
    padding: 3vh 0;
}

#ftr .snsArea .snsTit {}

#ftr .snsLists {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: center;
    padding: 0;
    margin: 4vw 17% 0;
}

#ftr .snsLists .snsList {
    margin: 0 8px 8px;
}

#ftr .snsLists .snsList svg {
    width: 7vw;
    height: 7vw;
    max-width: 28px;
    max-height: 28px;
    fill: #fff;
}

#ftr .snsLists .snsList img {
    max-width: 28px;
    max-height: 28px;
}

#ftr .subMenuLists {
    text-align: left;
    padding: 8rem 0;
}

#ftr .subMenuLists .subMenuList {
    padding: .6em 0;
    line-height: 1.2;
}

#ftr .companySet {}

#ftr .companySet .companySetLists {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0 auto 3rem;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: start;
    -ms-flex-flow: wrap;
    flex-flow: wrap;
    width: 95%;
}

#ftr .companySet .companySetLists .companySetList {
    margin: 0 0 1em;
    width: 100%;
    text-align: start;
    margin: 0 0 1em 2em;
}

#ftr .companySet .companySetLists .companySetList a {
    color: #626262;
    font-weight: bold;
}

#ftr .companySet .companySetLists .companySetList + .companySetList {
    position: relative;
}

#ftr .companySet .companySetLists .companySetList + .companySetList::before {
    content: "";
    width: 1px;
    height: 60%;
    background: #fff;
    position: absolute;
    left: -1em;
    top: 60%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
}



#ftr .lMarkBlk {
    margin: 0 auto;
}
#ftr .lMarkBlk img{
    width: 10vw;
    max-width: 40px;
}

#ftr .lMarkBlk figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

#ftr .lMarkBlk figure figcaption{
    margin: 0 0 0 2em;
    text-align: left;
    max-width: 60vw;
}


@media screen and (min-width:641px) {
    #ftr .companySet .companySetLists .companySetList:nth-of-type(5) {
    }

    #ftr .companySet .companySetLists .companySetList:nth-of-type(5)::before {
    }

    #ftr {
        font-size: 12px;
    }
    #ftr .lMarkBlk, #ftr .crSct {
        font-size: 10px;
    }
    #ftr .companySet .companySetLists .companySetList {
        width: 33.333%;
        margin: 0 0 20px;
    }
}

@media screen and (min-width:961px) {
    #ftr .companySet {
        margin: 0 auto;
    }

    #ftr .companySet .companySetLists {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    #ftr .companySet .companySetLists .companySetList {
        width: 20%;
        padding-left: 5%;
    }

    #ftr .crSct {
        margin: 0 auto;
        text-align: center;
    }

    #ftr .subMenuArea {
        -ms-flex-flow: wrap;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        flex-flow: row;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
        margin: 0 auto;
        width: 80%;
        max-width: 1228px;
    }

    #ftr .subMenuArea a {
        color: inherit;
    }

    #ftr .subMenuArea .subMenuSet {
        margin: 0;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-flow: wrap;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        flex-flow: column;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    #ftr .subMenuArea .subMenuSet + .subMenuSet {
        margin: 0 0 0 auto;
    }

    #ftr .subMenuArea .subMenuSet .smTit {
        letter-spacing: 0;
        margin: 0;
        text-align: left;
    }

    #ftr .subMenuArea .subMenuSet .column2ListSet {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-flow: row;
        flex-flow: row;
    }

    #ftr .subMenuArea .subMenuSet .subMenuLists {
        padding: 0;
    }

    #ftr .subMenuArea .subMenuSet .subMenuLists + .subMenuLists {
        margin: 0 0 0 2rem;
    }

    #ftr .subMenuArea .subMenuSet .subMenuLists .subMenuList {
        padding: 0 0 .8em;
        width: 100%;
    }

    #ftr .subMenuArea .subMenuSet .subMenuLists .subMenuList + .subMenuList {}

    #ftr .ftrInformationArea {
        margin: 0 auto;
        max-width: 1228px;
    }

    #ftr .snsArea .snsTit {
        margin: 0 2rem 0 0;
    }

    #ftr .snsLists {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: center;
        padding: 0;
        margin: 0;
    }

    #ftr .snsLists .snsList {
        margin: 0 1.5rem 0 0;
    }

    #ftr .snsLists .snsList a{
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }

    #ftr .snsLists .snsList svg {
        width: 7vw;
        height: 7vw;
        fill: #fff;
        max-width: 29px;
        max-height: 28px;
    }

    #ftr .subMenuLists {
        text-align: left;
        padding: 8rem 0;
    }

    #ftr .subMenuLists .subMenuList {
        padding: .6em 0;
    }

}

@media screen and (min-width:1366px) {}

/* ==================================================
main
================================================== */

#cnts {
    min-height: calc(100vh - 12rem);
}

.swiper-container-vertical > .swiper-pagination-bullets {
    right: 5px;
    top: 45vh;
    -webkit-transform: translate3d(0, -50%, 0);
    transform: translate3d(0, -50%, 0);
}

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 6px auto;
}

.swiper-pagination-bullet {
    width: 4px;
    height: 4px;
    display: inline-block;
    border-radius: 100%;
    background: #000;
    opacity: 1;
}

.swiper-pagination-bullet-active {
    width: 8px;
    height: 8px;
    display: inline-block;
    border-radius: 100%;
    background: none;
    border: 1px solid #000;
}
