@charset "utf-8";

/*==================================================
---COMMON
====================================================*/
body {
    line-height: 28px;
    animation-duration: 1.8s;
    overflow: auto;
    position: relative;
    z-index: -2;
    font-feature-settings: "palt";
    letter-spacing: 0.1em;
    color: #202023;
    word-wrap: break-word;
    font-weight: 600;
    font-style: normal;
    animation-name: opacity;
    min-width: 1164px;
    font-family: YakuHanJPs_Noto, "Noto Sans JP", sans-serif;
    font-style: normal;
    background: #000;
    font-optical-sizing: auto;
}

html {
/*    scroll-padding-top: 540px;*/
   scroll-margin-top: 540px;
}

.enFont {
    font-family: "Syncopate", sans-serif;
    font-weight: 700;
    font-style: normal;
}

body a {
    color: #fff;
    display: block;
}

img {
    -webkit-backface-visibility: hidden;
    vertical-align: bottom;
    image-rendering: -webkit-optimize-contrast;
}

@keyframes opacity {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

.bodyWrap {
    position: relative;
    z-index: 1;
}

.sameFade {
    opacity: 0;
    transform: translate(0, 1em);
    transition: 0.9s cubic-bezier(0.36, 0.14, 0, 1) 0s;
}

.sameFade.scrollin {
    opacity: 1;
    transform: translate(0);
}

.sameFade2 {
    opacity: 0.5;
    transform: translate(0, 20px);
    transition: 4s cubic-bezier(0.36, 0.14, 0, 1);
}

.sameFade2.scrollin {
    opacity: 1;
    transform: translate(0);
}

.rightFade {
    opacity: 0;
    transform: translateX(3rem);
    transition: opacity 1.3s, transform 1.3s cubic-bezier(0.25, 0.46, 0.45, 0.94),
        mask-position 1.3s cubic-bezier(0.39, 0.575, 0.565, 1),
        -webkit-mask-position 1.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.rightFade.scrollin {
    opacity: 1;
    transform: translate(0);
}

.fadezoom {
    overflow: hidden;
}

.fadezoom img {
    transform: scale(1.08);
    transition: 1.4s;
    opacity: 0;
}

.fadezoom.scrollin img {
    animation: fadeopa 1.4s cubic-bezier(0.36, 0.14, 0, 1) forwards;
    transform: scale(1);
}

@keyframes colorEffect {
    0% {
        color: #fff;
    }

    100% {
        color: #000;
    }
}

@keyframes colorEffect2 {
    0% {
        color: #fff;
    }

    100% {
        color: #000;
    }
}

@keyframes maskEffect {
    0% {
        transform: translateX(-100%);
    }

    30% {
        transform: translateX(0);
    }

    40% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(101%);
    }
}

@keyframes fadeopa {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes titleBtmFade {
    0% {
        -webkit-transform: translate(0, 100%);
        transform: translate(0, 100%);
    }

    100% {
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
}

@keyframes pulseMotion {
    0% {
        transform: translate(-50%, -50%) scale(1, 1);
        background: rgba(255, 255, 255, 0.7);
    }

    100% {
        transform: translate(-50%, -50%) scale(4.8, 4.8);
        background: rgba(255, 255, 255, 0);
    }
}

.headerInnr.change-color {
    padding: 30px 60px 0 60px;
}

.textAnime span {
    display: inline-block;
    transform: translate(0, 101%);
    transition: transform 1.2s cubic-bezier(0.36, 0.14, 0, 1);
    opacity: 0;
    -webkit-transform: translate3d(0, 0.2em, 0);
    transform: translate3d(0, 0.2em, 0);
    transition: 400ms;
    transition-property: opacity, -webkit-transform;
    transition-property: opacity, transform;
    transition-property: opacity, transform, -webkit-transform;
}

.textAnime.-visible span {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.textAnime span:nth-child(2) {
    transition-delay: 50ms;
}

.textAnime span:nth-child(3) {
    transition-delay: 100ms;
}

.textAnime span:nth-child(4) {
    transition-delay: 150ms;
}

.textAnime span:nth-child(5) {
    transition-delay: 200ms;
}

.textAnime span:nth-child(6) {
    transition-delay: 250ms;
}

.textAnime span:nth-child(7) {
    transition-delay: 300ms;
}

.textAnime span:nth-child(8) {
    transition-delay: 350ms;
}

.textAnime span:nth-child(9) {
    transition-delay: 400ms;
}

.textAnime span:nth-child(10) {
    transition-delay: 450ms;
}

.textAnime span:nth-child(11) {
    transition-delay: 500ms;
}

.textAnime span:nth-child(12) {
    transition-delay: 650ms;
}

.textAnime span:nth-child(13) {
    transition-delay: 700ms;
}

.textAnime span:nth-child(14) {
    transition-delay: 750ms;
}

.textAnime span:nth-child(15) {
    transition-delay: 800ms;
}

.textAnime span:nth-child(16) {
    transition-delay: 850ms;
}

.textAnime span:nth-child(17) {
    transition-delay: 900ms;
}

.textAnime span:nth-child(18) {
    transition-delay: 950ms;
}

.textAnime span:nth-child(19) {
    transition-delay: 1000ms;
}

.textAnime span:nth-child(20) {
    transition-delay: 1050ms;
}

.spheader {
    display: none;
}

.pcHeader {
    position: fixed;
    width: 100%;
    box-sizing: border-box;
    display: flex;
    top: 54px;
    justify-content: space-between;
    align-items: center;
    padding: 0 32px;
    z-index: 4;
    justify-content: center;
    transition: 0.4s;
    min-width: 1164px;
}

.navListBox .logoBox {
    position: absolute;
    left: 54px;
}

.navListBox nav {}

.navListBox {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
    column-gap: 20px;
}

.navListBox ul {
    display: flex;
    justify-content: center;
    align-items: center;
    column-gap: 18px;
}

.navListBox nav > ul {
    position: relative;
    padding: 0 70px;
}

.navListBox nav > ul::after {
    content: "";
    position: absolute;
    background: rgba(255, 255, 255, 0.66);
    width: 1px;
    height: 15px;
    right: 0;
    top: 14px;
}

.navListBox nav > ul::before {
    content: "";
    position: absolute;
    background: rgba(255, 255, 255, 0.66);
    width: 1px;
    height: 15px;
    left: 0;
    top: 14px;
}

.navListBox {
    backdrop-filter: blur(20px);
    background: rgba(0, 0, 0, 0.56);
    padding: 18px 45px;
    border-radius: 8px;
}


.navListBox ul a {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

header .h_nav p {
    position: relative;
    display: inline-block;
}

header .h_nav p::before {
    content: attr(data-replace);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #2c3138;
    transform: rotateX(90deg);
    opacity: 0;
    transform-origin: 50% 100%;
    transform: translate(0, 30%);
    transition: 0.5s, transform 0.5s cubic-bezier(0.36, 0.14, 0, 1);
}

header .h_nav .line::after {
    content: "";
    position: absolute;
    bottom: 1px;
    left: 0;
    display: block;
    width: 0;
    height: 1px;
    background-color: #7A78FF;
    -webkit-transition: all 1s ease;
    transition: all 1s ease;
}

header .h_nav:hover {
    color: transparent;
}

header .h_nav:hover p::before {
    transform: translate(0, 0);
    opacity: 1;
    color: #7A78FF;
}

header .h_nav:hover .line::after {
    width: 100%;
}

header .h_nav {
    position: relative;
    display: inline-block;
    padding: 9px 0;
}

header .h_nav .text {
    display: inline-block;
    transition: 0.5s, transform 0.5s cubic-bezier(0.36, 0.14, 0, 1);
}

header .h_nav:hover .text {
    transform: translate(0, -40%);
    transform: translateY(-40%) scaleY(0);
}

header .inConta a {
    background: #000;
    color: #fff;
    border-radius: 100vw;
    height: 66px;
    width: 236px;
    display: flex;
    box-sizing: border-box;
    position: relative;
    padding-right: 20px;
    justify-content: center;
    transition: 0.4s;
    letter-spacing: 0.03em;
    font-weight: 800;
    align-items: center;
}

header .inConta a::after {
    content: "";
    position: absolute;
    background-image: url(../img/mailicon.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: 18px;
    height: 14px;
    right: 24px;
    top: 27px;
}

/*================================*/
/*================================*/
/*================================*/
/*================================*/



.gnavi__list:hover .dropdown__lists {
    display: block;
    /*Gナビメニューにホバーしたら表示*/
}

.dropdown__list {
    transition: all 0.3s;
    position: relative;
}


.dropdown__list a:hover {
    background-color: #26d2ca;
}

.dropdown__list a {
    display: flex;
    transition: 0.3s;
    justify-content: center;
    align-items: center;
    color: #fff;
    background-color: #7A78FF;
    height: 60px;
    text-decoration: none;
    position: relative;
}

.dropdown__list a::before {
    content: "";
    display: block;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-left: 2px solid #fff;
    transform: rotate(135deg);
    position: absolute;
    right: 15px;
    top: calc(50% - 5px);
}



.gnavi__list:hover .dropdown__lists {
    visibility: visible;
    /*Gナビメニューにホバーしたら表示*/
    opacity: 1;
    /*不透明度1*/
}



.dropdown__lists li:first-child a {
    border-radius: 6px 6px 0 0;
}

.dropdown__lists li:last-child a {
    border-radius: 0 0 6px 6px;
}

/* ナビゲーションリストの親要素 */
.gnavi__list {
    position: relative;
    /* ドロップダウンの位置の基準点 */
    display: inline-block;
    /* 他のメニュー項目と横並びにするため */
}

/* 親メニューのテキストスタイル（任意） */
.gnavi__list > a {
    padding: 8px 16px;
    display: block;
}

/* --- ▼ ドロップダウンメニューのスタイル ▼ --- */

/* ドロップダウンのコンテナ (最初は非表示) */
.dropdown__lists {
    background-color: #000;
    color: #fff;
    border-radius: 8px;
    position: fixed;
    top: 100%;
    left: 0;
    margin: 0 auto;
    right: 0;
    max-width: 1500px;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity 0.4s ease, transform 0.4s ease, visibility 0.4s;
}

/* ホバー時にドロップダウンを表示 */
.gnavi__list:hover > .dropdown__lists {
    opacity: 1;
    visibility: visible;
    transform: translateY(9%);
}

/* ドロップダウンの中身のレイアウト */
.dropdown__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 60px 40px;
    display: flex;
    gap: 5%;
}

.dropdown__title {
    width: 25%;
}

.dropdown__title h2 {
    font-size: 32px;
    text-transform: uppercase;
    margin: 0;
    margin-top: 8px;
    letter-spacing: 0.05em;
    color: #fff;
}

.blurBox {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0;
    transition: opacity .4s;
    backdrop-filter: blur(20px);
    background: #3a3a3a7d;
    display: block;
    z-index: 2;
    pointer-events: none;
}

.pcHeader.change-color {
    top: 32px;
}

body.blurC .blurBox {
    opacity: 1;
    pointer-events: auto;
}

.dropdown__nav {
    width: 70%;
}

.dropdown__nav ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px 60px;
}

.dropdown__nav a {
    font-size: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 12px;
    transition: .4s;
    position: relative;
    /* 下線の基準 */
}

/* リンクの下線 */
.dropdown__nav a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #555;
}

.dropdown__nav a span::after {
    content: '';
    position: absolute;
    right: 0;
    top: 8px;
    transition: transform 0.3s ease-out;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-image: url(../img/navArrow.svg);
    width: 13px;
    height: 9px;
    transition: .4s;
}

.dropdown__nav a:hover span::after {
    background-image: url(../img/navArrowh.svg);
}

.dropdown__nav a:hover {
    color: #7A78FF;
}



/* --- ホバーエフェクト --- */

.dropdown__nav a:hover span::after {}

/* ホバー時の下線（白い線） */
.dropdown__nav a::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #7A78FF;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease-out;
    z-index: 1;
}

.dropdown__nav a:hover::before {
    transform: scaleX(1);
}

/*==================================================
---toggle
====================================================*/

.accordion {
    max-width: 887px;
    margin: 0 auto;
}

.accordion .toggle {
    display: none;
}

.accordion .option {
    position: relative;
    margin-bottom: 12px;
}

.accordion .title,
.accordion .content {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.3s;
}

.accordion .title {
    padding: 30px 45px;
    padding-right: 50px;
    display: block;
    border-radius: 6px;
    cursor: pointer;
    background: #fff;
}

.accordion .title.on {
    background: #26d2ca;
}

.accordion .title::after,
.accordion .title::before {
    content: "";
    position: absolute;
    right: 50px;
    top: 37px;
    width: 4px;
    height: 22px;
    background-color: #ee4499;
    transition: all 0.3s;
}

.accordion .title.on::after,
.accordion .title.on::before {
    background-color: #fff;
}

.on .qText {
    color: #fff;
}

.on .accordionFlexBoxNmber {
    color: #fff;
}

.accordion .lastPrice .title::after,
.accordion .lastPrice .title::before {
    display: none;
}

.accordion .lastPrice .title {
    cursor: default;
}

.accordion .title::after {
    transform: rotate(90deg);
}

.accordion .content {
    max-height: 0;
    overflow: hidden;
    padding: 0 45px;
}

.tableBox {
    padding: 0 80px 40px 80px;
}

.accordion .toggle:checked + .title + .content {
    background: #f5f9fc;
    max-height: 1500px;
    transition: all 1.5s;
    border-radius: 0 0 6px 6px;
}

.accordion .toggle:checked + .title::before {
    transform: rotate(90deg) !important;
}

.accordionFlexBox {
    display: flex;
    align-items: center;
}

.accordionFlexBoxNmber {
    font-size: 30px;
    color: #ee4499;
    text-transform: uppercase;
    margin-right: 14px;
    font-weight: 800;
    margin-top: -2px;
}

.accordionFlexBoxanswer {
    color: #fff;
    text-transform: uppercase;
}

.filter-toggle {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 24px 20px;
    background-color: #7A78FF;
    color: #fff;
    font-size: 15px;
    font-weight: bold;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    text-align: center;
    position: relative;
    z-index: 10;
    letter-spacing: 0.06em;
    transition: border-radius 0.3s ease;
}

/* 開いたときのボタンの角丸を調整 */
.filter-toggle[aria-expanded="true"] {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

/* 矢印アイコンのスタイル */
.arrow-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    right: 23px;
    position: absolute;
    height: 32px;
    background-color: rgba(0, 0, 0, 0.1);
    border-radius: 50%;
}

.arrow-icon svg {
    color: #fff;
    transition: transform 0.3s ease;
}

.arrow-up {
    display: none;
    /* 最初は上矢印を隠す */
}

/* is-openクラスが付いた時の矢印の表示切替 */
.is-open .arrow-down {
    display: none;
}

.is-open .arrow-up {
    display: block;
}

.filter-dropdown {
    background-color: #fff;
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 4px 20px rgb(0 0 0 / 4%);
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 5;
    visibility: hidden;
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
}

/* is-openクラスが付いた時にドロップダウンを表示 */
.is-open .filter-dropdown {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
}

.filter-dropdown ul {
    list-style: none;
    margin: 0;
}

.filter-dropdown li a {
    display: block;
    padding: 11px 20px;
    letter-spacing: 0.06em;
    font-size: 14px;
    color: #333;
    text-decoration: none;
    transition: background-color 0.2s;
}

.filter-dropdown li a:hover {
    background-color: #f9f9f9;
}

/* 最後の要素以外に区切り線を入れる */
.filter-dropdown li:not(:last-child) {
    border-bottom: 1px dotted #ccc;
}

.archive_page_navi {
    padding-top: 68px;
}

.archive_page_navi .wp-pagenavi {
    display: flex;
    column-gap: 7px;
    font-weight: 600;
    font-size: 17px;
    justify-content: center;
    align-items: center;
}

.wp-pagenavi .current {
    background: #555555;
    color: #fff;
    border-radius: 3px;
    padding: 7px 11px 3px 14px;
}

.wp-pagenavi .larger,
.wp-pagenavi .smaller {
    background: #d5d5d5;
    border-radius: 3px;
    padding: 5px 11px 4px 14px;
}

.archive_page_navi a {
    color: #fff;
}

.archive_page_navi .nextpostslink {
    color: #252525;
    margin-left: 14px;
}

.archive_page_navi .previouspostslink {
    color: #252525;
    margin-right: 14px;
}

.udpostbg .blogInner a:nth-child(4) {
    display: none;
}

.recoBlog .blogInner a:nth-child(4) {
    display: none;
}

#blog.udBloglist h4 {
    margin-bottom: 10px;
}

#blog.udBloglist .day {
    margin-top: 16px;
}

.single .loopSlideWrap03.udNamiBox {
    overflow: hidden;
}

.singlepostnavi {
    padding: 0 40px;
    padding-bottom: 140px;
}

.post_page_navi {
    list-style: none !important;
    display: flex;
    margin: 0 auto;
    justify-content: center;
    border-radius: 0;
    padding: 26px 25px;
    max-width: 1240px;
    margin-top: 160px;
    column-gap: 200px;
    /* background: #252525; */
    border-bottom: solid 1px #fff;
    letter-spacing: 0.06em;
}

a.pagenationBox_centaer {
    padding-left: 29px;
    position: relative;
}

.post_page_navi a {
    color: #fff;
    transition: 0.4s;
}

.post_page_navi span {
    font-size: 16px;
    transition: 0.4s;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
}

.prev_child .prev {
    position: relative;
    cursor: pointer;
}

.next_child .next {
    position: relative;
    cursor: pointer;
}

a.pagenationBox_centaer::after {
    content: "";
    position: absolute;
    background-image: url(../img/listicon.svg);
    background-size: contain;
    transition: 0.4s;
    background-repeat: no-repeat;
    width: 19px;
    height: 19px;
    left: 0;
    top: 4px;
}

.prev_child .prev::before {
    content: "";
    width: 53px;
    height: 1px;
    background: #fff;
    position: absolute;
    top: 52%;
    left: 86px;
}

.next_child .next::before {
    content: "";
    width: 53px;
    height: 1px;
    background: #fff;
    position: absolute;
    top: 52%;
    right: 86px;
}

#postnavi .inactive {
    opacity: 0.3;
}

.udQaBox .firstH {
    padding-top: 0;
}

p.faq-message {
    font-size: 20px;
    letter-spacing: 0.06em;
    line-height: 40px;
    font-weight: 600;
}

.voiceAyp {
    text-align: center;
    font-size: 16px;
    letter-spacing: 0.06em;
    font-weight: 600;
}

#classRoom.udclassRoom .imgBox {
    overflow: hidden;
}

#classRoom.udclassRoom .imgBox img {
    transition: 0.4s;
}

.spheader .snsBox {
    display: flex;
    column-gap: 9px;
    margin-bottom: 30px;
    margin-top: -4px;
}

.spheader .snsBox a::before {
    display: none;
}

.spheader .snsBox a::after {
    display: none;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.thanksTag a {
    display: inline-block;
    text-decoration: underline;
    color: #7A78FF;
}

p.des.thanksTag {
    line-height: 21px;
    font-size: 14px;
}

.pcBr {
    display: block;
}

#company {
    padding: 160px 80px;
    background-position: 0 0;
    border-radius: 60px 60px 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
}

#company .commonTitle {
    text-align: center;
    margin-bottom: 140px;
}

.commonTitle {
    color: #fff;
}

.commonTitle .jaTitle {
    font-size: 20px;
    display: block;
    font-weight: 600;
    line-height: 1;
    margin-bottom: 30px;
}

.commonTitle .enTitle {
    font-size: 87px;
    display: block;
    font-family: "Syncopate", sans-serif;
    font-weight: 700;
    font-style: normal;
    line-height: 1;
    text-transform: uppercase;
}

.enTitle {
    font-family: "Syncopate", sans-serif;
    font-weight: 700;
    font-style: normal;
}

/* コンテンツエリアのレイアウト */
.companyContent {
    color: #fff;
    display: flex;
    justify-content: space-between;
}

.companyContent a {
    display: inline-block;
    color: #0074d8;
    text-decoration: underline;
}

/* 左側の「outline」部分 */
.companyOutline {
    width: 20%;
    padding-top: 10px;
}

.companyOutline .jaFont {
    font-size: 14px;
    margin: 0;
    display: block;
    opacity: 0.5;
    margin-bottom: 20px;
}

.companyOutline .enFont {
    font-size: 32px;
    display: block;
    line-height: 1;
    margin: 0;
}

.companyDetailList {
    width: 66%;
}

.companyDetailList dl {
    margin: 0;
}

#company h3 {
    position: sticky;
    top: 40%;
}

.companyDetailItem {
    display: flex;
    padding: 36px 0;
    position: relative;
    /* 疑似要素の基準点 */
    align-items: flex-start;
}

/* 項目ごとの白い線（擬似要素） */
.companyDetailItem::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background-color: rgba(112, 112, 112, 0.5);
    /* 少し透過させた白線 */
    transition: 1.4s cubic-bezier(0.36, 0.14, 0, 1) 0s;
}

.companyInner .companyDetailItem.scrollin::after {
    width: 100%;
}

.companyDetailList dd {
    font-weight: 300;
}

.companyDetailItem dt {
    width: 208px;
    /* dtの幅を固定 */
    flex-shrink: 0;
    /* 幅が縮まないようにする */
    font-weight: bold;
}

.companyDetailItem dd {
    flex-grow: 1;
    margin: 0;
    line-height: 1.8;
    word-break: break-all;
}

.companyDetailItem dd span {
    display: block;
}

.companyInner {
    max-width: 1300px;
    margin: 0 auto;
}

.historyInner {
    color: #fff;
}

.historyInner .ageBox dl dt {
    color: #fff;
    font-size: 32px;
    position: relative;
    letter-spacing: 0;
    font-weight: 600;
    width: 150px;
    padding-left: 31px;
}

#history {
    padding-top: 125px;
}

#history .ageBox {
    margin-top: 79px;
}

.historyInner .ageBox dl dd {
    width: 100%;
    font-weight: 300;
}

.historyInner .inFlex {
    display: flex;
    column-gap: 80px;
    margin-bottom: 20px;
}

.historyInner .inFlex:last-child {
    margin-bottom: 0;
}

.historyInner .textBox a {
    display: inline-block;
    color: #0074d8;
    text-decoration: underline;
}

.historyInner .ageBox dl dt::after {
    content: "";
    position: absolute;
    background: #7a78ff;
    width: 14px;
    height: 14px;
    left: 0;
    top: 10px;
    border-radius: 100vw;
}

.historyInner .ageBox dl {
    display: flex;
    column-gap: 14px;
    align-items: baseline;
    position: relative;
    padding-bottom: 63px;
}

.historyInner .ageBox dl::after {
    content: "";
    position: absolute;
    background: #7a78ff;
    width: 1px;
    height: 100%;
    left: 7px;
    top: 11px;
}

.historyInner .ageBox dl:last-child::after {
    display: none;
}

.historyInner .flex {
    display: flex;
    column-gap: 14%;
}

.historyInner .ageBox .month {
    font-size: 16px;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 0;
    font-weight: 600;
    width: 52px;
}

.historyInner .textBox p {
    font-size: 16px;
    line-height: 30px;
}

#hero {
    position: relative;
    height: var(--viewport-height);
    overflow: hidden;
}

#hero h2 {
    position: absolute;
    right: 0;
    bottom: 0;
    /*    overflow: hidden;*/
    z-index: 1;
    letter-spacing: .2em;
    color: #fff;
    font-size: 74px;
    font-weight: 600;
}

#hero .textWrap {
    overflow: hidden;
    margin-top: 28px;
}

#hero .textWrap:first-child {
    margin-left: -137px;
}

#hero h2 span {
    display: block;
    line-height: 1;
}

#hero h2 span {
    -webkit-transform: translate(0, 154%);
    transform: translate(0, 154%);
    display: block;
}

#hero.scrollin h2 span {
    animation: titleBtmFade 1s cubic-bezier(.36, .14, 0, 1) 1.5s both;
}

#hero .scrolldwn {
    width: 148px;
    height: 148px;
    border-radius: 100vw;
    position: absolute;
    bottom: 40px;
    background: rgba(0, 0, 0, 0.399);
    backdrop-filter: blur(20px);
    left: 8%;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 0.35s;
}

#hero .scrolldwn:hover {
    transform: scale(0.8);
    border: solid 1px #fff;
}

#hero .scrolldwn > div {
    margin-top: 7px;
}

#hero .scrolldwn .enTitle {
    font-size: 12px;
    line-height: 1;
    color: #fff;
    margin-bottom: -4px;
}

#hero .scrolldwn span {
    display: block;
    text-align: center;
}

#hero video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

#hero .loopSlideWrap {
    position: absolute;
    top: 45%;

    overflow: hidden;
}

#hero .loopSlide {
    display: flex;
    width: 100vw;
    height: 180px;
    position: relative;
    padding-bottom: 100px;
}

#hero .loopSlideWrap::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background-color: rgba(255, 255, 255, 0.5);
    transition: 1.4s cubic-bezier(0.36, 0.14, 0, 1) 0.4s;
}

#hero.scrollin .loopSlideWrap::after {
    width: 100%;
}

#hero .loopSlide img {
    width: auto;
    height: 100%;
}

.heroSameFade01 {
    opacity: 0;
    transform: translate(0, 2.6em);
    transition: 0.8s cubic-bezier(0.36, 0.14, 0, 1) 1.2s;
}

#hero.scrollin .heroSameFade01 {
    opacity: 1;
    transform: translate(0);
}

#hero .loopSlide img:first-child {
    animation: slide3 240s -120s linear infinite;
}

#hero .loopSlide img:last-child {
    animation: slide4 240s linear infinite;
}

@keyframes slide3 {
    0% {
        transform: translateX(100%);
    }

    to {
        transform: translateX(-100%);
    }
}

@keyframes slide4 {
    0% {
        transform: translateX(0);
    }

    to {
        transform: translateX(-200%);
    }
}

@keyframes slide1 {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(100%);
    }
}

@keyframes slide2 {
    0% {
        transform: translateX(-200%);
    }
}

#news {
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 12px 12px;
    background-image: url(../img/dodobg.svg);
    padding: 160px 80px;
}

#news .titleFlex {
    display: flex;
    column-gap: 78px;
    align-items: center;
    margin-bottom: 135px;
}

#news .titleFlex .commonBtn {
    margin-top: 40px;
}

.commonBtn a {
    display: flex;
    align-items: center;
    color: #202023;
    position: relative;
    border-radius: 8px;
    width: 221px;
    height: 62px;
    background: #ffffff;
    padding: 0 35px;
    text-transform: uppercase;
    box-sizing: border-box;
    letter-spacing: 0;
    transition: 0.35s;
    font-size: 12px;
    border: solid 1px rgba(0, 0, 0, 0);
}

.commonBtn a:hover {
    background: #202023;
    border: solid 1px rgba(255, 255, 255, 0.161);
    color: #fff;
}

.commonBtn .arrowLink {
    content: "";
    position: absolute;
    top: 2px;
    right: 4px;
    width: 60px;
    height: 56px;
    border-radius: 5px;
    background: #202023;
    transition: 0.7s;
    overflow: hidden;
    transition: background-color 0.35s;
}

.commonBtn .arrowLink::before,
.commonBtn .arrowLink::after {
    content: "";
    position: absolute;
    top: 24px;
    right: 23px;
    width: 13px;
    height: 9px;
    background: url(../img/btnArrow.svg) 0 0 no-repeat;
    background-size: cover;
    z-index: 3;
}

.commonBtn .arrowLink::after {
    transform: translateX(-38px);
}

.commonBtn a:hover .arrowLink {
    background: #383838;
    transition: 0.7s;
    right: 2px;
}

.commonBtn a:hover .arrowLink::before,
.commonBtn a:hover .arrowLink::after {
    background: url(../img/btnArrow.svg) 0 0 no-repeat;
}

.commonBtn a:hover .arrowLink::before {
    animation: befobtn 0.35s cubic-bezier(0.36, 0.14, 0, 1);
}

.commonBtn a:hover .arrowLink::after {
    animation: afterbtn 0.35s cubic-bezier(0.36, 0.14, 0, 1);
}

@keyframes befobtn {
    0% {
        transform: translateX(0);
        opacity: 1;
    }

    100% {
        transform: translateX(38px);
        opacity: 0;
    }
}

@keyframes afterbtn {
    0% {
        transform: translateX(-38px);
        opacity: 0;
    }

    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

#news {
    overflow: hidden;
}

#news .tagBox {
    display: flex;
    margin-top: 30px;
    column-gap: 18px;
}

#news .tagBox .day {
    color: #fff;
    letter-spacing: 0;
    opacity: 0.6;
    font-size: 10px;
}

.newsInner {
    max-width: 1800px;
    margin: 0 auto;
}

#news .cat {
    line-height: 1;
    display: inline-block;
    border-radius: 100vw;
    color: #fff;
    font-size: 13px;
    letter-spacing: 0.03em;
    border-radius: 100vw;
    box-sizing: border-box;
    padding: 6px 14px;
    border: #585858 solid 1px;
    font-weight: 600;
    background: #202023;
}

#news .imgBox {
    border-radius: 8px;
    transition: 0.35s;
}

#news .imgBox img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 373 / 447;
    border-radius: 8px;
}

#news .swiper-button-prev::after {
    background-image: url(../img/llarrowsp.svg);
    content: "";
    width: 56px;
    height: 56px;
}

#news .swiper-button-next::after {
    background-image: url(../img/arroesp.svg);
    content: "";
    width: 56px;
    height: 56px;
}

#news .swiArrow {
    position: absolute;
    width: 143px;
    left: -13px;
    bottom: auto;
    right: auto;
    top: -66px;
    margin: 0;
}

#news .swiper-button-next,
#news .swiper-button-prev {
    width: calc(var(--swiper-navigation-size) / 40 * 51);
}

#news .nameBox {
    font-size: 18px;
    margin-top: 24px;
    font-weight: 600;
}

#news .nameBox h3 {
    font-weight: 600;
}

#news .swiper-slide a {
    color: #fff;
}

#news .swiper-slide a:hover img {
    transform: scale(1.08);
}

#news .swiper-slide a:hover .imgBox {
    transform: scale(0.94);
}


#service {
    padding: 170px 0;
    position: relative;
}

#service::after {
    content: "";
    position: absolute;
    background: #171C22;
    right: 0;
    top: 0;
    left: 0;
    bottom: -18%;
    z-index: -1;
}

#service .commonTitle {
    text-align: center;
    margin-bottom: 78px;
}


/* サービスリスト全体 */
.serviceList {
    position: relative;
    color: #fff;
}

.serviceList::after {
    content: "";
    position: absolute;
    background: #353b3e;
    width: 0;
    height: 1px;
    top: 0;
    transition: 2s cubic-bezier(0.56, 0.14, 0, 1) 0s;
}

#service.scrollin .serviceList::after {
    width: 100%;
}

.serviceItem {
    display: flex;
    position: relative;
    max-width: 1221px;
    height: 247px;
    /* align-items: center; */
    margin: 0 auto;
}

.serviceItemLine {
    position: relative;
    padding: 0 40px;
}

.serviceItemLine::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 1px;
    height: 0;
    background-color: #353b3e;
    transition: 2s cubic-bezier(0.56, 0.14, 0, 1) 0s;
}

#service.scrollin .serviceItemLine::after {
    height: 100%;
}

.serviceItemLine::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 0;
    background-color: #353b3e;
    transition: 2s cubic-bezier(0.56, 0.14, 0, 1) 0s;
}

#service.scrollin .serviceItemLine::before {
    height: 100%;
}

.serviceItemWrap {
    position: relative;
    padding: 0 10%;
}

/* サービスアイテム間の横線（擬似要素） */
.serviceItemWrap::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    transition: 2s cubic-bezier(0.56, 0.14, 0, 1) 0s;
    background-color: #353b3e;
}

#service.scrollin .serviceItemWrap::after {
    width: 100%;
}

.serviceItem_left,
.serviceItem_right {
    padding: 60px 0 0 0;
}

.serviceItem_left {
    width: 42%;
    position: relative;
}

.serviceItem_num {
    font-size: 10px;
    color: rgba(255, 255, 255, 0.40);
    margin: 0 0 3px 0;
    letter-spacing: 0;
}

.serviceItem_name {
    font-size: 23px;
    font-weight: 500;
    margin: 0;
}

.serviceItem_right {
    width: 60%;
    display: flex;
    margin-top: 31px;
    flex-direction: column;
}

.serviceItem_desc {
    font-size: 16px;
    line-height: 32px;
    margin: 0;
    font-weight: 400;
}

.serviceItem_link {
    display: inline-block;
    margin-top: 16px;
    position: relative;
    transition: .35s;
    padding-right: 30px;
}

.serviceItem_link .logo {
    display: block;
    font-size: 28px;
    font-weight: bold;
    letter-spacing: 0.05em;
}

.serviceItem_link:hover {
    opacity: .4;
}

.serviceItem_link .sub {
    display: block;
    font-size: 12px;
    margin-top: 4px;
}

.serviceItem_link::after {
    content: '';
    position: absolute;
    top: 24%;
    width: 31px;
    margin-left: 19px;
    background-size: contain;
    background-repeat: no-repeat;
    height: 26px;
    background-image: url(../img/logoarrow.svg);
    transition: right 0.3s;
}



#message {
    position: relative;
    padding: 0 0 180px 0;
}

#message .des {
    font-size: 17px;
    line-height: 30px;
    font-weight: 400;
    margin-bottom: 40px;
}

#message .des:last-child {
    margin-bottom: 0;
}

#message h3 {
    font-size: 39px;
    line-height: 60px;
    font-weight: 600;
    letter-spacing: .15em;
    margin-bottom: 40px;
}


#message .nameBox {
    margin-left: auto;
    margin-top: 93px;
    text-align: right;
}

#message .nameBox p {
    font-size: 14px;
    letter-spacing: .03em;
    text-align: left;
    display: inline-block;
    font-weight: 400;
}

#message .nameBox p span {
    font-size: 19px;
    line-height: 31px;
}





#message::before {
    content: "";
    top: 0;
    left: 0;
    bottom: -40%;
    width: 100%;
    position: absolute;
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 200px 106px;
    background-image: url(../img/noisebg.png);
    z-index: -1;
}

#message .conts {
    max-width: 1264px;
    margin: 0 auto;
}

.lineTitle {
    color: #202023;
    position: relative;
    margin-bottom: 60px;
    padding-bottom: 16px;
}

.lineTitle h2 {
    display: flex;
    justify-content: space-between;
    font-weight: 600;
}

.lineTitle::after {
    content: "";
    position: absolute;
    background: rgba(112, 112, 112, 0.5);
    width: 0;
    height: 1px;
    left: 0;
    bottom: 0;
    transition: 1.4s cubic-bezier(0.36, 0.14, 0, 1) 0s;
}

.lineTitle.scrollin::after {
    width: 100%;
}

.lineTitle .enTitle {
    font-size: 26px;
}

.lineTitle .jaTitle {
    font-size: 15px;
}

#message .loopSlideWrap {
    margin-top: -4px;
    overflow: hidden;
}

#message .loopSlide {
    display: flex;
    width: 100vw;
    height: 150px;
    position: relative;
    padding-bottom: 140px;
}

#message .loopSlide img:first-child {
    animation: slide3 240s -120s linear infinite;
}

#message .loopSlide img {
    width: auto;
    height: 100%;
}


#cta {
    padding: 130px 40px;
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
}

.ctaInner {
    display: flex;
    max-width: 1800px;
    margin: 0 auto;
    column-gap: 74px;
}

.ctaInner .ctaItem_bg {
    border-radius: 3px;
}

.ctaInner .ctaItem_bg img {
    width: 100%;
    border-radius: 3px;
}

.ctaInner .ctaItem {
    position: relative;
}

.ctaInner .ctaItem::after {
    content: "";
    background: rgba(32, 32, 35, 0.61);
    position: absolute;
    background-repeat: no-repeat;
    right: 0;
    top: 0;
    left: 0;
    bottom: 0;
    border-radius: 3px;
}

.ctaItem_content {

    color: #fff;

}

.ctaInner .frame {
    content: "";
    position: absolute;
    width: 10px;
    height: 10px;
    border-color: #fff;
    border-style: solid;
    top: -15px;
    left: -15px;
    border-width: 1px 0 0 1px;
}

.ctaInner .frame02 {
    top: -15px;
    left: auto;
    right: -15px;
    border-width: 1px 1px 0 0;
}

.ctaInner .frame03 {
    bottom: -15px;
    right: auto;
    top: auto;
    left: -15px;
    border-width: 0 0 1px 1px;
}

.ctaInner .frame04 {
    bottom: -15px;
    right: -15px;
    left: auto;
    top: auto;
    border-width: 0 1px 1px 0;
}

.ctaItem_head .jaTitle {
    font-size: 20px;
    font-weight: 500;
    display: block;
    margin-bottom: 23px;
}

.ctaItem_head .enTitle {
    font-size: 40px;
    display: block;
}


.ctaInner .ctaItem_head {
    position: absolute;
    z-index: 1;
    left: 46px;
    top: 44px;
}

.ctaInner .ctaItem_body {
    position: absolute;
    z-index: 1;
    bottom: 42px;
    left: 46px;
}

.ctaInner .ctaItem_body p {
    font-size: 16px;
    font-weight: 400;
}

.ctaInner .commonBtn {
    position: absolute;
    bottom: 20px;
    z-index: 1;
    right: 19px;
}




/* フッター全体 */
.site-footer {
    padding: 124px 0 64px 0;
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 200px 106px;
    background-image: url(../img/noisebg.png);
}





.footer-inner {}

/* --- 上段：ロゴとナビゲーション --- */
.footer-main {
    display: flex;
    padding: 0 80px;
    justify-content: space-between;
    gap: 60px;
    padding-bottom: 60px;
    max-width: 1500px;
    margin: 0 auto;
}

.footer-info {
    width: 30%;
}

.footer-logo {
    display: block;
    margin-bottom: 24px;
}

.footer-logo img {
    width: auto;
}

.footer-address {
    font-style: normal;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: .03em;
    line-height: 1.6;
}

.footer-address strong {
    display: block;
    font-weight: 600;
    margin-bottom: 14px;
    font-size: 14px;
}

/* 右側：ナビゲーション */
.footer-nav {
    flex-grow: 1;
    /* 残りのスペースをすべて使う */
    display: flex;
    /* 2つの列を横並びに */
    gap: 24px;
    /* 列と列の間の隙間 */
}

/* 各列のスタイル */
.footer-nav-col {
    flex: 1;
    /* 列の幅を均等に */
    display: flex;
    flex-direction: column;
    /* 列の中で項目を縦に並べる */
    gap: 40px;
    /* 項目（NEWSやSERVICEなど）の間の隙間 */
}

.nav-title {
    font-size: 21px;
    font-weight: bold;
    margin: 0 0 10px 0;
    letter-spacing: 0.03em;
}

.nav-group ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.nav-group li a {
    font-size: 14px;
    color: #79797B;
    position: relative;
    font-weight: 500;
    letter-spacing: .03em;
    padding-left: 1.0em;
}

/* リストの「・」を擬似要素で作成 */
.nav-group li a::before {
    content: '・';
    position: absolute;
    left: 0;
}

/* --- 下段：タグラインとコピーライト --- */
.footer-bottom {
    padding: 0 80px;
    padding-top: 60px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    max-width: 1500px;
    margin: 0 auto;
}

footer hr {
    height: 0;
    border-top: 1px solid #E0E0E0;
    margin: 40px 0;
}

.en-tag {
    font-size: 10px;
    font-weight: bold;
    letter-spacing: 0.05em;
    margin: 0 0 0 0;
}

.ja-tag {
    font-size: 65px;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: .14em;
    margin: 0;
}

.ja-tag .highlight {
    color: #7A78FF;
    /* ハイライトの色 */
}

.footer-copyright small {
    font-size: 14px;
    opacity: .5;
}

.footer-nav {
    flex-grow: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 62px 24px;
    align-items: start;
}

.footer-tagline .glSec {
    margin-left: 81px;
}

/* 1列目 */
.nav-group--news {
    grid-column: 2;
    grid-row: 1;
    /* 1行目に配置 */
}

.nav-group--service {
    grid-column: 2;
    grid-row: 2;
    /* 2行目に配置 */
}

/* 2列目 */
.nav-group--about {
    grid-column: 3;
    grid-row: 1;
    /* 1行目に配置 */
}

.nav-group--recruit {
    grid-column: 3;
    grid-row: 2;
    /* 2行目に配置 */
}

.nav-group--contact {
    grid-column: 3;
    grid-row: 3;
    /* 3行目に配置 */
}

#about {
    padding: 160px 0;
    background-position: 0 0;
    border-radius: 60px 60px 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
}


#about .commonTitle {
    text-align: center;
    margin-bottom: 120px;
}



#about .abCommonFlex {
    color: #fff;
    max-width: 1474px;
    margin: 0 auto;
    display: flex;
    column-gap: 8%;
    position: relative;
    padding: 0 40px;
}

#about .abCommonFlex::after {
    content: "MISSION";
    position: absolute;
    right: 0;
    left: 0;
    margin: 0 auto;
    text-align: center;
    font-size: 11vw;
    white-space: nowrap;
    top: 29%;
    font-family: "Syncopate", sans-serif;
    font-weight: 700;
    font-style: normal;
    color: rgba(255, 255, 255, 0.01);
}


#about .abCommonFlex02::after {
    content: "VISION";
    font-size: 11vw;
}

#about .abCommonFlex03::after {
    content: "VALUE";
    font-size: 11vw;
}

#about .imgBox img {
    width: 100%;
}

#about .imgBox {
    width: 50%;
    position: relative;
    z-index: 1;
}

#about .textBox {
    width: 50%;
    position: relative;
    z-index: 1;
}

#about .textBox .enTitle {
    font-size: 18px;
    margin-bottom: 26px;
}

.abCommonFlex01 .textBox .enTitle {
    color: #56B1A0;
}

.abCommonFlex02 .textBox .enTitle {
    color: #3D95F6;
}

.abCommonFlex03 .textBox .enTitle {
    color: #319DCE;
}

#about .textBox h3 {
    font-size: 39px;
    line-height: 60px;
    letter-spacing: .15em;
    margin-bottom: 52px;
    font-weight: 500;
}

#about .textBox h3 span {
    display: inline-block;
}

.abCommonFlex01 .textBox h3 span {
    color: #56B1A0;
}

.abCommonFlex02 .textBox h3 span {
    color: #3D95F6;
}

.abCommonFlex03 .textBox h3 span {
    color: #319DCE;
}

#about .textBox .des {
    font-size: 16px;
    line-height: 32px;
    margin-bottom: 31px;
    letter-spacing: .07em;
    font-weight: 300;
}

#about .textBox .des:last-child {
    margin-bottom: 0;
}


.abspacer {
    width: 100%;
    margin: 134px auto;
    height: 1px;
    background-image: repeating-linear-gradient(to right,
            #48484D,
            #48484D 5px,
            /* ダッシュの長さ */
            transparent 5px,
            transparent 10px
            /* ダッシュの間隔 */
        );
}

/* カードコンテナ */
.values-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 30px;
    max-width: 1400px;
    margin: 0 auto;
    margin-top: 141px;
}

.card {
    background-color: #202023;
    border: 1px solid;
    border-radius: 15px;
    padding: 40px 44px;
    width: 100%;
    max-width: 31%;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
}

.badge {
    display: inline-block;
    padding: 6px 13px 5px 13px;
    border-radius: 100vw;
    font-size: 10px;
    font-weight: bold;
    color: #fff;
    text-align: center;
    margin: 0 auto;
    line-height: 1;
    margin-bottom: 20px;
    align-self: flex-start;
    font-family: "Syncopate", sans-serif;
    font-weight: 700;
    font-style: normal;
}

.card h3 {
    font-size: 34px;
    text-align: center;
    color: #fff;
    margin-top: 0;
    font-weight: 500;
    margin-bottom: 38px;
}

/* カード説明文 */
.card p {
    font-size: 16px;
    line-height: 32px;
    color: #fff;
    font-weight: 400;
}

/* 各カードの配色 */
.card-accountability {
    border-color: #00A652;
}

.card-accountability .badge {
    background-color: #00A652;
}

.card-essence {
    border-color: #7A78FF;
}

.card-essence .badge {
    background-color: #7A78FF;
}

.card-integrity {
    border-color: #FFC412;
}

.card-integrity .badge {
    background-color: #FFC412;
}

.card-teamwork {
    border-color: #FE6B20;
}

.card-teamwork .badge {
    background-color: #FE6B20;
}

.card-innovation {
    border-color: #0059A6;
}

.card-innovation .badge {
    background-color: #0059A6;
}

.messageInner {
    padding: 0 80px;
}

.commonBtnPc {
    display: block;
}

.commonBtnSp {
    display: none;
}

.fixBtn {
    display: none;
}



#udhero {
    padding: 200px 8% 78px 8%;
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
    position: relative;
}

#udhero::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background-color: rgba(112, 112, 112, 0.5);
    transition: 1.4s cubic-bezier(0.36, 0.14, 0, 1) .4s;
}

#udhero.scrollin::after {
    width: 100%;
}




/*==================================================
---form
====================================================*/
.form {
    max-width: 1200px;
    margin: 0 auto;
    margin-bottom: 11px;
    box-sizing: content-box;
    position: relative;
    border-radius: 3px;
}

.form .radioBox {
    display: flex;
    align-items: center;
    column-gap: 28px;
}

.form .radioBox input {
    width: 26px;
    font-size: 16px;
    height: 26px;
    background: #f5f5f5;
    border: 1px solid #deebf5;
    border-radius: 100vw;
    padding: 0;
    margin: 0;
}

.form .radioBox span {
    font-size: 16px;
    color: #000;
    margin-top: 0px;
    margin-left: 3px;
    display: inline-block;
    position: relative;
    top: 3px;
}

.inputBg input[type="radio"] {
    appearance: none;
    /* デフォルトのスタイルをリセット */
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: #f5f5f5;
    /* 背景色を変更 */
}

.inputBg input[type="radio"]:checked {
    background-color: #0485d9;
    border: solid 5px #f5f5f5;
}

.formOpBox {
    text-align: center;
    margin-bottom: 62px;
}

.formOpBox h3 {
    font-size: 32px;
    color: #364c8e;
    margin-bottom: 24px;
}

.formOpBox p {
    font-size: 16px;
    line-height: 30px;
    font-weight: 600;
    letter-spacing: 0.05em;
}

.formSchoolBox {
    width: 100%;
}

.formSchoolBox .inputBg {
    margin-bottom: 10px;
}

.form .des {
    line-height: 30px;
    margin-top: 34px;
    margin-bottom: 45px;
    font-weight: 400;
    font-size: 16px;
}

.form_flexBox {
    padding-bottom: 39px;
    margin-bottom: 24px;
}

.form_flexBox:first-child {
    padding-top: 42px;
}

.form_flexBox_list {
    position: relative;
    font-weight: 500;
    color: #fff;
    letter-spacing: 0.06em;
    padding-top: 0;
    margin-bottom: 6px;
    font-size: 17px;
}

.mandatory {
    position: absolute;
    right: 25px;
    color: #fff;
    top: 16px;
    font-size: 13px;
    border-radius: 3px;
    background: #0072c4;
    padding: 1px 20px;
}

.any {
    position: absolute;
    right: 25px;
    color: #fff;
    top: 16px;
    font-size: 13px;
    border-radius: 3px;
    background: #949da5;
    padding: 1px 20px;
}

.inputBg {
    width: 100%;
}

input {
    width: 100%;
    box-sizing: border-box;
    font-size: 16px;
    height: 70px;
    font-weight: 600;
    background: #313134;
    padding: 0 27px;
    border: none;
    border-radius: 5px;
}

.mwform-tel-field input[type="text"],
.mwform-zip-field input[type="text"] {
    color: #fff;
}

input[type="text"] {
    color: #fff;
}

::placeholder {
    color: rgba(255, 255, 255, 0.50);
    font-weight: 500;
}

textarea {
    width: 100%;
    box-sizing: border-box;
    background: #313134;
    font-size: 16px;
    color: #fff;
    border: none;
    padding: 22px 27px;
}

.privacypBox {
    text-align: center;
}

.form .privacyp {
    display: inline-block;
    font-size: 15px;
    font-weight: 100;
    margin-bottom: 31px;
}

.form .privacyp a {
    text-decoration: underline;
    color: #364c8e;
}

.form .nmber {
    font-size: 25px;
    color: #011640;
}

.checkbox {
    display: flex;
    max-width: 873px;
    margin: 0 auto;
    color: #fff;
}

.checkbox input {
    width: 27px;
    height: 27px;
    border-radius: 6px;
    padding: 0;
    margin-top: -3px;
    -webkit-appearance: none;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    border: 2px solid #ccc;
    background: #ffffff;
    position: relative;
    cursor: pointer;
}

.checkbox input:checked::after {
    content: "";
    position: absolute;
    left: 7px;
    top: 1px;
    width: 6px;
    height: 13px;
    /* background: red; */
    border: solid #7A78FF;
    border-width: 0 4px 4px 0;
    transform: rotate(45deg);
}

.checkbox p {
    text-align: center;
    font-weight: 500;
}

.form_contentBox {
    margin-bottom: 50px;
    max-width: 873px;
    margin: 0 auto;
    font-size: 15px;
}

.submitBox {
    margin: 0 auto;
    display: flex;
    max-width: 600px;
    margin: 0 auto;
    margin-top: 48px;
}

.submitBox input {
    color: #fff;
    font-size: 16px;
    border-radius: 100vw !important;
    height: 75px;
    letter-spacing: 0.06em;
    max-width: 300px;
    cursor: pointer;
    font-weight: 600;
    transition: 0.4s;
    margin: 0 auto;
    background: #7A78FF;
}

.submitBox input:hover {
    opacity: 0.6;
}

.mw_wp_form .error {
    font-size: 13px;
    margin-top: 3px;
}

.thanyouMail {
    max-width: 750px;
    margin: 0 auto;
    padding-bottom: 156px;
    padding: 0 25px;
    padding-top: 90px;
}

.thanyouMail .commonBtn a {
    margin: 0 auto;
}

.thanyouMail h3 {
    font-size: 30px;
    margin-bottom: 25px;
    color: #0072c4;
}

.thanyouMail p {
    line-height: 30px;
    color: #333;
    font-weight: 500;
    font-size: 14px;
}

.mw_wp_form_complete {
    background: #f7f5ef;
}

.thanyouMail .blackBtn {
    margin: 0 auto;
    margin-top: 25px;
}

.thanyouMail .cmmnBtn {
    text-align: center;
    margin-top: 25px;
}

.mw_wp_form .error {
    font-size: 78% !important;
    position: absolute;
}

input[type="text"] {
    -webkit-appearance: none;
    border-radius: 0;
    border-radius: 5px;
}

textarea {
    -webkit-appearance: none;
    border-radius: 0;
    border-radius: 5px;
}

select {
    width: 100%;
    box-sizing: border-box;
    height: 70px;
    font-size: 16px;
    background: #313134;
    font-weight: 500;
    color: #fff;
    border: none;
    padding: 0 27px;
    border-radius: 6px;
}

input[type="submit"],
input[type="button"] {
    border-radius: 0;
    -webkit-box-sizing: content-box;
    -webkit-appearance: button;
    appearance: button;
    box-sizing: border-box;
    cursor: pointer;
}

form {
    padding: 100px 80px;
    padding-bottom: 168px;
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
    position: relative;
}

form .aten {
    font-size: 13px;
    line-height: 25px;
    color: #525252;
}

input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
    display: none;
}

input[type="submit"]::focus,
input[type="button"]::focus {
    outline-offset: -2px;
}

.mwform-radio-field-text {
    font-weight: 600;
    color: #525252;
}

.submitBox .button_back {
    background: #afafaf;
    border: solid 1px #d3d2d2;
    margin: 0 5px;
    color: #fff;
}

.mw_wp_form_preview .form_flexBox_list {
    padding-top: 0;
}

.mw_wp_form_preview .mandatory {
    top: -3px;
}

.mw_wp_form_preview .any {
    top: -3px;
}

.mw_wp_form_preview .submitBox {
    width: auto;
    margin-bottom: 30px;
    margin-top: 20px;
}

#privacyPolicy {
    max-width: 1025px;
    margin: 0 auto;
    padding: 0 25px;
}

.birthBgBox {
    display: flex;
}

.birthBgBox > div {
    width: 50%;
}

.birthBgBox input {
    width: 90%;
}

.selectinner {
    position: relative;
}

.selectinner::after {
    position: absolute;
    position: absolute;
    content: "";
    background-image: url(../img/selectArrow.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: 16px;
    height: 23px;
    top: 63%;
    left: 77%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.selectinnerEntry::after {
    left: auto;
    right: 18px;
}

/*
.selectinner span {
    position: absolute;
}
*/

.birthBgBox select {
    width: 90%;
}

select {
    -webkit-appearance: none;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.mw_wp_form_preview .privacypBox {
    display: none;
}

.mw_wp_form_preview .checkbox p {
    position: relative;
    -webkit-backface-visibility: hidden;
    font-weight: 500;
}

.mw_wp_form_preview .checkbox p::before {
    position: absolute;
    content: "";
    background-image: url(../img/privacypolicyCheck.png);
    background-size: contain;
    background-repeat: no-repeat;
    width: 43px;
    height: 42px;
    top: 50%;
    left: 13px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.privacyAge {
    text-align: right;
    font-weight: bold;
    text-decoration: underline;
}

.inactive {
    color: #d8d8d8;
}

.radioiinput input {
    width: 6%;
    height: 22px;
    margin-bottom: 7px;
}

.documentinput label {
    display: flex;
    justify-content: left;
    margin-bottom: -16px !important;
}

.thanyouMail .commonBtn {
    text-align: center;
    margin-top: 20px;
}

.mw_wp_form_preview .selectinner::after {
    display: none;
}

.priLinkP {
    text-align: center;
    font-size: 16px;
    line-height: 30px;
    letter-spacing: 0.06em;
    margin-bottom: 14px;
    font-weight: 400;
}

.priLinkP a {
    display: inline-block;
    text-decoration: underline;
}

.redC {
    display: inline-block;
    color: #E75400;
    font-size: 10px;
    letter-spacing: 0.06em;
}

.mw_wp_form_preview .inputBg {
    width: 100%;
    color: #7a78ff;
    text-decoration: underline;
}

.mw_wp_form_preview .priLinkP {
    display: none;
}

.mw_wp_form_preview .submitBox input {
    height: 67px;
}

.mw_wp_form .error {
    color: #b70000 !important;
    letter-spacing: 0.06em;
}

.calendarBox .selectinnerEntry::after {
    display: none;
}

.calendarBox input {
    width: 50%;
}

.ui-datepicker-title select {
    height: 31px;
    font-weight: 500;
}

#autozip a {
    background: #ffb302 !important;
    font-weight: 600;
    color: #ffffff !important;
    padding: 3px 11px;
    letter-spacing: 0.06em;
}

#autozip {
    display: none !important;
}

.mw_wp_form .priLinkP .error {
    display: inline-block;
    margin-top: 23px;
}

span.mwform-tel-field {
    color: #fff;
}

.thanksBox {
    color: #fff;
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
    position: relative;
}

.thanksBoxIner {
    margin: 0 auto;
    padding: 80px 8%;
}

.thanksBoxIner p {
    color: #fff;
    font-weight: 500;
}


.BlogSingleCont {
    padding: 220px 80px 80px;
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
    position: relative;
}

.BlogSingleContInner {
    max-width: 1002px;
    margin: 0 auto;
}

.BlogSingleContInner .image-wrapper {
    border-radius: 8px;
    margin-bottom: 32px;
}

.BlogSingleContInner .image-wrapper img {
    width: 100%;
    border-radius: 8px;
    height: auto;
}

.BlogSingleContInner .tagBox {
    display: flex;
    margin-top: 30px;
    column-gap: 18px;
}

.BlogSingleContInner .cat {
    line-height: 1;
    display: inline-block;
    border-radius: 100vw;
    color: #fff;
    font-size: 13px;
    letter-spacing: 0.03em;
    border-radius: 100vw;
    box-sizing: border-box;
    padding: 6px 14px;
    border: #585858 solid 1px;
    font-weight: 600;
    background: #202023;
}

.BlogSingleContInner .tagBox .day {
    color: #fff;
    letter-spacing: 0;
    opacity: 0.6;
    font-size: 10px;
    margin-top: 2px;
}

.BlogSingleContInner .article-title {
    font-size: 33px;
    color: #fff;
    margin-top: 25px;
    font-weight: 500;
    line-height: 45px;
}

.BlogSingleContInner .blog-main {
    margin-bottom: 118px;
}

.BlogSingleContInner ul {
    list-style-position: inside;
    margin-top: 24px;
    font-weight: 300;
}

.BlogSingleContInner .mainContents {
    color: #fff;
}

.BlogSingleContInner .mainContents h2 {
    font-size: 26px;
    font-weight: 500;
    line-height: 56px;
    position: relative;
    padding-top: 12px;
    margin-top: 40px;
}

.BlogSingleContInner .mainContents h3 {
    font-size: 21px;
    font-weight: 500;
    line-height: 48px;
    position: relative;
    margin-top: 40px;
}


.BlogSingleContInner .mainContents p {
    margin-top: 24px;
    font-weight: 300;
    font-size: 16px;
    line-height: 30px;
}

.BlogSingleContInner .mainContents h2::after {
    content: "";
    position: absolute;
    background: #7A78FF;
    width: 31px;
    height: 5px;
    left: 0;
    top: 0;
}

.BlogSingleContInner .mainContents a {
    display: inline-block;
    color: #7A78FF;
    text-decoration: underline;
}


.BlogSingleContInner figure {
    margin-top: 28px;
}

.certifWrap {
    padding: 80px 80px 78px 80px;
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
    position: relative;
}

.certifWrapInner {
    max-width: 1115px;
    margin: 0 auto;
    color: #fff;
}

.certifWrapInner .ceOpfBox {
    margin-bottom: 94px;
    text-align: center;
}

.ceOpfBox h2 {
    font-size: 24px;
    font-weight: 500;
    line-height: 40px;
    margin-bottom: 40px;
}

.certifBtn {
    display: flex;
    height: 88px;
    font-size: 18px;
    align-items: center;
    justify-content: center;
    border: solid 2px #fff;
    border-radius: 8px;
    max-width: 374px;
    margin: 0 auto;
    margin-top: 36px;
    transition: .35s;
}

.certifBtn:hover {
    background: #7A78FF;
    border: solid 2px #7A78FF;
}

.ceOpfBox p {
    font-size: 16px;
    line-height: 34px;
    margin-bottom: 24px;
    font-weight: 500;
}

.ceOpfBox p:last-child {
    margin-bottom: 0;
}



#certiCont .certi-section {
    background-color: rgba(255, 255, 255, 0.10);
    border-radius: 16px;
    padding: 48px 55px;
    border: solid 1px rgba(122, 120, 255, 0.46);
    margin-bottom: 14px;
    display: flex;
}

#certiCont .section-title {
    display: inline-block;
    background-color: #7A78FF;
    color: #ffffff;
    font-size: 17px;
    font-weight: 500;
    padding: 10px 26px;
    border-radius: 50px;
    margin-top: 0;
    margin-bottom: 25px;
    min-width: 136px;
    text-align: center;
}

#certiCont .sectionTWrap {
    width: 534px;
}

/* List Styling */
#certiCont .certi-list {
    list-style-type: none;
    padding-left: 0;
    margin: 0;
}

#certiCont .certi-list li {
    position: relative;
    padding-left: .8em;
    font-weight: 400;
    margin-bottom: 8px;
}

#certiCont .certi-list li::before {
    content: '・';
    position: absolute;
    left: 0;
}

#certiCont .certi-listNox li::before {
    display: none;
}

#certiCont .certi-listNox li {
    padding-left: 0;
}



/* Procedure Section */
#certiCont .procedure-list {
    list-style-type: none;
    padding-left: 0;
    width: 100%;
    counter-reset: procedure-counter;
}

#certiCont .procedure-list > li {
    counter-increment: procedure-counter;
    margin-bottom: 25px;
    position: relative;
}


#certiCont .procedure-list p {
    margin-top: 0;
    font-weight: 500;
    margin-bottom: 16px;
    line-height: 30px;
}

#certiCont .info-box {
    background-color: rgba(0, 0, 0, 0.25);
    border-radius: 6px;
    padding: 25px 40px;
    margin-top: 8px;
}

#certiCont .info-box-title {
    font-weight: bold;
    color: #7A78FF;
    margin-top: 0;
    font-weight: 500;
    margin-bottom: 8px;
}

#certiCont strong {
    font-weight: 500;
}

#certiCont .info-box .certi-list li {
    margin-bottom: 3px;
    font-weight: 400;
}

#certiCont .info-box p {
    margin: 0;
}

#certiCont .note {
    font-size: 13px;
    color: #ffffff;
    margin-top: 15px;
    font-weight: 400 !important;
}

#certiCont .note02 {
    font-size: 13px;
    margin-top: -14px !important;
}

#certiCont .fee-table {
    width: 100%;
    border-collapse: separate;
    margin-top: 15px;
    border-radius: 8px;
}

#certiCont .fee-table th,
#certiCont .fee-table td {
    padding: 12px 32px;
    font-weight: 400;
    text-align: center;
}

#certiCont .fee-table th:first-child {
    border-right: solid 1px #fff;
    border-radius: 6px 0 0 0;

}

tbody tr td:last-child {
    border-left: none !important;
}

tbody tr:last-child td {
    border-top: none !important;
}

tbody tr:last-child td:first-child {
    border-radius: 0 0 0 6px;
}

tbody tr:last-child td:last-child {
    border-radius: 0 0 6px 0;
}

#certiCont .fee-table th:last-child {
    border-radius: 0 6px 0 0;
}

#certiCont .fee-table td {
    border: 1px solid #ffffff;
}

#certiCont .fee-table th {
    background-color: #7A78FF;
    color: #fff;
    text-align: center;
}

#certiCont .fee-table td:last-child {
    text-align: center;
}

.bank-info {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 5px 15px;
    font-weight: 400;
}

.bank-info dt {
    font-weight: 400;
}

.bank-info dd {
    margin: 0;
}

.yscAten {
    display: none;
}

.recruitWrap {
    background-position: 0 0;
    background-repeat: repeat;
    background-size: 273px 279px;
    background-image: url(../img/noiseB.png);
}


.scroll-infinity__wrap {
    display: flex;
    overflow: hidden;
    padding-top: 184px;
    padding-bottom: 20px;
    column-gap: 40px;
}

.scroll-infinity__list {
    display: flex;
    list-style: none;
    padding: 0;
    column-gap: 40px;
}

.scroll-infinity__list--left {
    animation: infinity-scroll-left 80s infinite linear 0.5s both;
}

.scroll-infinity__item {
    width: 732px;
    border-radius: 8px;
}

.scroll-infinity__item > img {
    width: 100%;
    border-radius: 8px;
    object-fit: cover;
    height: auto;
}

@keyframes infinity-scroll-left {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-100%);
    }
}

.recruitWrap {
    color: #fff;
}

.recruitOpBox {
    padding: 136px 80px;
    150px 80px
}

.recruitOpBox .tiltBox .enTitle {
    font-size: 12px;
    margin-bottom: 31px;
    color: #7A78FF;
    display: block;
}

.recruitOpBox .tiltBox .ja {
    display: block;
    font-size: 46px;
    line-height: 75px;
    letter-spacing: .08em;
    font-weight: 500;
}

.recruitOpBox .flexBox {
    display: flex;
    column-gap: 148px;
    max-width: 1264px;
    margin: 0 auto;
    position: relative;
}

.recruitOpBox .bgEnh {
    position: absolute;
    font-size: 120px;
    left: -221px;
    line-height: 106px;
    opacity: .03;
    text-transform: uppercase;
    top: -100px;
}

.recruitOpBox .textBox p {
    font-size: 18px;
    font-weight: 300;
    line-height: 36px;
    margin-bottom: 40px;
}

.recruitOpBox .textBox p:last-child {
    margin-bottom: 0;
}

.recruitOpBox .textBox {
    margin-top: 66px;
}

.recMessege {
    background: #171C22;
    padding: 150px 80px 0 80px;
}

.recMessegeInner {
    max-width: 1264px;
    margin: 0 auto;


}

.recMessegeInner .lineTitle .enTitle {
    font-size: 26px;
    color: #7A78FF;
    text-transform: uppercase;
}

.recMessegeInner .lineTitle .jaTitle {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.5);
}


.recMessegeInner#message .des {
    font-weight: 300;
}

.recMessegeInner#message h3 {
    font-weight: 500;
}

.recruitInfo {
    padding: 150px 80px;
}

.recruitInfo .FlexBox {
    display: flex;
    column-gap: 200px;
    max-width: 1264px;
    margin: 0 auto;
}

.recruitInfo .FlexBox .inDexBox a {
    display: block;
    font-size: 16px;
    font-weight: 400;
    width: 170px;
    position: relative;
    border-bottom: solid 1px rgba(255, 255, 255, 0.40);
    padding-bottom: 8px;
    margin-bottom: 24px;
}

.recruitInfo .FlexBox .inDexBox a::after {
    content: "";
    position: absolute;
    background-image: url(../img/indexarrow.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: 19px;
    height: 14px;
    right: 0;
    top: 10px;
}

.recruitInfo .conBoxWrap {
    width: 100%;
}


.recruitInfo .commonConBox .enTitle {
    color: #7A78FF;
    text-transform: uppercase;
}

.recruitInfo .lineTitle .jaTitle {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.5);
}


#Candidate .opDes {
    font-size: 22px;
    font-weight: 500;
    letter-spacing: .08em;
}

.canArrwo {
    text-align: center;
    margin: 28px 0;
}

.recruitInfo .flexCard {
    display: flex;
    justify-content: space-between;
    gap: 16px 16px;
    flex-wrap: wrap;
}

.recruitInfo .flexCard > div {
    border-radius: 16px;
    background: #00A652;
    box-sizing: border-box;
    width: 49%;
    padding: 24px 24px 35px 35px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.recruitInfo .flexCard > div:nth-child(2) {
    background: #7A78FF;
}

.recruitInfo .flexCard > div:nth-child(3) {
    background: #F5BE18;
}

.recruitInfo .flexCard > div:nth-child(4) {
    background: #FE6B20;
}

.recruitInfo .flexCard > div:nth-child(5) {
    background: #0059A6;
}

.recruitInfo .flexCard > div:nth-child(6) {
    background: #E0425A;
}

.recruitInfo .flexCard > div:nth-child(7) {
    background: #A64600;
}

.recruitInfo .flexCard > div:nth-child(8) {
    background: #B542E0;
}

.recruitInfo .flexCard > div:nth-child(9) {
    background: #00A0A6;
}

.recruitInfo .flexCard > div:nth-child(10) {
    background: #E0B542;
}

.recruitInfo .flexCard .nam {
    text-align: right;
    margin-bottom: 28px;
}

.recruitInfo .flexCard h3 {
    font-size: 22px;
    line-height: 36px;
    flex-grow: 1;
    font-weight: 500;
    margin-bottom: 16px;
    margin-top: auto;
    vertical-align: top;
    display: flex;
    align-items: end;
}

.recruitInfo .flexCard p {
    font-size: 15px;
    font-weight: 300;
    line-height: 28px;
    flex-grow: 1;
}

.inDexBox > div {
    position: sticky;
    top: 50%;
}

.recruitInfo .commonConBox {
    margin-bottom: 200px;
}

.recruitInfo .commonConBox:last-child {
    margin-bottom: 0;
}




.accordion-item {}

.accordion-item {
    margin-bottom: 10px;
}

.accordion-content .flex {
    display: flex;
}

.accordion-item ul {
    list-style-position: inside;
    position: relative;
    list-style: none;
}

.accordion-item strong {
    color: #0068ae;
    margin-bottom: -30px;
    display: block;
}

.accordion-item em {
    font-size: 13px;
    font-style: normal;
}

.accordion-content ol li {
    list-style-position: inside;
}

.accordion-title::after {
    transform: rotate(90deg);
}

.accordion-title.open::after,
.accordion-title.open::before {
    background-color: #fff;
}

.accordion-title::after,
.accordion-title::before {
    content: "";
    position: absolute;
    right: 40px;
    top: 44px;
    width: 3px;
    height: 21px;
    background-color: #7A78FF;
    transition: all 0.3s;
}

.accordion-title {
    border: solid 1px rgba(112, 112, 112, 0.5);
    font-size: 16px;
    display: flex;
    color: #fff;
    font-weight: 500;
    font-size: 22px;
    cursor: pointer;
    border-radius: 4px;
    padding: 38px 61px 38px 40px;
    transition: 0.4s;
    position: relative;
}

.accordion-content {
    display: none;
    margin-top: 58px;
}

.accordion-title.open {
    background: #7A78FF;
}

.positionDl section:first-child {
    border-top: solid 1px rgba(112, 112, 112, 0.5);
}

.positionDl section {
    display: flex;
    gap: 5px 15px;
    font-weight: 400;
    padding: 60px 0;
    justify-content: space-between;
    border-bottom: solid 1px rgba(112, 112, 112, 0.5);
}

.positionDl section h3 {
    width: auto;
    font-size: 18px;
    font-weight: 400;
}

.positionDl section > div {
    width: 66%;
}

.positionDl section > div p {
    font-size: 15px;
    line-height: 28px;
    font-weight: 400;
    margin-bottom: 27px;
}

.positionDl section > div p:last-child {
    margin-bottom: 0;
}

.positionDl section > div ul {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 6px;
    margin-bottom: 20px;
}

.accordion-title.open::before {
    transform: rotate(90deg) !important;
}

.positionDl section > div a {
    display: inline-block;
    text-decoration: underline;
    color: #7A78FF;
}

.positionDl section > div ul li {
    background: #7A78FF;
    padding: 11px 14px;
    font-size: 15px;
    line-height: 1;
    box-sizing: border-box;
    border-radius: 4px;
    color: #fff;
}

.accordion-content .programSlide {
    overflow: hidden;
    position: relative;
    border-radius: 4px;
    margin: 0 auto;
    max-width: 600px;
    margin-bottom: 50px;
}

.accordion-content .swiper-wrapper {
    border-radius: 4px;
}

.accordion-content .programSlide .imgBox {
    border-radius: 4px;
}

.accordion-content .swiper-pagination-bullet {
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 10px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 10px));
    display: inline-block;
    border-radius: 50%;
    background: var(--swiper-pagination-bullet-inactive-color, #fff);
    opacity: var(--swiper-pagination-bullet-inactive-opacity, .4);
}

.accordion-content .swiper-pagination-bullet-active {
    background: #fff !important;
    opacity: 1;
}

.accordion-content .programSlide .imgBox img {
    width: 100%;
    max-width: 600px;
    aspect-ratio: 16/ 9;
    border-radius: 4px;
    object-fit: cover;
}

.accordion-content .programSlide .swiper-slide {
    overflow: hidden;
    border-radius: 6px;
    margin-bottom: 55px;
}


.entryBtn {
    height: 76px;
    background: #7A78FF;
    border-radius: 8px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff !important;
    font-size: 21px;
    max-width: 542px;
    margin: 0 auto;
    margin-top: 61px;
    transition: .35s;
    border: solid 1px #7A78FF;

}

.accordion-content {
    margin-bottom: 40px;
}

.entryBtn:hover {
    background: #000;
}


#Welfare section {
    display: flex;
    align-items: center;
    column-gap: 48px;
    padding: 36px 0;
    border-bottom: solid 1px rgba(112, 112, 112, 0.5);
}

#Welfare .iconBox img {
    width: 78px;
}

#Welfare section h3 {
    font-size: 18px;
    font-weight: 400;
    margin-bottom: 14px;
}

#Welfare section .textBoxer p {
    font-size: 15px;
    font-weight: 400;
    line-height: 28px;
}

#faq .accordion-title .enFont {
    font-size: 26px;
    margin-right: 14px;
    margin-top: 4px;
    display: block;
    color: #7A78FF;
}

#faq .accordion-content {
    background: #f8f8f8;
    padding: 36px 40px;
    border-radius: 0 0 4px 4px;
    margin-top: -4px;
    color: #000000;
    font-weight: 400;
}

#faq .accordion-title.open .enFont {
    color: #fff;
}

#faq .accordion-content .flex {
    display: flex;
}

#faq .accordion-content .enFont {
    font-size: 26px;
    margin-right: 14px;
    color: #7A78FF;
    margin-top: 2px;
    display: block;
}

.udnewslistwrap .newsInner {
    display: flex;
    gap: 128px 2%;
    flex-wrap: wrap;
}

.udnewslistwrap .newsInner a {
    width: 32%;
}

.udnewslistwrap .newsInner {
    max-width: 1280px;
    margin: 0 auto;
}






.udnewslistwrap .catBox {
    max-width: 1280px;
    margin: 0 auto;
    margin-bottom: 40px;
}

.udnewslistwrap .catBox ul {
    list-style: none;
    gap: 8px;
    display: flex;
}

.udnewslistwrap .catBox ul li {}

.udnewslistwrap .catBox ul a {
    display: block;
    text-align: center;
    border-radius: 100vw;
    color: #ffffff;
    background: #2b2b2b;
    border: solid 1px #585858;
    font-size: 13px;
    transition: .4s;
    padding: 7px 0;
    font-weight: bold;
    padding: 6px 40px;
    margin-bottom: 8px;
}

.udnewslistwrap .catBox ul a:hover {
    opacity: .5;
}

.udnewslistwrap .catBox ul .catAc a {
    background: #000;
    color: #fff;
}

.udnewslistwrap .catBox ul .catAc a {
    background: #7a78ff;
    color: #fff;
    border: solid 1px #7a78ff;
}

.udnewslistwrap .catBox .commonTitle {
    margin-bottom: 28px;
}


.udnewslistwrap .catBox ul .current-cat a {
    background: #7a78ff;
    color: #fff;
    border: solid 1px #7a78ff;
    transition: .4s;
}

#privacy {
    padding: 0 80px;
    padding-bottom: 120px;
    color: #fff;
    padding-top: 64px;
}

.privacyInner {
    max-width: 900px;
    margin: 0 auto;
}

#privacy h3 {
    font-size: 24px;
    font-weight: 600;
    color: #fff;
    letter-spacing: 0.06em;
    margin-bottom: 5px;
    padding-bottom: 9px;
}

#privacy .des {
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.12em;
    color: #fff;
    line-height: 2.4em;
}

#privacy li {
    letter-spacing: 0.12em;
    color: #fff;
    font-weight: 400;
    line-height: 2.4em;
}

#privacy ul {
    margin-top: 28px;
    letter-spacing: 0.06em;
    font-size: 14px;
    line-height: 30px;
    list-style: none;
}

#privacy ul ul {
    margin-top: 4px;
    margin-left: 20px;
}

#privacy ul span {
    display: block;
}

#privacy .poliBox {
    margin-bottom: 48px;
}

#privacy .priConta .des {
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.12em;
    color: #fff;
    line-height: 1.8em;
}

#privacy .priConta {
    margin-top: -30px;
}

#privacy .priConta .des a {
    display: inline-block;
    color: #7A78FF;
    text-decoration: underline;
}







@media screen and (max-width: 1550px) {
    #hero .loopSlide {
        height: 108px;
    }

    #news.udnewslistwrap {
        padding: 88px 80px 128px 80px;
    }

    .accordion-title::after,
    .accordion-title::before {
        top: 39px;
    }

    .scroll-infinity__item {
        width: 462px;
    }

    .positionDl section > div {
        width: 68%;
    }

    .recruitInfo .FlexBox {
        column-gap: 160px;
    }

    .accordion-title {
        padding: 34px 61px 34px 40px;
    }

    .recruitInfo .flexCard {
        gap: 16px 2px;
    }

    .recruitOpBox .bgEnh {
        font-size: 98px;
        left: -114px;
        line-height: 106px;
        opacity: .03;
    }

    .recruitOpBox .textBox p {
        margin-bottom: 34px;
    }

    .BlogSingleCont {
        padding: 184px 80px 80px;
    }

    .BlogSingleContInner {
        max-width: 878px;
        margin: 0 auto;
    }

    .values-container {
        margin-top: 105px;
    }

    #about .abCommonFlex {
        padding: 0 80px;
    }

    #message .loopSlide {
        height: 111px;
    }

    .singlepostnavi {
        padding-bottom: 60px;
    }

    #message {
        padding: 0 0 154px 0;
    }

    .serviceItem {
        height: auto;
        padding-bottom: 89px;
    }

    .serviceItem_right {
        margin-top: 30px;
    }

    .serviceItem_left,
    .serviceItem_right {
        padding: 56px 0 0 0;
    }

    .serviceItemWrap {
        padding: 0 6%;
    }

}



@media screen and (max-width: 1280px) {
    .serviceItem_right {
        width: 53%;
    }

    .serviceItem {
        column-gap: 48px;
    }
}



@media screen and (max-width: 768px) {
    body {
        min-width: auto;
    }

    .humFlow span:nth-of-type(2) {
        display: none;
    }

    .menu__line {
        height: 1px;
    }

    .hLogo img {
        width: 120px;
    }

    #hero h2 {
        right: 0;
        left: 0;
        bottom: 24%;
    }

    .serviceItem {
        display: block;
    }

    .serviceItem_right {
        width: auto;
    }

    .serviceItem_left {
        width: auto;
    }

    .serviceItemWrap {
        padding: 0 16px;
    }

    .commonTitle .enTitle {
        font-size: 54px;
    }

    #news {
        padding: 80px 32px;
    }

    .gnav__wrap .nav-title {
        font-size: 20px;
        color: #fff;
        margin: 0 0 4px 0;
    }

    .menu_box {
        position: absolute;
        right: 12px;
        top: 11px;
        background: #2C2C32;
        border-radius: 3px;
        height: 50px;
        width: 50px;
    }

    .commonTitle .jaTitle {
        font-size: 16px;
        margin-bottom: 28px;
    }

    #hero .scrolldwn {
        width: 128px;
        height: 128px;
        bottom: 34px;
        left: 0;
        right: 0;
        margin: 0 auto;
    }

    #about {
        padding: 120px 0;
        border-radius: 24px 24px 0 0;
    }

    #service .commonTitle {
        margin-bottom: 64px;
    }

    #service {
        padding: 120px 0;
    }

    .serviceItem_desc {
        font-size: 14px;
        line-height: 30px;
    }

    .serviceItem {
        padding-bottom: 62px;
    }

    #hero .textWrap:first-child {
        margin-left: 0;
    }

    .serviceItem_left,
    .serviceItem_right {
        padding: 45px 0 0 0;
    }

    #hero .textWrap {
        margin-top: 20px;
    }

    #hero h2 {
        font-size: 38px;
        text-align: center;
    }

    .serviceItem_right {
        margin-top: 11px;
    }

    .gnav__menu {
        padding: 0 80px;
        margin-top: 60px;
    }

    .menu {
        height: 11px;
        right: 11px;
        top: 23px;
        width: 28px;
    }

    .spheader {
        position: fixed;
        z-index: 6;
        top: 10px;


        right: 0;
        left: 0;

        margin: 0 auto;

        width: 98%;
        box-sizing: border-box;
    }

    .spheader .logoBox {
        backdrop-filter: blur(20px);
        border-radius: 6px;
        background: rgba(0, 0, 0, 0.52);
        padding: 12px 24px;
        z-index: 14;
        position: relative;
    }

    #hero .loopSlide {
        padding-bottom: 62px;
    }

    .pcHeader {
        display: none;
    }

    #hero .loopSlide {
        height: 75px;
    }

    #company .commonTitle {
        margin-bottom: 80px;
    }

    body.open .menu__line--bottom {
        bottom: 7px !important;
    }

    body.open .menu__line--top {
        top: 3px !important;
    }

    .spheader {
        display: block;
    }

    .open .menu__line {
        background: #fff;
    }

    .historyInner .flex {
        display: block;
    }

    .historyInner .inFlex {
        column-gap: 1px;
    }

    #message .des {
        font-size: 15px;
        line-height: 30px;
        margin-bottom: 32px;
    }

    .companyDetailItem:first-child::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 0;
        height: 1px;
        background-color: rgba(112, 112, 112, 0.5);
        transition: 1.4s cubic-bezier(0.36, 0.14, 0, 1) 0s;
    }

    #history .ageBox {
        margin-top: 60px;
    }

    .historyInner .ageBox dl {
        display: block;
        padding-bottom: 43px;
    }

    .historyInner .ageBox dl dd {
        padding-left: 31px;
        margin-top: 12px;
    }

    .historyInner .ageBox dl dt {
        font-size: 24px;
        width: auto;
    }

    .companyDetailList dl {
        margin-top: 60px;
    }

    .companyInner .companyDetailItem.scrollin::before {
        width: 100%;
    }

    .companyDetailList {
        width: auto;
    }

    .companyContent {
        display: block;
    }

    .companyOutline {
        width: auto;
    }

    .site-footer {
        padding: 80px 0 44px 0;
    }

    footer hr {
        margin: 10px 0;
    }

    .footer-logo img {
        width: 234px;
    }

    .site-footer {
        padding: 67px 0 24px 0;
    }

    .nav-title {
        font-size: 20px;
        margin: 0 0 4px 0;
    }

    .footer-bottom {
        padding: 0 40px;
        padding-top: 50px;
    }

    .ja-tag {
        font-size: 34px;
    }

    .footer-main {
        padding-bottom: 6px;
    }

    #message {
        padding: 0 0 120px 0;
    }

    .footer-nav {
        display: block;
    }

    .footer-address {
        margin-bottom: 50px;
    }

    #cta {
        padding: 100px 0 0 0;
    }

    .ctaItem_head .enTitle {
        font-size: 35px;
    }

    .footer-main {
        display: block;
        padding: 0 40px;
        padding-bottom: 40px;
    }

    .nav-group {
        margin-bottom: 40px;
    }

    #company {
        padding: 120px 40px 20px 40px;
        border-radius: 24px 24px 0 0;
    }

    #message h3 {
        font-size: 34px;
        line-height: 57px;
        margin-bottom: 32px;
    }

    #message .nameBox {
        margin-top: 64px;
    }

    .ctaInner {
        display: block;
    }

    .ctaInner .frame {
        display: none;
    }

    #about .textBox .enTitle {
        font-size: 14px;
        margin-bottom: 11px;
    }

    #message .loopSlide {
        padding-bottom: 108px;
    }

    .messageInner {
        padding: 0 40px;
    }

    .card h3 {
        font-size: 24px;
        margin-bottom: 23px;
    }

    #message .loopSlide {
        height: 64px;
    }

    .card p {
        font-size: 14px;
        line-height: 26px;
    }

    .badge {
        letter-spacing: 0;
        font-size: 9px;

        font-style: normal;
    }

    .values-container {
        margin-top: 60px;
        padding: 0 40px;
        gap: 16px;
    }

    .abspacer {
        margin: 97px auto;
    }

    #about .abCommonFlex {
        padding: 0;
        display: block;
    }

    .card {
        max-width: 48%;
        padding: 33px 28px;
    }

    #about .textBox .des {
        font-size: 15px;
        line-height: 28px;
        margin-bottom: 30px;
    }

    #about .textBox h3 {
        font-size: 34px;
        line-height: 58px;
        margin-bottom: 46px;
    }

    #about .commonTitle {
        margin-bottom: 42px;
    }

    #about .textBox {
        width: auto;
        padding: 0 40px;
    }

    #about .abCommonFlex::after {
        display: none;
    }

    #about .abCommonFlex01 .imgBox {
        padding-left: 40px;
    }

    #about .abCommonFlex02 .imgBox {
        padding-right: 40px;
    }

    #about .abCommonFlex03 .imgBox {
        padding-left: 40px;
    }

    #about .imgBox {
        width: auto;
        margin-bottom: 80px;
    }

    .gnav {
        background-position: 0 0;
        background-repeat: repeat;
        background-size: 12px 12px;
        background-image: url(../img/dodobg.svg);
    }

    .fixBtn {
        display: block;
        position: fixed;
        right: 0;
        left: 0;
        bottom: 8px;
        margin: 0 auto;
        z-index: 4;
        opacity: 0;
        transition: opacity 0.4s ease;
        width: 310px;
        text-align: center;
        border-radius: 100vw;
        border: solid 1px rgba(97, 96, 103, 0.32);
    }

    .fixBtn.is-show {
        opacity: 1;
    }

    .fixBtn.is-hide {
        opacity: 0;
    }

    .fixBtn a {
        margin: 0 auto;
        border-radius: 100vw;
        text-align: center;
        border: none;
        background: linear-gradient(90deg, #10072F 50%, #6341D0 100%);
        color: #fff;

        width: 310px;
        justify-content: center;
        height: 62px;

    }

    .fixBtn.commonBtn .arrowLink {
        top: 5px;
        right: 4px;
        width: 52px;
        height: 52px;
        border-radius: 100vw;
        background: #F7F7F7;
    }

    .fixBtn .arrowLink::before,
    .fixBtn .arrowLink::after {
        top: 22px;
        right: 19px;
        width: 13px;
        height: 9px;
        background: url(../img/fixBtnarrow.svg) 0 0 no-repeat;
        background-size: cover;
        z-index: 3;
    }

    #udhero {
        padding: 160px 40px 52px 40px;
    }

    form {
        padding: 60px 40px;
        padding-bottom: 48px;
        position: relative;
    }

    .BlogSingleCont {
        padding: 110px 40px 40px;
    }

    .BlogSingleContInner .article-title {
        font-size: 24px;
        margin-top: 20px;
        font-weight: 500;
        line-height: 35px;
    }

    .BlogSingleContInner .mainContents h2::after {
        width: 28px;
        height: 4px;
        left: 0;
        top: 0;
    }

    .BlogSingleContInner .mainContents p {
        margin-top: 16px;
        font-size: 15px;
        line-height: 28px;
    }

    .singlepostnavi {
        padding: 0;
    }

    .BlogSingleContInner .blog-main {
        margin-bottom: 80px;
    }

    .next_child .next::before {
        right: 69px;
    }

    .prev_child .prev::before {
        left: 69px;
    }

    .BlogSingleContInner .mainContents h2 {
        font-size: 19px;
        line-height: 35px;
        padding-top: 12px;
        margin-top: 40px;
    }

    .post_page_navi span {
        font-size: 14px;
    }

    .post_page_navi {
        padding: 18px 0;
        max-width: 1240px;
        margin-top: 144px;
        column-gap: 133px;
    }

    .BlogSingleContInner .mainContents h3 {
        font-size: 16px;
        font-weight: 500;
        line-height: 32px;
        margin-top: 30px;
    }

    .BlogSingleContInner .mainContents h2 {
        margin-top: 60px;
    }

    .certifWrap {
        padding: 60px 40px 20px 40px;
    }

    .ceOpfBox h2 {
        font-size: 18px;
        margin-bottom: 26px;
    }

    .ceOpfBox p {
        font-size: 15px;
        line-height: 30px;
        margin-bottom: 17px;
        font-weight: 400;
    }

    #certiCont .sectionTWrap {
        width: auto;
    }

    #certiCont .certi-section {
        border-radius: 12px;
        padding: 40px 20px;
        margin-bottom: 14px;
        display: block;
    }

    #certiCont .info-box {
        padding: 25px 20px;
    }

    .certifWrapInner .ceOpfBox {
        margin-bottom: 55px;
    }

    .certifBtn {
        height: 72px;
        font-size: 15px;
        border: solid 2px #fff;
        border-radius: 8px;
        max-width: 356px;
        margin-top: 32px;
    }

    .scroll-infinity__wrap {
        padding-top: 105px;
        padding-bottom: 20px;
        column-gap: 28px;
    }

    .scroll-infinity__list {
        column-gap: 28px;
    }

    .scroll-infinity__item {
        width: 362px;
    }

    .recruitOpBox .tiltBox .ja {
        font-size: 34px;
        line-height: 54px;
    }

    .recruitOpBox .tiltBox .enTitle {
        margin-bottom: 10px;
    }

    .recMessege {
        padding: 80px 40px 0 40px;
    }

    .recruitInfo .flexCard .nam {
        margin-bottom: 17px;
    }

    .recruitInfo .commonConBox {
        margin-bottom: 160px;
    }

    .recruitInfo .flexCard p {
        font-size: 14px;
        font-weight: 400;
        line-height: 24px;
    }

    .recruitInfo .flexCard > div {
        padding: 22px 24px 29px 28px;
    }

    .inDexBox {
        margin-bottom: 48px;
    }

    .inDexBox > div {
        display: flex;
        flex-wrap: wrap;
        gap: 16px 1%;
        justify-content: space-between;
    }

    .recruitInfo .flexCard h3 {
        font-size: 18px;
        line-height: 30px;
        flex-grow: 1;
        margin-bottom: 12px;
    }

    .recruitInfo .FlexBox .inDexBox a {
        width: 49%;
    }

    #Candidate .opDes {
        font-size: 18px;
        text-align: center;
    }

    .recruitInfo .FlexBox {
        display: block;
    }

    .recruitOpBox .textBox p {
        font-size: 15px;
        line-height: 30px;
        margin-bottom: 32px;
    }

    .recruitInfo {
        padding: 80px 40px 10px 40px;
    }

    .recruitOpBox .textBox {
        margin-top: 32px;
    }

    .recruitOpBox {
        padding: 86px 40px;
    }

    .recruitOpBox .bgEnh {
        font-size: 83px;
        left: -40px;
        top: -77px;
        line-height: 89px;
    }

    .recruitOpBox .flexBox {
        display: block;
    }

    .accordion-title {
        padding: 30px 61px 30px 30px;
    }

    .accordion-title {
        font-size: 18px;
    }

    #faq .accordion-title .enFont {
        margin-top: 2px;
    }

    #Welfare .iconBox img {
        width: 66px;
    }

    .positionDl section > div {
        width: auto;
    }

    .positionDl section > div ul li {
        padding: 8px 14px;
        font-size: 15px;
        font-weight: 300;
    }

    #Welfare section h3 {
        font-size: 18px;
        font-weight: 500;
    }

    #faq .accordion-content {
        padding: 30px 32px;
        border-radius: 0 0 4px 4px;
    }

    .entryBtn {
        height: 69px;
        border-radius: 4px;
        font-size: 18px;
        max-width: 362px;
        margin-top: 40px;

    }

    .accordion-content {
        margin-bottom: 56px;
    }

    .positionDl section > div p {
        font-size: 15px;
        line-height: 26px;
        font-weight: 300;
    }

    .positionDl section h3 {
        width: auto;
        font-size: 18px;
        font-weight: 500;
        margin-bottom: 38px;
    }

    .accordion-title::after,
    .accordion-title::before {
        top: 36px;
    }

    .positionDl section {
        display: block;
        padding: 48px 0;
    }

    #news.udnewslistwrap {
        padding: 60px 40px 80px 40px;
    }



    .udnewslistwrap .catBox ul a {
        font-size: 12px;
        padding: 7px 0;
        padding: 1px 31px;
    }

    .udnewslistwrap .catBox ul {
        flex-wrap: wrap;
    }

    .udnewslistwrap .newsInner a {
        width: 48%;
    }

    .udnewslistwrap .newsInner {
        gap: 88px 2%;
        justify-content: space-between;
        flex-wrap: wrap;
    }

    #privacy {
        padding: 0 40px;
        padding-bottom: 90px;
        padding-top: 64px;
    }


}

@media screen and (max-width: 650px) {
    #hero .loopSlide {
        height: 47px;
    }

    #news .nameBox {
        margin-top: 18px;
    }

    html {
/*        scroll-padding-top: 80px;*/
        scroll-margin-top:80px;
    }

    .companyOutline .jaFont {
        font-size: 11px;
        margin-bottom: 11px;
    }

    .companyDetailItem dt {
        width: 135px;
    }

    .companyDetailItem dd {
        flex-grow: 1;
        line-height: 24px;
        font-size: 14px;
    }

    .serviceItem_left,
    .serviceItem_right {
        padding: 33px 0 0 0;
    }

    #message .nameBox {
        margin-top: 43px;
    }

    .companyOutline .enFont {
        font-size: 20px;
    }

    #company {
        padding: 60px 32px 20px 32px;
        border-radius: 24px 24px 0 0;
    }

    #message {
        padding: 0 0 60px 0;
    }

    #message .nameBox p span {
        font-size: 18px;
        line-height: 29px;
    }

    #about .textBox .enTitle {
        font-size: 10px;
        margin-bottom: 5px;
    }

    #message .des {
        margin-bottom: 30px;
    }

    #message .nameBox p {
        font-size: 13px;
    }

    #message h3 {
        font-size: 30px;
        line-height: 52px;
        margin-bottom: 19px;
    }

    .lineTitle {
        margin-bottom: 29px;
        padding-bottom: 10px;
    }

    .lineTitle .jaTitle {
        font-size: 11px;
        opacity: .5;
    }

    #message .loopSlide {
        height: 39px;
    }

    .messageInner {
        padding: 0 32px;
    }

    .lineTitle .enTitle {
        font-size: 20px;
    }

    .values-container {
        gap: 10px;
    }

    .card h3 {
        font-size: 22px;
        margin-bottom: 18px;
    }

    .values-container {
        margin-top: 40px;
        padding: 0 32px;
    }

    .card {
        max-width: 100%;
        padding: 28px 18px;
    }

    .abspacer {
        margin: 66px auto;
    }

    #about .textBox h3 {
        font-size: 23px;
        line-height: 41px;
        margin-bottom: 29px;
    }

    .serviceItem {
        padding-bottom: 50px;
    }

    #about .textBox {
        padding: 0 32px;
    }

    #about {
        padding: 60px 0;
    }

    .serviceItemLine {
        padding: 0 18px;
    }

    .serviceItem_link {
        margin-top: 11px;
    }

    .serviceItem_name {
        font-size: 17px;
    }

    .serviceItem_link img {
        width: 169px;
    }

    #hero .loopSlide {
        padding-bottom: 36px;
    }

    #service .commonTitle {
        text-align: left;
        padding: 0 32px;
    }

    #service {
        padding: 60px 0;
    }

    .hLogo img {
        width: 94px;
    }

    .commonTitle .jaTitle {
        font-size: 15px;
        margin-bottom: 21px;
    }

    .commonTitle .enTitle {
        font-size: 40px;
    }

    #news .commonBtnSp {
        margin-top: 40px;
    }

    .menu_box {
        right: 9px;
        top: 8px;
        height: 42px;
        width: 42px;
    }

    .menu {
        height: 10px;
        right: 9px;
        top: 19px;
        width: 23px;
    }

    .gnav__menu {
        padding: 0 32px;
    }

    .spheader .logoBox {
        padding: 14px 24px;
    }

    .ctaItem_head .jaTitle {
        font-size: 11px;
        margin-bottom: 0px;
    }

    .nav-group {
        margin-bottom: 37px;
    }

    .nav-title {
        margin: 0 0 2px 0;
    }

    .footer-logo img {
        width: 187px;
    }

    .footer-info {
        width: auto;
    }

    body.open .menu__line--top {
        top: 2px !important;
    }

    .footer-main {
        padding: 0 32px;
        padding-bottom: 40px;
    }

    .ctaItem_head .enTitle {
        font-size: 20px;
    }

    .gnav__menu {
        padding-top: 204px;
    }

    .gnav {
        overflow: scroll;
    }

    .ctaInner .commonBtn {
        bottom: 10px;
        right: 6px;
    }

    .ctaInner .ctaItem_head {
        left: 20px;
        top: 24px;
    }

    #cta {
        padding: 30px 0 0 0;
    }

    header .hLogo .h_nav {
        padding: 0;
        top: -5px;
    }

    .ctaInner .ctaItem_body p {
        display: none;
    }

    .historyInner .ageBox dl dt {
        font-size: 19px;
    }

    .historyInner .ageBox .month {
        font-size: 15px;
        width: 41px;
    }

    #history {
        padding-top: 50px;
    }

    .historyInner .textBox p {
        font-size: 14px;
        line-height: 24px;
        margin-top: 2px;
    }

    #hero h2 {
        font-size: 33px;
        font-weight: 500;
    }

    .companyDetailItem {
        padding: 30px 0;
    }

    .historyInner .ageBox dl dd {
        padding-left: 31px;
        box-sizing: border-box;
    }

    .footer-tagline .glSec {
        margin-left: 41px;
    }

    .en-tag {
        font-size: 8px;
        margin-bottom: -8px;
    }

    .footer-bottom {
        padding: 0 20px;
        padding-top: 30px;
    }

    #hero .scrolldwn {
        width: 104px;
        height: 104px;
        bottom: 34px;
        left: 0;
        right: 0;
        margin: 0 auto;
    }

    .footer-bottom {
        display: block;
    }

    .footer-address strong {
        margin-bottom: 8px;
    }

    .ja-tag {
        margin-bottom: 20px;
        font-size: 32px;
    }

    #hero .scrolldwn .enTitle {
        font-size: 10px;
    }

    .footer-copyright small {
        font-size: 9px;
        letter-spacing: 0;
        display: block;
        text-align: center;

    }

    #message .loopSlide {
        padding-bottom: 84px;
    }

    .site-footer {
        padding: 52px 0 14px 0;
    }

    .footer-main {
        padding-bottom: 1px;
    }

    .companyDetailItem dd span:first-child {
        margin-bottom: 16px;
    }

    .mwform-tel-field input {
        padding: 0 17px;
    }

    select {
        height: 64px;
        font-size: 16px;
        padding: 0 20px;
    }

    .commonBtnPc {
        display: none;
    }

    input {
        height: 64px;
        font-size: 16px;
        padding: 0 20px;
    }

    textarea {
        font-size: 16px;
        padding: 15px 20px;
    }

    .priLinkP {
        font-size: 13px;
        letter-spacing: 0.05em;
        margin-bottom: 4px;
    }

    .submitBox input {
        font-size: 15px;
        height: 69px;
        max-width: 234px;
    }

    #hero .scrolldwn {
        bottom: 20px;
    }

    .form_flexBox:first-child {
        padding-top: 19px;
    }

    .form_flexBox {
        padding-bottom: 24px;
        margin-bottom: 14px;
    }

    .commonBtnSp {
        display: block;
    }

    .post_page_navi span {
        font-size: 12px;
        letter-spacing: 0;
    }

    .prev_child .prev::before {
        width: 24px;
        left: 55px;
    }

    .BlogSingleContInner .blog-main {
        margin-bottom: 72px;
    }

    .next_child .next::before {
        right: 55px;
        width: 24px;
    }

    .post_page_navi {
        justify-content: space-between;
    }

    .form_flexBox_list {
        margin-bottom: 6px;
        font-size: 15px;
    }

    a.pagenationBox_centaer {
        padding-left: 0;
    }

    .post_page_navi {
        padding: 18px 0;
        margin-top: 80px;
        column-gap: 38px;
    }

    .ceOpfBox h2 {
        font-size: 18px;
        margin-bottom: 20px;
    }

    #certiCont .fee-table th,
    #certiCont .fee-table td {
        padding: 12px 17px;
    }

    #certiCont .info-box-title {
        line-height: 24px;
        margin-bottom: 9px;
    }

    #certiCont .fee-table {

        width: 434px;
    }

    #certiCont .fee-table td {
        font-size: 14px;
    }

    .fee-tableWrap {
        overflow: auto;
    }

    #certiCont .note {
        font-size: 13px !important;
        line-height: 24px !important;
    }

    #certiCont .note02 {
        margin-top: -9px !important;
    }

    #certiCont .sectionTWrap {
        width: auto;
        margin: 0 auto;
        text-align: center;
    }

    form {
        padding: 30px 32px;
        padding-bottom: 48px;
    }

    #certiCont .info-box .certi-list li {
        margin-bottom: 8px;
    }

    #certiCont .section-title {
        font-size: 16px;
        padding: 8px 19px;
        border-radius: 50px;
        margin-bottom: 25px;
    }

    #certiCont .certi-section {
        padding: 32px 20px 20px 20px;
    }

    .ceOpfBox p {
        font-size: 13px;
        line-height: 24px;
        margin-bottom: 14px;
    }

    #certiCont .procedure-list p {
        margin-top: 0;
        font-weight: 400;
        font-size: 15px;
        line-height: 26px;
    }

    #certiCont .certi-list li {
        font-size: 15px;
        margin-bottom: 8px;
        line-height: 24px;
    }

    .thanksBoxIner p {
        color: #fff;
        font-size: 14px;
        font-weight: 400;
        line-height: 26px;
    }

    #certiCont .fee-table {
        margin-top: 4px;
    }

    .bank-info {
        gap: 8px 13px;
    }

    .bank-info dt {
        line-height: 22px;
    }

    .bank-info dd {
        margin: 0;
        line-height: 22px;
        font-size: 13px;
    }

    .bank-info {
        font-size: 15px;
    }

    .thanksBoxIner {
        padding: 40px 32px;
    }

    #certiCont .fee-table th {
        font-size: 15px;
    }

    .scroll-infinity__wrap {
        padding-top: 87px;
        column-gap: 16px;
    }

    .BlogSingleCont {
        padding: 90px 32px 32px;
    }

    .scroll-infinity__list {
        column-gap: 16px;
    }

    .recruitOpBox .textBox p {
        font-size: 15px;
        line-height: 30px;
        margin-bottom: 30px;
    }

    .recruitOpBox .bgEnh {
        font-size: 50px;
        left: -32px;
        top: -24px;
        line-height: 49px;
    }

    .accordion-title {
        font-size: 16px;
    }

    #Welfare section {
        column-gap: 22px;
        padding: 30px 0;
    }

    .accordion-title {
        line-height: 26px;
    }

    #faq .accordion-title .enFont {
        font-size: 21px;
        margin-top: 2px;
    }

    #faq .accordion-content .enFont {
        font-size: 21px;
    }

    #faq .accordion-content {
        padding: 25px 20px;
        font-size: 15px;
        line-height: 24px;
        border-radius: 0 0 4px 4px;
    }

    #Welfare .iconBox img {
        width: 58px;
    }

    .accordion-content .programSlide {
        margin-bottom: 22px;
    }

    .accordion-content .programSlide .swiper-slide {
        margin-bottom: 39px;
    }

    #Welfare section h3 {
        font-size: 17px;
    }

    #Welfare section .textBoxer p {
        font-size: 15px;
        font-weight: 300;
        line-height: 28px;
    }

    .positionDl section > div p {
        margin-bottom: 16px;
    }

    .entryBtn {
        height: 66px;
        border-radius: 4px;
        padding-top: 4px;
        font-size: 16px;
        max-width: 261px;
        margin-top: 32px;
    }

    .accordion-content {
        margin-bottom: 56px;
    }

    .positionDl section h3 {
        font-size: 17px;
        margin-bottom: 28px;
    }

    .swiper-horizontal > .swiper-pagination-bullets,
    .swiper-pagination-bullets.swiper-pagination-horizontal,
    .swiper-pagination-custom,
    .swiper-pagination-fraction {
        bottom: 6px;
    }

    .accordion-content .swiper-pagination-bullet {
        width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
        height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
    }

    .recruitOpBox .textBox {
        margin-top: 19px;
    }

    .positionDl section {
        padding: 32px 0;
    }

    .recruitOpBox .tiltBox .ja {
        font-size: 30px;
        line-height: 52px;
    }

    .accordion-title {
        padding: 26px 34px 26px 20px;
    }

    .accordion-title::after,
    .accordion-title::before {
        right: 22px;
        width: 2px;
        top: 42%;
        height: 16px;
        background-color: #7A78FF;
        transition: all 0.3s;
    }

    .accordion-content {
        margin-top: 32px;
    }

    .recruitInfo .flexCard {
        display: block;
    }

    .recruitInfo .flexCard .nam {
        margin-bottom: 8px;
        margin-right: -7px;
    }

    .recruitInfo .flexCard p {
        font-weight: 300;
        letter-spacing: .03em;
    }

    .recruitInfo .commonConBox {
        margin-bottom: 88px;
    }

    .recruitInfo .flexCard h3 {
        font-size: 17px;
        line-height: 30px;
        flex-grow: 1;
        margin-bottom: 8px;
    }

    .recruitInfo .flexCard .nam img {
        width: 30px;
    }

    .recruitInfo .flexCard > div {
        border-radius: 12px;
        width: auto;
        padding: 14px 20px 28px 20px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }

    .recruitInfo .flexCard .nam {
        margin-bottom: 12px;
    }

    .recruitInfo .flexCard > div {
        margin-bottom: 12px;
    }

    .recruitInfo .flexCard > div:last-child {
        margin-bottom: 0;
    }

    .canArrwo {
        margin: 9px 0 28px 0;
    }

    #Candidate .opDes {
        font-size: 16px;
    }

    .commonTitle .enTitle {
        font-size: 31px;
    }

    .recruitWrap .lineTitle .enTitle {
        font-size: 19px;
    }

    .recruitInfo .FlexBox .inDexBox a {
        width: 48%;
    }

    .inDexBox {
        margin-bottom: 60px;
    }

    .inDexBox > div {

        gap: 16px 3%;
    }

    .recruitInfo .FlexBox .inDexBox a::after {
        width: 16px;
        height: 12px;
        right: 0;
        top: 12px;
    }

    .recruitInfo .FlexBox .inDexBox a {
        font-size: 13px;
        padding-bottom: 5px;
        margin-bottom: 10px;
    }

    .recruitWrap .lineTitle {
        margin-bottom: 29px;
        padding-bottom: 6px;
    }

    .recruitInfo {
        padding: 60px 32px 10px 32px;
    }

    #udhero {
        padding: 118px 32px 34px 32px;
    }

    .udnewslistwrap .newsInner a {
        width: auto;
    }

    .recMessege {
        padding: 60px 32px 0 32px;
    }

    #news.udnewslistwrap .tagBox {
        margin-top: 14px;
    }

    #news.udnewslistwrap .imgBox img {
        aspect-ratio: 370 / 394;
    }

    .udnewslistwrap .newsInner a {
        margin-bottom: 55px;
    }

    #news.udnewslistwrap .nameBox {
        font-size: 16px;
        margin-top: 8px;
    }

    .certifWrap {
        padding: 48px 24px 20px 24px;
    }

    .udnewslistwrap .newsInner {
        display: block;
    }

    .pcBr {
        display: none;
    }

    .udnewslistwrap .catBox {
        margin-bottom: 40px;
    }

    .udnewslistwrap .catBox ul {
        gap: 6px;
    }

    .udnewslistwrap .catBox ul a {
        font-size: 10px;
        padding: 8px 23px;
        line-height: 1;
    }

    .yscAten {
        display: block;
        font-size: 12px !important;
        font-weight: 300 !important;
        margin-top: 8px !important;
    }

    #news.udnewslistwrap .tagBox .day {
        margin-top: 3px;
    }

    #news.udnewslistwrap .tagBox {
        column-gap: 10px;
    }

    #news.udnewslistwrap {
        padding: 40px 24px 60px 24px;
    }

    .recruitOpBox {
        padding: 60px 32px;
    }

    #news.udnewslistwrap .cat {
        font-size: 10px;
        padding: 6px 17px 7px 17px;
    }

    #news.udnewslistwrap .tagBox {
        align-items: center;
    }

    .wp-pagenavi .current {
        padding: 5px 9px 1px 12px;
    }

    .archive_page_navi .wp-pagenavi {
        column-gap: 5px;
        font-size: 13px;
    }

    #news .tagBox {
        column-gap: 10px;
    }

    #privacy .poliBox {
        margin-bottom: 36px;
    }

    .scroll-infinity__item {
        width: 242px;
    }

    #news .tagBox {
        margin-top: 14px;
    }

    #news .cat {
        font-size: 10px;
        padding: 6px 17px 7px 17px;
    }

    #news.udnewslistwrap .imgBox {
        border-radius: 4px;
    }

    #privacy .priConta .des {
        font-size: 13px;
        letter-spacing: 0.12em;
        line-height: 1.6em;
    }

    .archive_page_navi {
        padding-top: 32px;
    }

    #news.udnewslistwrap .imgBox img {
        aspect-ratio: 1 / 1;
        border-radius: 4px;
    }

    #privacy li {
        font-size: 13px;
        letter-spacing: 0.12em;
        line-height: 2.2em;
    }

    #news .tagBox {
        align-items: center;
    }

    #privacy .des {
        font-size: 13px;
        letter-spacing: 0.12em;
        line-height: 2.2em;
    }

    #privacy h3 {
        font-size: 18px;
        margin-bottom: 5px;
        padding-bottom: 0;
    }

    #news.udnewslistwrap {
        padding: 24px 32px 60px 32px;
    }

    .card {
        border-radius: 8px;
    }

    #privacy {
        padding: 0 24px;
        padding-bottom: 55px;
        padding-top: 40px;
    }

    .page-id-150 #cta {
        padding: 0 0 0 0;
    }



    .page-id-150 .commonTitle .enTitle {
        font-size: 24px;
    }




}
