@charset "utf-8";

html, body, input, textarea, select, button,a {
    font-family: '游ゴシック体', YuGothic, '游ゴシック', 'Yu Gothic', 'メイリオ', Meiryo, 'Hiragino Sans', 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', sans-serif;
    font-weight: 500;
    font-feature-settings: "palt";
    -webkit-font-smoothing: antialiased;
}
* {
    letter-spacing: 0.1em;
}
a {
    text-decoration: none;
}
a:hover {
    text-decoration: underline;
}
img {
    vertical-align: bottom;
}

/* header */
.navoverlay {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: rgba(0,0,0,.7);
    z-index: 100;
    transition: all .2s;
    display: none;
}
.navopen #navi:before{
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}
.header {
    position: relative;
    z-index: 800;
}
.menu_intern {
    display: flex;
    position: absolute;
    top: 18px;
    right: 190px;
}
.menu_intern_tablet {
    display: none;
}
.menu_intern > li {
    display: inline-block;
    margin-left: 10px;
}
.menu_intern > li a {
    font-size: 14px;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px 20px;
    text-align: center;
    min-width: 160px;
    height: 50px;
    text-decoration: none;
    letter-spacing: 0.05em;
    line-height: 1.28;
    position: relative;
}
.menu_mypage {
    background: #fff;
    color: #cc0033;
    border: 1px solid #cc0033;
}
.menu_intern > li .menu_internship_mypage {
    padding: 8px 0px 8px 30px;
}
.menu_intern > li .menu_mypage {
    padding: 8px 30px;
}
.menu_internship_mypage {
    background: #fff;
    color: #61b4c9;
    border: 1px solid #279dba;
    width: 160px;
}
.menu_mypage_icon {
    position: absolute;
    top: 0;
    left:8px;
    bottom: 0;
    margin: auto;
    width: 24px;
    height: 24px;
    background: url(../images/ico_floating.gif?v=1) no-repeat center center;
    background-size: 100% auto;
    margin-right: 3px;
}
.menu_internship_mypage_icon {
    position: absolute;
    top: 0;
    left:8px;
    bottom: 0;
    margin: auto;
    width: 24px;
    height: 24px;
    background: url(../images/ico_floating_blue.gif) no-repeat center center;
    background-size: 100% auto;
    margin-right: 3px;
}
.menu_intern > li .menu_new_docomo,
.menu_intern > li .menu_new_docomocs {
    padding: 8px 30px;
}
.menu_intern > li .menu_internship {
    padding: 8px 30px;
}
.menu_new_docomo,
.menu_new_docomocs {
    font-weight: 700;
    font-size: 14px;
    color: #fff;
    background: #cc0033;
}

.menu_new_docomocs {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.menu_new_docomocs .small {
    display: inline-block;
    font-size: 10px;
    white-space: nowrap;
}
.menu_internship {
    font-weight: 700;
    font-size: 14px;
    color: #fff;
    background: #279dba;
}
.menu_intern_entry {
    background: #cc0033;
    color: #fff;
    border: 1px solid #cc0033;
    width: 160px;
}
.menu_internship_entry {
    background: #61b4c9;
    color: #fff;
    border: 1px solid #61b4c9;
}
.menu_mypage {
    background: #fff;
    color: #cc0033;
    border: 1px solid #cc0033;
}
.menu_entry {
    background: #cc0033;
    color: #fff;
    border: 1px solid #cc0033;
}

#navi {
    background-color: #fff;
    position: fixed;
    top: 0;
    left: 0;
    height: 120px;
    width: 100%;
    z-index: 10;
}
li a.menu_new_docomocs,
li a.menu_internship_mypage,
li a.menu_internship {
    text-align: left;
}
li a.menu_new_docomo {
    text-align: center;
}
.menu_mypage {
    font-size: 18px;
}
.menu_mypage .sp {
    display: none;
}
.navi_open #navi {
    background-color: #fff;
}
.menu_parent_br {
    display: none;
}
.menu_parent .img {
    height: 32.59px;
}
@media screen and (max-width: 1280px) {
    #navi {
        background-color: #fff;
        height: 120px;
    }
    .navi_inner {
        padding: 60px;
        position: relative;
        z-index: 1;
    }
}
@media screen and (max-width: 1100px) {
    #navi {
        height: 140px;
    }
    .navi_inner {
        padding: 70px;
    }
}
@media screen and (max-width: 1150px) {
    #navi {
        font-size: 0.8695vw;
        height: 140px;
    }
    .navi_inner {
        padding: 70px;
        position: relative;
        z-index: 1;
    }
    .menu_parent_br {
        display: block;
    }
}
/* ヘッダー修正 */
@media screen and (max-width: 1350px) {
    #navi {
        font-size: 0.74vw;/* 10px */
        height: 120px;
    }
    .navi_inner {
        padding: 60px;
    }
    .menu_mypage .sp {
        display: block;
    }
}
@media screen and (max-width: 1150px) {
    #navi {
        height: 14em;
    }
    .navi_inner {
        padding: 7em;
    }
}
@media screen and (max-width: 640px) {
    #navi {
        height: 60px;
    }
    .navi_inner {
        padding: 30px;
    }
}

/* チェックボックスを非表示 */
#navi input {
    display: none;
}
/* 左上ロゴ */
.menu-left {
    position: absolute;
    top: 30px;
    left: 40px;
    width: 320px;
    max-width: 320px;
}
.hd_logo_img {
    width: 100%;
}
.hd_logo {
    display: block;
}
.menu-left img {
    vertical-align: middle;
}
/* 右上ロゴ */
.hd_logo_docomo {
    position: absolute;
    top: 18px;
    /* right: 105px; */
    right: 47px;
}
/* 上部メニュー */
#menu {
    margin-top: 82px;
}
/* #menu_sp {
    display: none;
} */
.menu_list {
    font-size: 0;
    padding-right: 31px;
    text-align: right;
}
.menu_parent {
    display: inline-block;
    font-size: 14px;
}
.menu_parent_link {
    font-weight: 700;
    color: #212121;
    padding:0 26px 15px 10px;
    display: block;
    position: relative;
}
.menu_parent_link_arrow:before {
    content: '';
    display: block;
    position: absolute;
    top: 6px;
    right: 9px;
    width: 0;
    height: 0;
    border-top: 10px solid #cc0033;
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
}
.menu_parent_link_arrow_right:before {
    top: 4px;
    right: 7px;
    border-top: 5px solid transparent;
    border-left: 10px solid #cc0033;
    border-bottom: 5px solid transparent;
}
.menu_parent_en {
    display: none;
}
#menu-navibtn {
    display: none;
    cursor: pointer;
    cursor: hand;
}
.menu_intern_sp {
    /* display: none; */
}
/* ヘッダーENTRYボタン拡縮調整 */
@media screen and (max-width: 640px) {
    #menu .menu_intern > li a {
        height: 5.1vw;
        padding: 0.8vw 1vw;
    }
}
@media screen and (max-width: 1150px) {
    .menu_parent_link_arrow:before {
        top: 0.3em;
        right: 9px;
        border-top: 5px solid transparent;
        border-left: 10px solid #cc0033;
        border-bottom: 5px solid transparent;
    }
    #menu .menu_parent_link {
        padding: 0;
    }
}

#menu .menu-left {
    top: 5.4vw;
    width: 23%;
    left: 4.08vw;
    max-width: 260px;
    transform: translate(0, -50%);
}
/* 基本非表示 */
#menu_sp {
    /* pointer-events: none; */
    /* max-width: 1280px; */
    margin: 0 auto;
}
#menu_sp .menu_inner {
    background-color: #ebe9ea;
    position: fixed;
    height: 100%;
    width: 100%;
    padding-top: 50px;
    padding-bottom: 200px;
    overflow-y: auto;
    z-index: 1;
}
#menu_sp .menu_list {
    max-width: 600px;
    margin: 0 auto;
    padding-top: 50px;
    text-align: left;
    padding-right: 0;
}
#menu_sp .menu_list li {
    position: relative;
    height: auto;
    width: 100%;
    white-space: nowrap;
}
#menu_sp .menu_parent + .menu_parent {
    margin-top: 54px;
}
#menu_sp .menu_parent_special {
    display: none;
}
#menu_sp .menu_parent_link {
    padding: 0;
}
#menu_sp .menu_parent_en {
    display: block;
}
#menu_sp .menu_parent_ja {
    font-size: 18px;
    margin-top: 9px;
    display: block;
}
#menu_sp .menu_parent_link_arrow {
    width: 120px;
    height: 28px;
    background: #fff;
    position: absolute;
    top: 0;
    right: 0;
}
#menu_sp .menu_parent_link_arrow:before {
    right: 10px;
    border-top: 4px solid transparent;
    border-left: 14px solid #cc0033;
    border-bottom: 4px solid transparent;
    bottom: 0;
    top: 0;
    margin: auto;
    border-right: none;
}
#menu_sp .menu_parent_link_arrow:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 78%;
    width: calc(92% - 28px);
    height: 1px;
    right: 28px;
    background: #cc0033;
}
#menu_sp .menu_list li i {
    padding: 0px 6px;
}
#menu_sp .menu_intern {
    margin-left: auto;
    margin-right: auto;
    /* width: 75%;
    width: calc(75% - 39vw); */
    /* transform: translateY(-50%); */
}
#menu_sp .menu_intern > li {
    margin-left: 0;
}
#menu_sp .menu_intern > li + li {
    margin-left: 0.5vw;
}
#menu_sp .menu_intern > li a {
    margin: auto;
    min-width: auto;
    padding: 0.8vw 1.8vw;
    width: 15vw;
    font-size: 1.428vw;
}
#menu_sp .menu_intern > li .menu_new_docomo,
#menu_sp .menu_intern > li .menu_new_docomocs,
#menu_sp .menu_intern > li .menu_internship {
    padding: 0.8vw 0.7vw;
}
#menu_sp .menu_intern_tablet {
    display: flex;
    font-size: 0;
}
#menu_sp .menu_intern > li .menu_internship_mypage {
    padding: 0.8vw 0 0.8vw 3vw;
}
#menu_sp .menu_intern > li .menu_mypage {
    padding: 0.8vw 0.8vw 0.8vw 0.3vw;
}
#menu_sp .menu_mypage_icon,
#menu_sp .menu_internship_mypage_icon {
    left: 0.6vw;
    width: 2.2vw;
    height: 2.2vw;
}
#menu_sp .hd_logo_docomo {
    top: 47px;
    right: 12.24vw;
    width: 10.1vw;
    transform: translate(0, -50%);
}
#menu_sp .menu_intern_sp {
    width: 600px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    font-size: 0;
    position: static;
}
#menu_sp .menu_intern_sp > li {
    width: calc(50% - 1%);
}
#menu_sp .menu_intern_sp > li:nth-child(3) {
    width: 100%;
}
#menu_sp .menu_intern_sp > li a {
    width: 100%;
}
#menu_sp .menu_intern_sp > li:nth-child(n + 3) {
    margin-top: 2%;
}
#menu_sp .menu_intern_sp > li + li {
    margin-left: 0;
}
#menu_sp .menu_intern_sp > li a {
    width: 100%;
    height: 45px;
    font-size: 12px;
}
#menu_sp .menu_intern_sp > li .menu_new_docomo,
#menu_sp .menu_intern_sp > li .menu_new_docomocs,
#menu_sp .menu_intern_sp > li .menu_internship,
#menu_sp .menu_intern_sp > li .menu_mypage,
#menu_sp .menu_intern_sp > li .menu_internship_mypage {
    padding: 8px 30px;
}
#menu_sp .menu_mypage_icon,
#menu_sp .menu_internship_mypage_icon {
    width: 20px;
    height: 20px;
    left: 8px;
}
@media screen and (max-width: 1350px) {
    #menu,
    #menu_sp {
        margin-top: 0;
    }
    #menu .menu_intern {
        max-width: 600px;
        position: absolute;
        top: 18px;
        right: calc(11.9em + 70px);
        z-index: 1;
    }
    #menu .menu_intern_sp {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        font-size: 0;
    }
    #menu .menu_intern_sp > li {
        width: calc(50% - 1%);
    }
    #menu .menu_intern_sp > li:nth-child(n + 3) {
        margin-top: 2%;
    }
    #menu .menu_intern_sp > li + li {
        margin-left: 0;
    }
    #menu .menu_intern_sp > li a {
        width: 100%;
        height: 45px;
        font-size: 12px;
    }
    #menu .menu_intern_sp > li .menu_new_docomo,
    #menu .menu_intern_sp > li .menu_new_docomocs,
    #menu .menu_intern_sp > li .menu_internship,
    #menu .menu_intern_sp > li .menu_mypage,
    #menu .menu_intern_sp > li .menu_internship_mypage {
        padding: 8px 30px;
    }
    #menu .menu_mypage_icon,
    #menu .menu_internship_mypage_icon {
        width: 20px;
        height: 20px;
        left: 8px;
    }

    #menu {
        display: block;
    }
    #menu .menu_list {
        width: 100%;
        position: absolute;
        top: 82px;
        right: 0;
        left: 0;
        z-index: 1;
    }
    .hd_logo_docomo {
        right: 105px;
    }
    #menu .menu_parent_link {
        padding:0 26px 7px 10px;
    }
    .menu_parent_link:hover {
        text-decoration: none;
    }
}
@media screen and (max-width: 970px) {
    #menu .menu_intern {
        right: calc(150px + 4em);
        right: 24em;
    }
}

/* ヘッダー修正 */
@media screen and (max-width: 1350px) {
    .menu-left {
        width: 31em;
        top: 3em;
        left: 4em;
    }
    .hd_logo_docomo {
        width: 11.9em;
        top: 1.8em;
        right: 47px;
    }
    #menu .menu_parent {
        font-size: 1.037vw;/* 14px */
    }
    #menu .menu_intern {
        top: 1.8em;
        /* left: 38em; */
        /* left: 57em; */
    }
    #menu .menu_intern > li {
        margin-left: 1em;
    }
    #menu .menu_intern > li .menu_mypage,
    #menu .menu_intern > li .menu_internship_mypage {
        padding: 0.8em 0 0.8em 0;
    }
    #menu .menu_intern > li a {
        /* width: 13.9em; */
        height: 3.7vw;/* 50px */
        /* min-width: 11.9em; */
        min-width: 9em;
        font-size: 1.037vw;/* 14px */
    }
    #menu .menu_intern > li .menu_new_docomo,
    #menu .menu_intern > li .menu_new_docomocs,
    #menu .menu_intern > li .menu_internship,
    #menu .menu_intern > li .menu_entry {
        padding: 0.8em 1em;
    }
    #menu .menu_intern > li a .small {
        font-size: 0.74vw;/* 10px */
    }
    #menu .menu_mypage_icon,
    #menu .menu_internship_mypage_icon {
        width: 2em;
        height: 2em;
        left: 0.3em;
    }
    #menu .menu_list {
        font-size: 0.74vw;/* 10px */
        top: 8em;
    }
}
@media screen and (max-width: 970px) {
    #menu .menu_intern > li a {
        /* width: 17.9em; */
    }

    .hd_logo_docomo {
        width: 8.762886597938144vw;
        top: 1.443298969072165;
        right: 7.628865979381443vw;
    }
}
@media screen and (max-width: 640px) {
    #menu {
        display: none;
    }
    #menu_sp .menu_inner {
        padding: 8px 0 120px;
    }
    #menu_sp .menu_list {
        padding: 44px 20px 0;
    }
    #menu_sp .menu-left {
        top: 17px;
        left: 20px;
        width: 100%;
        max-width: 160px;
        transform: translate(0);
    }
    #menu_sp .hd_logo_img {
        width: 160px;
    }
    #menu_sp .menu_parent_ja {
        font-size: 15px;
    }
    #menu_sp .menu_parent_link {
        padding: 0;
    }
    #menu_sp .menu_parent_link_arrow {
        width: 100px;
        height: 24px;
        bottom: 0;
        margin: auto;
    }
    #menu_sp .menu_intern > li a {
        width: 100%;
        height: 50px;
        font-size: 10px;
        letter-spacing: 0;
    }
    #menu_sp .menu_intern_tablet {
        display: none;
    }
    #menu_sp .menu_intern_sp {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        font-size: 0;
    }
    #menu_sp .menu_intern {
        position: initial;
        left: auto;
        top: auto;
        right: auto;
        padding: 0 2%;
    }
    #menu_sp .menu_intern > li {
        width: calc(50% - 1%);
    }
    #menu_sp .menu_intern > li + li {
        margin-left: 0;
    }
    #menu_sp .menu_intern > li:nth-child(n + 3) {
        margin-top: 2%;
    }
    .hd_logo_docomo {
        top: 19px;
        right: 64px;
        width: 60px;
        transform: translateY(0);
    }
    #menu_sp .menu_mypage_icon,
    #menu_sp .menu_internship_mypage_icon {
        left: 6px;
        width: 16px;
        height: 16px;
    }
    #menu_sp .menu_intern > li .menu_internship_mypage,
    #menu_sp .menu_intern > li .menu_mypage {
        padding: 0 4px 0 4px;
    }
    #menu_sp .menu_intern > li a.menu_internship_mypage {
        letter-spacing: -0.04em;
        padding-right: 2px;
    }

    .menu-left {
        top: 24px;
        left: 20px;
        width: 100%;
        max-width: 160px;
        transform: translateY(0);
    }
}




/* 子メニュー */
.menu_child_list {
    font-size: 0;
}
.menu_child_list li {
    font-size: 14px;
}
.menu_child_ttl_en,
.menu_child_ttl_ja {
    display: inline-block;
    vertical-align: bottom;
    line-height: 1;
}
.menu_child_ttl_ja {
    font-size: 18px;
    font-weight: 700;
    padding-left: 40px;
}
.menu-grandchild {
    font-size: 0;
}
/* ドロップダウンメニュー */
.menu_child {
    text-align: left;
    position: absolute;
    background-color: #fff;
}
.menu_child_inner {
    width: 980px;
    margin: auto;
    /* padding: 60px 0; */
}
.menu_parent .menu_child {
    display: none;
    opacity: 0;
    transition: .3s;
}
.mega_menu_link {
    position: relative;
    display: block;
    padding-top: 20px;
    cursor: pointer;
}
.mega_menu_name {
    position: absolute;
    top: 0;
    left: 0;
    background: #cc0033;
    color: #fff;
    display: inline-block;
    font-size: 18px;
    font-weight: 700;
    padding: 0 4px;
    z-index: 1;
}
.mega_menu_name_spacing0 {
    letter-spacing: 0;
}
.mega_menu_name_sub {
    font-size: 0.8em;
    display: inline-block;
}
.mega_menu_arrow {
    position: absolute;
    bottom: -14px;
    right: 0;
    display: block;
    background-color: #fff;
    width: 210px;
    height: 30px;
}
.mega_menu_arrow:before,
.mega_menu_arrow:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}
.mega_menu_arrow:before {
    width: 78%;
    width: calc(92% - 28px);
    height: 1px;
    right: 28px;
    background: #c03;
}
.mega_menu_arrow:after {
    width: 0;
    height: 0;
    right: 10px;
    border-top: 4px solid transparent;
    border-left: 14px solid #c03;
    border-bottom: 4px solid transparent;
}

.mega_menu_img {
    overflow: hidden;
    position: relative;
}
@keyframes navfade {
    0% {
        opacity: 0;
        transform: translateY(-15px);
    }
    100% {
        opacity: 1;
        transform: translateY(0px);
    }
}

#menu_sp .menu_inner {
    display: none;
}
@media screen and (min-width: 1151px) {
    #menu .menu_inner {
        display: block!important;
    }
    #menu .menu_parent:hover .menu_parent_link:before {
        content: '';
        display: block;
        position: absolute;
        width: 100%;
        bottom: 0;
        left: 0;
        height: 4px;
        z-index: 1;
        background: #cc0033;
    }
    .mega_menu_img > img {
        transition: transform .4s ease;
        transform: scale(1);
    } 
    .mega_menu_link:hover .mega_menu_img > img {
        transform: scale(1.08);
        transition: transform .8s ease;
    }
    .menu_parent.is_active .menu_child {
        display: block;
        animation: navfade .2s ease-out forwards;
        height: calc(100vh - 120px);
        max-height: 550px;
        padding: 60px 0 60px;
        overflow-y: scroll;
    }
    /* .menu_parent.is_active .menu_child.thisisdocomo {
        max-height: 748px;
    } */
    .menu_parent:hover .menu_parent_link {
        text-decoration: none;
    }
    .menu_intern > li a {
        transition: opacity .3s;
    }
    .menu_intern > li a:hover {
        opacity: .7;
    }
    .menu_parent {
        position: static;
    }
    .menu_child {
        width: 100%;
        left: 0;
    }
    .menu_child_list li {
        display: inline-block;
        vertical-align: top;
    }
    .menu-grandchild {
        margin: 0 -38px;
    }
    .menu-grandchild > li{
        margin: 60px 40px 0;
    }
    .menu-grandchild_recruit {
        margin: 0 -30px;
    }
    .menu_recruit_left {
        float: left;
        width: 690px;
        position: relative;
    }
    .menu_recruit_left:before {
        content: '';
        display: block;
        height: calc(100% - 60px);
        position: absolute;
        bottom: 0;
        right: 1px;
        width: 1px;
        background: rgba(0,0,0,0.15);
    }
    .menu_recruit_left li {
        margin: 60px 30px 0;
    }
    .menu_career {
        float: left;
    }
    .menu-grandchild_internship {
        margin: 0 -10px;
    }
    .menu-grandchild_internship > li{
        margin: 60px 10px 0;
    }
    .menu-grandchild_internship .mega_menu_name {
        background-color: transparent;
        display: block;
        padding: 0;
    }
    .menu-grandchild_internship .mega_menu_name_in {
        background-color: #cc0033;
        display: inline-block;
        margin-right: 20px;
        padding: 0 5px;
        margin-bottom: 5px;
    }
    .menu-grandchild .menu_career {
        margin-top: 60px;
        margin-left: 50px;
        position: relative;
    }
    .menu_career .mega_menu_name {
        background: #000;
    }
    .mega_menu_link[target="_blank"]:after {
        content: '';
        display: block;
        position: absolute;
        bottom: 10px;
        right: 10px;
        width: 15px;
        height: 15px;
        background: url(../images/ico_new_tab_w.svg) no-repeat;
        background-size: 100% auto;
    }
}
/* ヘッダー修正 */
@media screen and (max-width: 970px) {
    #menu-navibtn:checked ~ * #menu {
        pointer-events: all;
    }
    #menu-navibtn:checked ~ * .menu_parent {
        max-height: inherit;
        overflow-y: visible;
    }
    /* アコーディオン部分初期状態 */
    .menu_child_list li {
        display: none;
    }
    .menu_child_list {
        position: static;
        display: inline;
    }
    /* 子メニュー */
    .menu_child {
        margin-left: initial;
    }
    .menu_list ul li:last-child {
        border-bottom: none;
    }
    .menu_child_list li {
        border-left: 1px solid #FFF;
        border-right: 1px solid #FFF;
    }
    .menu_child_list li ul {
        top: inherit;
        left: 0;
    }
}

/* ハンバーガー */
#navi #navibtn {
    display: block;
    position: absolute;
    top: 48px;
    right: 35px;
    transform: translate(0, -50%);
}
#navibtn span {
    display: none;
    width: 40px;
    height: 40px;
}
#navibtn span span {
    display: block;
    overflow: hidden;
    width: 1px;
    height: 1px;
}
#navibtn span span::before,
#navibtn span span::after,
#navibtn span::after {
    position: absolute;
    left:5px;
    content:"";
    width: 30px;
    height: 2px;
    background-color: #cc0033;
    transition:top 0.3s, bottom 0.3s, transform 0.3s;
}
/* 上の棒 */
#navibtn span span::before {
    top:10px;
}
#menu-navibtn:checked ~ #navi label#navibtn span span::before {
    top:19px;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
}
/* 下の棒 */
#navibtn span::after {
    bottom:10px;
}
#menu-navibtn:checked ~ #navi label#navibtn > span::after {
    bottom:19px;
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
}
/* 中の棒 */
#navibtn span span::after {
    top:19px;
}
#menu-navibtn:checked ~ #navi label#navibtn span span::after {
    display: none;
}
/* ヘッダー修正 */
@media screen and (max-width: 1350px) {
    #navi #navibtn {
        top: 4.5em;
        right: 3em;
    }
}
@media screen and (max-width: 970px) {
    #navibtn span {
        display: block;
    }
}
@media screen and (max-width: 640px) {
    #navi #navibtn {
        top: 10px;
        right: 14px;
        transform: translate(0);
    }
}


.entry_nav_list_wrap {
    display: none;
}
@media screen and (max-width: 640px) {
    .entry_nav_list_wrap {
        display: block;
        position: fixed;
        bottom: 5px;
        left: 0;
        right: 0;
        z-index: 10;
        padding: 0 2%;
    }
    .entry_nav_list {
        text-align: center;
        font-size: 0;
        -webkit-transform: translateY(0);
        transform: translateY(0);
        -webkit-transition: transform 0.3s;
        transition: transform 0.3s;
    }
    .entry_nav_list.is_hide {
        -webkit-transform: translateY(200%);
        transform: translateY(200%);
    }
    .entry_nav_list.is_pagebottom {
        -webkit-transform: translateY(0%);
        transform: translateY(0%);
    }
    .entry_nav_listitem {
        display: inline-block;
        vertical-align: middle;
        width: calc(50% - 1%);
    }
    .entry_nav_listitem + .entry_nav_listitem {
        margin-left: 2%;
    }
    .entry_nav_listitem:nth-child(3) {
        width: 100%;
        margin-top: 1.5%;
        margin-left: 0;
    }
    .entry_nav_listitem:nth-child(4) {
        margin-top: 1.5%;
    }
    .entry_nav_list_link {
        font-size: 10px;
        font-weight: 700;
        letter-spacing: 0;
        display: block;
        height: 50px;
        line-height: 1.5;
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: left;
        flex-wrap: wrap;
    }
    .entry_nav_list_link {

    }
    .entry_nav_list_link:hover {
        text-decoration: none;
    }
    .entry_nav_list_mypage {
        background-color: #fff;
        color: #cc0033;
        border: 1px solid #cc0033;
    }
    .entry_nav_list_entry {
        background-color: #cc0033;
        color: #fff;
        border: 1px solid #cc0033;
    }
    .entry_nav_list_mypage_internship {
        background-color: #fff;
        color: #61b4c9;
        border: 1px solid #61b4c9;
    }
    .entry_nav_list_internship {
        padding: 0 4vw;
        background-color: #279dba;
        color: #fff;
        text-align: center;
    }
    .entry_nav_list_entry_internship {
        background-color: #61b4c9;
        color: #fff;
        border: 1px solid #61b4c9;
    }
    .entry_nav_list_new_docomo,
    .entry_nav_list_new_docomocs {
        background-color: #cc0033;
        color: #fff;
    }
    .entry_nav_list_new_docomocs {
        text-align: center;
    }
    .entry_nav_list_mypage_ico {
        display: inline-block;
        vertical-align: middle;
        width: 12px;
        height: 12px;
        background: url(../images/ico_floating.gif) no-repeat center center;
        background-size: 100% auto;
        margin-right: 3px;
    }
    .entry_nav_list_mypage_internship_ico {
        display: inline-block;
        vertical-align: middle;
        width: 12px;
        height: 12px;
        background: url(../images/ico_floating_blue.gif) no-repeat center center;
        background-size: 100% auto;
        margin-right: 3px;
    }
}
.wrapper {
    padding-top: 195px;
    overflow: hidden;
    display: block;/*IE用*/
}
/* ヘッダー修正 */
@media screen and (max-width: 970px) {
    .wrapper {
        padding-top: 26.32vw;
    }
}
@media screen and (max-width: 640px) {
    .wrapper {
        padding-top: 95px;
    }
}
.page_ttl_wrap {
    background: #cc0033 url(../../common/images/index_noise.gif);
    text-align: center;
    color: #fff;
    position: relative;
}
.page_ttl_wrap:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../images/mv_gradation.png);
    background-size: 100% 100%;
}
.page_ttl_inner {
    padding: 119px 0;
    position: relative;
    z-index: 1;
}
.page_ttl_inner:before ,
.page_ttl_inner:after {
    content: '';
    display: block;
    position: absolute;
}
.page_ttl_inner:before {
    width: 1053px;
    height: 462px;
    left: -668px;
    top: -3px;
    background: url(../images/mv_line_l.png) no-repeat left top;
}
.page_ttl_inner:after {
    width: 1204px;
    height: 559px;
    right: -882px;
    top: -204px;
    background: url(../images/mv_line_r.png) no-repeat right top;
}

.category_ttl {
    border: 6px solid #08f4cc;
    position: absolute;
    top: -56px;
    left: 37px;
    padding: 24px 14px;
    z-index: 1;
    color: #000;
    text-align: left;
    width: 250px;
    height: 250px;
}
.category_ttl span {
    color: #fff;
}
.category_ttl_ja {
    font-size: 18px;
    font-weight: 700;
    color: #cc0033;
    position: relative;
    padding-bottom: 25px;
    margin-bottom: 21px;
}
.category_ttl_ja:after {
    content: '';
    display: block;
    width: 18px;
    height: 4px;
    background: #08f4cc;
    position: absolute;
    bottom: 0;
    left: 0;
}
.category_ttl_en {
    width: auto;
    height: 48.57px;
}
.page_ttl {
    font-weight: 500;
    font-size: 38px;
}
@media screen and (max-width: 980px) {
    .page_ttl_inner {
        padding: 134px 0 104px;
    }
    .page_ttl_inner:before {
        width: 283px;
        height: 347px;
        left: 0;
        top: 91px;
        background: url(../images/mv_line_l_m.png) no-repeat left top;
    }
    .page_ttl_inner:after {
        width: 343px;
        height: 528px;
        right: 0;
        top: -195px;
        background: url(../images/mv_line_r_m.png) no-repeat right top;
    }
    .category_ttl {
        top: -60px;
        border-width: 4px;
        width: 200px;
        height: 200px;
        padding: 30px 7px;
    }
    .category_ttl_ja {
        font-size: 16px;
    }
    .category_ttl_en {
        width: 159px;
    }
}
@media screen and (max-width: 640px) {
    .page_ttl_inner {
        padding: 81px 0 60px;
    }

    .page_ttl_inner:before {
        width: 99px;
        height: 215px;
        left: 0;
        top: 46px;
        background: url(../images/mv_line_l_s.png) no-repeat left top;
        background-size: 100% auto;
    }
    .page_ttl_inner:after {
        width: 110px;
        height: 284px;
        right: 0;
        top: -95px;
        background: url(../images/mv_line_r_s.png) no-repeat right top;
        background-size: 100% auto;
    }
    .page_ttl {
        font-size: 24px;
    }
    .category_ttl {
        top: -35px;
        left: 15px;
        border-width:3px;
        padding: 6px 12px;
        width: 270px;
        height: 88px;
        min-width: 285px;
    }
    .category_ttl_ja {
        font-size: 15px;
        padding-bottom: 11px;
        margin-bottom: 5px;
    }
    .category_ttl_ja span {
        color: #c03;
    }
    .category_ttl_ja:after {
        width: 9px;
        height: 2px;
    }
    .category_ttl_en {
        width: 161px;
    }
}

.container {
    position: relative;
}
.content {
    padding: 0 80px;
}
.content_inner {
    max-width: 1200px;
    margin: auto;
}
@media screen and (max-width: 980px) {
    .content {
        padding: 0 40px;
    }
}
@media screen and (max-width: 640px) {
    .content {
        padding: 0 24px;
    }
}


/*common*/
.nav_list {
    padding-top: 93px;
    padding-bottom: 83px;
    text-align: center;
    font-size: 0;
}
.barlow {
    font-family: 'Barlow Condensed', sans-serif; 
}
.chakra {
    font-family: 'Chakra Petch', sans-serif; 
}
.nav_listitem {
    display: inline-block;
    vertical-align: middle;
    position: relative;
    margin: 40px 0 0;
}
.nav_listitem.is_current .nav_txt {
    color: #cc0033;
}
.nav_listitem.is_current .nav_txt:before {
    content: '';
    display: block;
    position: absolute;
    background: #08f4cc;
    left: 0;
    width: 100%;
    height: 5px;
    bottom: 4px;
    z-index: -1;
}
.nav_listitem:before,
.nav_listitem:last-child:after {
    content: '';
    display: block;
    position: absolute;
    background: #cc0033;
    width: 2px;
    bottom: 5px;
    height: 20px;
}
.nav_listitem:before {
    left: -1px;
}
.nav_listitem:last-child:after {
    right: -1px;
}
.nav_link:not([href]):hover,
.nav_link:hover {
    text-decoration: none;
}
.nav_link {
    font-size: 18px;
    color: #666;
    font-weight: 700;
    padding: 0 40px;
    display: block;
    position: relative;
}
.nav_txt {
    position: relative;
    padding-top: 2px;
    display: inline-block;
}
.nav_num {
    display: block;
    font-size: 14px;
    color: #cc0033;
}
.ttl_line {
    font-size: 26px;
    line-height: 1.5;
    font-weight: 700;
    position: relative;
    padding-bottom: 24px;
}
.ttl_line .line {
    display: block;
    width: 100%;
    height: 1px;
    background: #d7cbcb;
    position: absolute;
    bottom: 0;
    left: 0;
}
.ttl_line .line:after {
    content: '';
    display: block;
    background: #cc0033;
    width: 120px;
    height: 1px;
}
.gaiyo_ttl {
    text-align: center;
    padding-bottom: 52px;
    margin-bottom: 56px;
}
.gaiyo_ttl_word {
    display: inline-block;
}
.gaiyo_ttl .line {
    background: transparent;
}
.gaiyo_ttl .line:after {
    margin: auto;
    height: 4px;
    width: 50px;
}
.cont_gaiyo_wrap {
    padding-top: 250px;
}
.cont_gaiyo {
   position: relative;
   z-index: 1;
}
.cont_gaiyo:before{
    content: '';
    display: block;
    background: #eae7e4;
    height: 100%;
    position: absolute;
    top: 0;
    width: 96.25%;
    right: 0;
}
.cont_gaiyo .content_inner {
    position: relative;
    padding-top: 204px;
    padding-bottom: 111px;
}
.gaiyo_mv {
    background: lightblue;
    text-align: center;
    height: 310px;
    width: 100%;
    position: absolute;
    left: 0;
    top: -220px;
    right: 0;
    margin: auto;
}
.gaiyo_num {
    position: absolute;
    left: 50%;
    top: -18px;
    transform: translateX(-50%);
}
.gaiyo_mv_ttl {
    display: inline-block;
    background: #cc0033;
    color: #fff;
    font-size: 24px;
    padding: 0 17px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.gaiyo_mv_ttl:before {
    content: '';
    display: block;
    position: absolute;
    top: -50px;
    left: 50%;
    width: 1px;
    height: 24px;
    background: #cc0033;
}
.gaiyo_txt {
    width: 65.8%;
    margin: 0 auto;
    line-height: 1.75;
}
.sp_only {
    display: none;
}
@media screen and (max-width: 980px) {
    .gaiyo_mv {
        width: 82.225%;
    }
    .gaiyo_txt {
        width: 82.225%;
    }
    .nav_list {
        width: 500px;
        margin: auto;
    }
    .nav_listitem {
        width: 50%;
    }
    .nav_listitem:nth-child(2):after {
        content: '';
        display: block;
        position: absolute;
        background: #cc0033;
        width: 2px;
        bottom: 5px;
        height: 20px;
        right: 0;
    }
}
@media screen and (max-width: 640px) {
    .nav_list {
        width: auto;
        padding-top: 45px;
        padding-bottom: 60px;
    }
    .nav_listitem {
        width: 41.7%;
        margin: 0 0;
    }
    .nav_listitem::before {
        height: 24px;
    }
    .nav_listitem:last-child:after,
    .nav_listitem:nth-child(2):after {
        height: 24px;
    }
    .nav_link {
        font-size: 14px;
        padding: 0 0;
    }
    .nav_num {
        font-size: 12px;
    }
    .ttl_line .line:after {
        width: 60px;
    }
    .ttl_line {
        font-size: 20px;
        padding-bottom: 10px;
    }
    .gaiyo_ttl {
        padding-bottom: 22px;
        margin-bottom: 25px;
    }
    .gaiyo_ttl .line:after {
        width: 34px;
    }
    .cont_gaiyo:before{
        width: 100%;
    }
    .cont_gaiyo .content_inner {
        padding-top: 95px;
        padding-bottom: 29px;
    }
    .cont_gaiyo_wrap {
        padding-top: 115px;
    }
    .gaiyo_mv {
        width: 100%;
        height: 155px;
        top:-115px;
    }
    .gaiyo_num {
        top: -10px;
    }
    .gaiyo_num img {
        width: 38px;
    }
    .gaiyo_mv_ttl {
        font-size: 16px;
        padding: 0 7px;
    }
    .gaiyo_mv_ttl:before {
        top: -25px;
        height: 16px;
    }
    .gaiyo_txt {
        width: 100%;
        font-size: 14px;
    }
    .sp_only {
        display: block;
    }
}

.pankuzu {
    position: absolute;
    top: 940px;
    right: 26px;
    transform: rotate(90deg);
    transform-origin: 100% 0%;
    width: 900px;
    color: #707070;
    font-size: 14px;
    z-index: 2;
}
.pankuzu_listitem {
    display: inline-block;
    position: relative;
}
.pankuzu_listitem + .pankuzu_listitem {
    padding-left: 20px;
}
.pankuzu_listitem + .pankuzu_listitem:before {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -4px;
    transform: rotate(45deg);
    width: 8px;
    height: 8px;
    border-top: 2px solid #08f4cc;
    border-right: 2px solid #08f4cc;
}
.pankuzu_link {
    color: #cc0033;
    font-weight: 700;
}
@media screen and (max-width: 980px) {
    .pankuzu {
        right: 20px;
    }
}
@media screen and (max-width: 640px) {
    .pankuzu {
        display: none;
    }
}

/* btn_entry */
.btn_entry {
    display: block;
    max-width: 780px;
    width: 100%;
    color: #cc0033;
    background: #fff url(../images/ico_new_tab.svg) no-repeat right 20px bottom 20px;
    background-size: 20px auto;
    margin: 0 auto;
    text-align: center;
    font-weight: 700;
    padding: 35px 0;
    transition: opacity .3s;
}
.btn_entry.btn_entry_non {
    background: #cc0033;
}
.btn_entry:hover {
    text-decoration: none;
}
.btn_entry_en {
    display: block;
    letter-spacing: 0.2em;
    font-size: 50px;
    line-height: 1;
}
.btn_entry_ja {
    letter-spacing: 0.2em;
    display: block;
    line-height: 1;
    margin-top: 14px;
}
@media screen and (min-width: 981px) {
    .btn_entry:hover {
        opacity: .7;
    }
    .btn_entry_non:hover {
        opacity: 1;
    }
}
@media screen and (max-width: 980px) {
    .btn_entry {
        width: 67.57%;
        padding: 22px 0;
        background-size: 14px auto;
    }
    .btn_entry_en {
        font-size: 36px;
    }
    .btn_entry_ja {
        font-size: 12px;
        margin-top: 8px;
    }
}
@media screen and (max-width: 640px) {
    .btn_entry {
        width: 100%;
        padding: 23px 0;
        background-size: 13px auto;
    }
}


/* page_index */
.page_index .page_ttl_wrap {
    text-align: center;
    background: #fff;
    padding: 0;
    color: #000;
}
.page_index .page_ttl_wrap:after {
    display: none;
}
.page_index .container {
    padding-top: 320px;
    padding-bottom: 90px;
    padding-left: 90px;
    padding-right: 90px;
    z-index: 1;
}
.page_index .content {
    padding: 0 60px;
    background: #cc0033 url(../images/index_noise.gif);
}
.page_index .content_inner {
    max-width: 1360px;
    padding-top: 60px;
}
.page_index .page_ttl_inner {
    background: none;
    padding-bottom: 0;
}
.page_index .page_ttl_inner:before {
    left: -587px;
    top:50%;
    margin-top: -20px;
}
.page_index .page_ttl_inner:after {
    right: -805px;
    top: 50%;
    margin-top: -374px;
}
.page_index .page_ttl_ja {
    display: block;
    color: #cc0033;
    font-weight: 700;
    font-size: 48px;
    line-height: 1;
}
.page_index .page_ttl_word {
    display: inline-block;
}
.page_index .page_ttl_en {
    display: block;
    color: #08f4cc;
    font-size: 20px;
    position: relative;
    margin-top: 23px;
    padding-top: 17px;
}
.page_index .page_ttl_en:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 18px;
    height: 4px;
    background:  #08f4cc;
}
.page_index .page_txt {
    margin-top: 43px;
    line-height: 1.75;
    position: relative;
    z-index: 1;
}
.page_index .page_txt_word {
    display: inline-block;
}
.index_list {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    transform: translateY(-180px);
}
.index_listitem {
    width: 45.8825%;
}
.index_listitem:nth-child(even) {
    margin-top: 90px;
}
.index_link {
    position: relative;
    display: block;
}
.index_link_ttl {
    position: absolute;
    top: 8.8%;
    left: 4.8%;
    font-size: 30px;
    z-index: 1;
}
.index_link_ttl_s {
    font-size: 18px;
    margin-right: 150px;
}

@media screen and (max-width: 1920px) {
    .index_link_ttl {
        font-size: 1.5625vw;
    }
    .index_link_ttl_s {
        font-size: 0.9375vw;
    }
}

.index_link_ttl_word {
    display: inline-block;
    vertical-align: top;
    background: #fff;
    color: #cc0033;
    font-weight: 700;
    padding: 8px 11px;
    line-height: 1;
}
.index_link_ttl_word + .index_link_ttl_word {
    margin-top: 10px;
}
.index_link_arrow {
    display: block;
    position: absolute;
    bottom: 0;
    right: 0;
    width: 210px;
    height: 50px;
    background: #fff;
}
.index_link_arrow.red_arrow {
    background: #c03;
}
.red_arrow.index_link_arrow:before {
    background:#fff;
}
.red_arrow.index_link_arrow::after {
    border-left: 14px solid #fff;
}
.index_link_arrow:before,
.index_link_arrow:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}
.index_link_arrow:before {
    width: 78%;
    width: calc(92% - 28px);
    height: 1px;
    right: 28px;
    background:#c03;
}
.index_link_arrow:after {
    width: 0;
    height: 0;
    right: 10px;
    border-top: 4px solid transparent;
    border-left: 14px solid #c03;
    border-bottom: 4px solid transparent;
}
.index_link_subttl {
    color: #fff;
    font-size: 20px;
    font-weight: 700;
    margin-top: 24px;
}
.index_link_txt {
    color: #fff;
    margin: 24px 0 120px;
    line-height: 1.75;
}
@media screen and (min-width: 981px) {
    .index_link{
        overflow: hidden;
    }
    .index_link > img{
        transform: scale(1);
        transition: transform .4s ease;
    }
    .index_link:hover > img{
        transform: scale(1.08);
        transition: transform .8s ease;
    }
}
@media screen and (max-width: 980px) {
    .page_index .container {
        padding-top: 185px;
        padding-left: 60px;
        padding-right: 60px;
    }
    .page_index .content {
        padding: 0 60px;
    }
    .page_index .content_inner {
        padding-top: 60px;
    }
    .page_index .page_ttl_inner  {
        padding-bottom: 0;
    }
    .page_index .page_ttl_inner:before {
        left: -40px;
        margin-top: 63px;
    }
    .page_index .page_ttl_inner:after {
        right: -73px;
        margin-top: -372px;
    }
    .page_index .page_txt {
        width: 56%;
        margin-left: auto;
        margin-right: auto;
        margin-top: 60px;
    }
    .index_link_subttl {
        letter-spacing: 0.05em;
    }
    .index_list {
        transform: translateY(-90px);
    }
    .index_listitem {
        width: 47.0825%;
    }
    .index_listitem:nth-child(even) {
        margin-top: 80px;
    }
    .index_link_ttl_word {
        padding: 6px;
    }
    .index_link_ttl_word + .index_link_ttl_word {
        margin-top: 3px;
    }
    .index_link_arrow {
        width: 45.7%;
        height: 24px;
    }
    .page_index .btn_entry {
        margin-top: 0;
    }
}
@media screen and (max-width: 640px) {
    .page_index .container {
        padding-top: 113px;
        padding-left: 0;
        padding-right: 0;
        padding-bottom: 80px;
    }
    .page_index .content {
        padding: 0 24px 0;
    }
    .page_index .content_inner {
        background-size: 100% auto;
    }
    .page_index .page_ttl_inner {
        padding: 0 24px;
    }
    .page_index .page_ttl_inner:before {
        left: 3px;
        margin-top: -75px;
    }
    .page_index .page_ttl_inner:after {
        right: -19px;
        margin-top: -230px;
    }
    .page_index .page_ttl_ja {
        font-size: 32px;
        line-height: 1.375;
    }
    .page_index .page_ttl_en {
        margin-top: 12px;
        padding-top: 22px;
        font-size: 10px;
    }
    .page_index .page_txt {
        width: 100%;
        margin-top: 33px;
        font-size: 14px;
    }
    .index_list {
        flex-direction: column;
        transform: translateY(-60px);
    }
    .index_listitem {
        width: 100%;
    }
    .index_listitem + .index_listitem,
    .index_listitem:nth-child(even) {
        margin-top: 50px;
    }
    .index_link_ttl {
        font-size: 15px;
    }
    .index_link_ttl_s {
        font-size: 9px;
    }
    .index_link_subttl {
        font-size: 18px;
        margin-top: 18px;
    }
    .index_link_txt {
        font-size: 12px;
        margin-top: 11px;
        margin-bottom: 0;
        line-height: 2.04;
    }
    .index_link_arrow {
        width: 33.8%;
    }
    .index_link_arrow:before {
        width: calc(92% - 22px);
        right: 22px;
    }
    .index_link_arrow:after {
        right: 5px;
        border-top-width: 4px ;
        border-left-width: 7px;
        border-bottom-width: 4px ;
    }
}

/* footer */
.footer {
    background: #262626 url(../images/ft_noise.gif);
    background-size: 100px auto;
    position: relative;
    color: #fff;
    padding: 0 40px;
    padding-top: 5px;
    
}
.footer * {
    letter-spacing: 0;
}
.footer:after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 756px;
    height: 386px;
    background: url(../images/ft_d.png) no-repeat;
    background-size: 100% auto;
    z-index: 1;
}
.footer a {
    color: #fff;
}
.footer .page_top {
    position: absolute;
    top: -147px;
    right: 22px;
    color: #000;
    z-index: 2;
}
.ft_inner {
    background: url(../images/ft_line.png) repeat-y center top;
    background-size: 100% auto;
    max-width: 1360px;
    margin: auto;
    padding-top: 90px;
    padding-bottom: 50px;
    position: relative;
    z-index: 1;
}
.ft_column_container {
    margin-bottom: 95px;
}
.ft_column {
    float: left;
    width: 25%;
}
.ft_column_interview_sp,
.ft_column_thisisdocomo_sp,
.ft_column_work_sp,
.ft_column_internship_sp,
.ft_column_recruit_sp {
    display: none;
}
.ft_column_home,
.ft_column_interview,
.ft_column_thisisdocomo {
    margin-bottom: 30px;
}
.ft_column_talk,
.ft_column_about,
.ft_column_internship {
    margin-bottom: 60px;
}
.ft_column_ttl {
    font-weight: 700;
}
.ft_child_list {
    font-size: 14px;
    margin-top: 30px;
}
.ft_child_listitem {
    padding-left: 20px;
    padding-right: 20px;
}
.ft_child_listitem + .ft_child_listitem {
    margin-top: 5px;
}
.ft_child_link {
    position: relative;
}
.ft_child_link:before {
    content: '';
    display: block;
    position: absolute;
    left: -16px;
    top: 6px;
    width: 0;
    height: 0;
    border-top: 3px solid transparent;
    border-left: 10px solid #cc0033;
    border-bottom: 3px solid transparent;
}
.ft_bottom {
    width: 25%;
    margin-right: 0;
    margin-left: auto;
    font-size: 14px;
}
.ft_bottom_listitem + .ft_bottom_listitem {
    margin-top: 5px;
}
.ft_logo {
    margin-top: 63px;
}
.ft_copy {
    font-size: 12px;
    margin-top: 22px;
}
@media screen and (max-width: 980px) {
    .footer:after {
        width: 73.06%;
        height: 0;
        padding-top: 34.77%;
        background: url(../images/ft_d.png) no-repeat left bottom;
        background-size: 100% auto;
    }
    .ft_inner {
        padding-bottom: 8%;
    }
    .ft_column_container {
        margin-bottom: 0;
    }
}
@media screen and (max-width: 640px) {
    .footer {
        padding: 0 16px 50px;
        z-index: 2;
    }
    .footer .page_top {
        top: -65px;
    }
    .footer .page_top img {
        width: 100%;
    }
    .ft_inner {
        background: url(../images/ft_line_sp.png) repeat-y center top;
        background-size: 100% auto;
        padding-top: 36px;
    }
    .footer:after {
        display: none;
    }
    .ft_bottom:after {
        content: '';
        display: block;
        position: absolute;
        top: -12%;
        left: -15px;
        width: 100%;
        width: calc(100% + 30px);
        height: 0;
        padding-top: 59.77%;
        background: url(../images/ft_d.png) no-repeat left bottom;
        background-size: 106% auto;
        pointer-events: none;
    }
    .ft_column {
        width: 100%;
        float: none;
        margin-bottom: 20px;
    }
    .ft_column_2,
    .ft_column_3,
    .ft_column_4,
    .ft_column_5 {
        justify-content: space-between;
        display: flex;
        flex-wrap: wrap;
    }

    .ft_column_thisisdocomo_pc,
    .ft_column_interview_pc,
    .ft_column_work_pc,
    .ft_column_internship_pc,
    .ft_column_recruit_pc {
        display: none;
    }
    .ft_column_thisisdocomo_sp,
    .ft_column_interview_sp,
    .ft_column_work_sp ,
    .ft_column_internship_sp,
    .ft_column_recruit_sp {
        display: block;
    }
    .ft_column_interview,
    .ft_column_thisisdocomo,
    .ft_column_work,
    .ft_column_talk,
    .ft_column_recruit,
    .ft_column_internship,
    .ft_column_about,
    .ft_column_seminar {
        width: 48%;
    }
    .ft_column_home,
    .ft_column_thisisdocomo,
    .ft_column_interview,
    .ft_column_talk,
    .ft_column_about,
    .ft_column_internship {
        margin-bottom: 0;
    }
    .ft_column_home .ft_column_ttl {
        width: 50%;
    }
    .ft_column_ttl.pc_only {
        display: none;
    }
    .ft_column_ttl {
        font-size: 14px;
        line-height: 1.5;
        display: block;
        position: relative;
    }
    .ft_column_ttl.js_ft_trigger:before,
    .ft_column_ttl.js_ft_trigger:after{
        content: '';
        display: block;
        position: absolute;
        background: #cc0033;
    }
    .ft_column_ttl.js_ft_trigger:before{
        top: 10px;
        right: 5px;
        width: 16px;
        height: 1px;
    }
    .ft_column_ttl.js_ft_trigger:after{
        width: 1px;
        height: 16px;
        right: 12px;
        top: 3px;
        display: block;
    }
    .ft_column_ttl.js_ft_trigger.is_ft_open:after{
        display: none;
    }
    .ft_child_list {
        font-size: 11px;
        margin-top: 18px;
        display: none;
    }
    .ft_child_listitem {
        padding-left: 17px;
        padding-right: 0;
    }
    .ft_child_listitem + .ft_child_listitem {
        margin-top: 14px;
    }
    .ft_child_link:before {
        border-top-width: 2px;
        border-left-width: 8px;
        border-bottom-width: 2px;
    }
    .ft_bottom {
        position: relative;
        width: 100%;
        text-align: center;
        padding-top: 55%;
    }
    .ft_bottom_listitem + .ft_bottom_listitem {
        margin-top: 0;
    }
    .ft_bottom_listitem {
        display: inline-block;
        vertical-align: middle;
        font-size: 11px;
        margin: 0 10px;
    }
    .ft_logo {
        width: 88px;
        margin-top: 20px;
    }
    .ft_copy {
        font-size: 11px;
        margin-top: 5px;
    }
}

a.hover_none {
    text-decoration: none;
    cursor: pointer;
    /* pointer-events: none; */
}
a.hover_none:hover {
    opacity: .7;
}
.index_link.hover_none:hover > img{
    transform: scale(1);
    transition: none;
}


/* page transition */
body:before,
body:after {
    content: '';
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 999;
    will-change: transform;
    background: #cc0033;
}
@-webkit-keyframes move {
    0% {
        -webkit-transform: none;
    }
    100% {
        -webkit-transform: translateY(-50px);
    }
}
@keyframes move {
    0% {
        transform: none;
    }
    100% {
        transform: translateY(-50px);
    }
}

@-webkit-keyframes move2 {
    0% {
        -webkit-transform: translateY(100px);
    }
    100% {
        -webkit-transform: none;
    }
}
@keyframes move2 {
    0% {
        transform: translateY(100px);
    }
    100% {
        transform: none;
    }
}

@-webkit-keyframes loader {
    0% {
        -webkit-transform: translateY(100%);
    }
    100% {
        -webkit-transform: translateY(0);
    }
}
@keyframes loader {
    0% {
        transform: translateY(100%);
    }
    100% {
        transform: translateY(0);
    }
}

@-webkit-keyframes loader2 {
    0% {
        -webkit-transform: translateY(0);
    }
    100% {
        transform: translateY(-100%);
    }
}
@keyframes loader2 {
    0% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(-100%);
    }
}
.is-loadingStart:before {
    display: block;
    -webkit-animation: loader 0.4s cubic-bezier(0.64, 0.04, 0.35, 1) forwards;
    animation: loader 0.4s cubic-bezier(0.64, 0.04, 0.35, 1) forwards;
}
.is-loadingStart #header,
.is-loadingStart #entry_nav_list,
.is-loadingStart #wrapper,
.is-loadingStart #footer {
    -webkit-animation: move 0.4s cubic-bezier(0.64, 0.04, 0.35, 1);
    animation: move 0.4s cubic-bezier(0.64, 0.04, 0.35, 1);
}
.is-loadingEnd:after {
    display: block;
    background: #cc0033;
}
.is-loadingEndStart:after {
    -webkit-animation: loader2 0.4s cubic-bezier(0.64, 0.04, 0.35, 1) forwards;
    animation: loader2 0.4s cubic-bezier(0.64, 0.04, 0.35, 1) forwards;
}

.pointer_hover_none {
    pointer-events: none;
}

/* 採用情報グレーアウト */
.menu_career a.mega_menu_link {
    pointer-events: all;
}
@media screen and (min-width: 981px) {
    .mega_menu_link_comingsoon {
        pointer-events: none;
    }
    .mega_menu_link_comingsoon .mega_menu_img::before {
        content: '';
        width: 213px;
        height: 28px;
        background: url(../images/mega_menu_img_comingsoon.svg) no-repeat center / contain;
        display: block;
        position: absolute;
        right: 0;
        bottom: 0;
        z-index: 11;
    }
    .mega_menu_link_comingsoon .mega_menu_img::after {
        content: '';
        width: 100%;
        height: 100%;
        background: #888;
        display: block;
        opacity: 0.7;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 10;
    }
    .mega_menu_link_comingsoon .mega_menu_name {
        background: #888;
        z-index: 11;
    }
    .mega_menu_link_comingsoon .menu_career .mega_menu_name {
        background: #000;
    }
    .mega_menu_link_comingsoon .menu_career .mega_menu_img::before,
    .mega_menu_link_comingsoon .menu_career .mega_menu_img::after {
        content: none;
    }
}
@media screen and (max-width: 980px) {
    .menu_parent_comingsoon .menu_parent_link {
        pointer-events: none;
    }
    .menu_parent_comingsoon::before {
        content: '';
        width: 297px;
        height: 39px;
        margin: auto;
        background: url(../images/mega_menu_img_comingsoon.svg) no-repeat center / contain;
        display: block;
        position: absolute;
        right: -5%;
        bottom: -40%;
        z-index: 11;
    }
    .menu_parent_comingsoon::after {
        content: '';
        width: 110%;
        height: 180%;
        background: #888;
        display: block;
        opacity: 0.6;
        position: absolute;
        top: -40%;
        left: -5%;
        z-index: 10;
    }
    .menu_parent_comingsoon .menu_parent_link {
        color: #fff;
    }
    .menu_parent_comingsoon .menu_parent_link_arrow {
        display: none;
    }
}
@media screen and (max-width: 640px) {
    .menu_parent_comingsoon::before {
        content: '';
        width: 58.89vw;
        height: 7.63vw;
        background: url(../images/mega_menu_img_comingsoon.svg) no-repeat center / contain;
        display: block;
        position: absolute;
        right: calc(50% - 50vw);
        bottom: -20%;
        z-index: 11;
    }
    .menu_parent_comingsoon::after {
        content: '';
        width: 100vw;
        height: 140%;
        background: #888;
        display: block;
        opacity: 0.6;
        position: absolute;
        top: -20%;
        left: calc(50% - 50vw);
        z-index: 10;
    }
    .menu_parent_comingsoon .menu_parent_link {
        color: #fff;
    }
}

/* comingsoon */
.index_listitem_comingsoon a {
    position: relative;
    pointer-events: none;
}
.index_listitem_comingsoon a::before {
    content: '';
    width: 100%;
    height: 100%;
    background: #888;
    display: block;
    opacity: 0.7;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}
.index_listitem_comingsoon a::after {
    content: '';
    width: 19.9vw;
    height: 2.6vw;
    background: url(../images/comingsoon.svg) no-repeat center / contain;
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: 2;
}
@media screen and (max-width: 980px) {
    .index_listitem_comingsoon a::after {
        width: 22vw;
        height: 2.96vw;
    }
}
@media screen and (max-width: 720px) {
    .index_listitem_comingsoon a::after {
        width: 53.33vw;
        height: 6.94vw;
    }
}

.mega_menu_career.mid_career {
    margin: 80px 40px 0;
    width: 272px;
    position: relative;
    bottom: 0;
    display: inline-flex;
    flex-direction: column;
    gap: 10px;
}
.mega_menu_career.mid_career .top_btn.header {
    display: block;
    padding: 10px 20px;
    background-color: #000;
    color:#fff;
    text-decoration: none;
    box-sizing: border-box;
}
.mega_menu_career.mid_career .top_btn.header:hover {
    width: 100%;
    color:#000;
    border: solid 1px #cc0033;
}
.mega_menu_career.mid_career .top_btn.header:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    transition: width .35s ease;
    background-color: #fff;
}
.mega_menu_career.mid_career .top_btn.header:hover:before {
    width: 100%;
}
.mega_menu_career.mid_career .top_btn.header:after {
    content: '';
    display: block;
    position: absolute;
    bottom: 10px;
    right: 10px;
    background: url(../images/ico_new_tab_w.svg) no-repeat;
    background-size: 100% auto;
    width: 10px;
    height: 10px;
    transition: background .35s ease;
}
.mega_menu_career.mid_career .top_btn.header.group:after {
    display: none;
}
.mega_menu_career.mid_career .top_btn:hover:after {
    background: url(../images/ico_new_tab.svg) no-repeat;
    background-size: 100% auto;
}
.mega_menu_career.mid_career .top_btn_ja.header {
    font-size: 14px;
    font-weight: 700;
    display: block;
    position: relative;
    letter-spacing: 0.2em;
    line-height: 1.2;
}
.mega_menu_career.mid_career .top_btn_en.header {
    font-size: 11px;
    font-weight: 700;
    color: #cc0033;
    margin-top: 5px;
    display: block;
    position: relative;
    letter-spacing: 0.2em;
    line-height: 1.2;
}

/* full_screen */
.full_screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 900;
    background: rgba(0, 0, 0, 0.7);
    transform: translateX(-100%);
    opacity: 0;
    transition: transform 0s 0.4s, opacity 0.4s 0s;
}
.is_play .full_screen {
    transform: translateX(0%);
    opacity: 1;
    transition: transform 0s 0s, opacity 0.4s 0s;
}
.full_screen iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%!important;
    height: 100%!important;
    border: none;
}
.full_screen .close_btn {
    display: block;
    position: absolute;
    cursor: pointer;
    z-index: 100;
    top: 0;
    right: 0;
    background: none;
    padding: 0;
    border: none;
    transform: translateY(-115%);
    appearance: none;
    outline: none;
    width: 50px;
    height: 50px;
}
.full_screen .close_btn::before,
.full_screen .close_btn::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    border-top: 2px solid #fff;
    margin-top: -1px;
}
.full_screen .close_btn::before {
    transform: rotate(45deg) ;
}
.full_screen .close_btn::after {
    transform: rotate(-45deg) ;
}
.iframe_player_api_wrap {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 90%;
    max-width: 800px;
}
.iframe_player_api_cover {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56%;
}



.coming_soon-thumb {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    aspect-ratio: 620/348;
    background: rgba(0, 0, 0, .35);
}
.coming_soon-txt {
    text-align: center;
    font-size: 20px;
    color: #13f4ce;
}


.enginner_blog_wrap {
    width: calc(100% - 160px);
    max-width: 1200px;
    margin: auto;
}
.enginner_blog_container {
    width: 800px;
    margin: 100px auto 0;
    position: relative;
    z-index: 1;
}
.enginner_blog_container_pj {
    width: 800px;
    margin: 0 0 100px;
    position: relative;
    z-index: 1;
}
.enginner_blog_tit {
    background-color: #cc0033;
    color: #fff;
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
    padding: 8px 11px 8px 16px;
    margin: 0 0 15px;
    display: inline-block;
    position: relative;
}
.enginner_blog_tit:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 100%;
    width: 0;
    height: 100%;
    border-top: 5px solid transparent;
    border-left: 6px solid #cc0033;
    border-bottom: 5px solid transparent;
}
.enginner_blog_flex {
    display: flex;
}
.enginner_blog_container {
    width: 800px;
    margin: 100px 0 0;
    position: relative;
    z-index: 1;
}
.enginner_blog_img {
    display: inline-block;
    width: 280px;
    margin-right: 10px;
    position: relative;
    overflow: hidden;
}
.enginner_blog_img::before {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    right: 0;
    background: url(../../../common/images/ico_new_tab_w.svg) no-repeat;
    background-size: 50% auto;
    background-position: center center;
    width: 24px;
    height: 24px;
    background-color: #cc0033;
    transition: background .35s ease;
    z-index: 1;
}
.enginner_blog_img .img {
    max-width: 100%;
    transition: transform .3s ease;
}
.enginner_blog_img:hover .img {
    transform: scale(1.08);
}
.enginner_blog_txtcont {
    width: min(510px);
}
.enginner_blog_txtcon_tit {
    font-size: 18px;
    font-weight: bold;
}
.enginner_blog_txtcon_txt {
    font-size: 14px;
}
.enginner_blog_txtcon_btnwrap {
    display: flex;
    justify-content: end;
    align-items: center;
    position: absolute;
    bottom: 0;
    right: 0;
    color: #cc0033;
}
.enginner_blog_txtcon_btn {
    font-size: 14px;
    font-weight: bold;
    margin-right: 210px;
}
.enginner_blog_txtcon_arrow {
    display: block;
    position: absolute;
    right: 0;
    width: 210px;
    height: 30px;
    background: #fff;
}
.enginner_blog_txtcon_arrow:before,
.enginner_blog_txtcon_arrow:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}
.enginner_blog_txtcon_arrow:before {
    width: 78%;
    width: calc(92% - 28px);
    height: 1px;
    right: 28px;
    background: #c03;
}
.enginner_blog_txtcon_arrow:after {
    width: 0;
    height: 0;
    right: 10px;
    border-top: 4px solid transparent;
    border-left: 14px solid #f03;
    border-bottom: 4px solid transparent;
}

@media screen and (max-width:980px) {
    .enginner_blog_container,
    .enginner_blog_container_pj {
        width: 100%;
    }
    .enginner_blog_img {
        width: 35%;
        margin-right: 1.25%;
    }
    .enginner_blog_txtcont {
        width: 63.75%;
    }
}

@media screen and (max-width:640px) {
    .enginner_blog_wrap {
        width: calc(100% - 48px);
    }
    .enginner_blog_flex {
        display: inline-block;
    }
    .enginner_blog_container {
       width: 100%;
    }
    .enginner_blog_img {
        width: 100%;
        position: relative;
        margin-right: 0;
    }
    .enginner_blog_txtcont {
        width: calc(100vw - 48px);
        margin: 16px 0 0;
    }
    .enginner_blog_txtcon_txt {
        word-break: break-all;
    }
    .enginner_blog_txtcon_btnwrap {
        justify-content: flex-start;
        align-items: center;
        position: relative;
        color: #cc0033;
        margin: 5px 0 0;
    }
    .enginner_blog_txtcon_btn {
        font-size: 14px;
        font-weight: bold;
        margin-right: 0;
    }
    .enginner_blog_txtcon_arrow {
        display: block;
        position: relative;
        top: 0;
        bottom: auto;
        right: 0;
        width: 150px;
        height: 30px;
        background: #fff;
    }
    .enginner_blog_txtcon_arrow:after {
        width: 0;
        height: 0;
        right: 14px;
        border-top: 4px solid transparent;
        border-left: 14px solid #f03;
        border-bottom: 4px solid transparent;
    }
}