  @charset "utf-8";

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@200;300;400;600;800&family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap');

/* ────────────────────── *
 *                                              *
 * 基本設定                                     *
 *                                              *
 * ────────────────────── */

html {
    font-size: calc(1em * 0.625);
}
body {
    font-family: "YakuHanJP_Noto", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    line-height: 1;
    font-weight: 400;
    color: #363746;
    padding-left: 18.5rem;
}
img {
    max-width: 100%;
    height: auto;
}
.sp {
    display: none;
}
.fadeinSlick{
    opacity: 0;
    transition: opacity 1.4s;
}
.fadeinSlick.showin {
    opacity: 1;
    transition: opacity 1.4s;
}

/* ────────────────────── *
 *                                              *
 * ヘッダー                                     *
 *                                              *
 * ────────────────────── */

#header {
    background: #fff;
    width: 18.5rem;
    height: 100vh;
    padding-top: 4.0rem;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 100;
    box-sizing: border-box;
}
#header #logo {
    font-family: "Manrope", sans-serif;
    font-size: 1.0rem;
    margin-left: 3.0rem;
    margin-bottom: 10.0rem;
    position: relative;
    z-index: 115;
}
#header #logo h1,
#header #logo p {
    letter-spacing: 0.1em;
    text-align: left;
    display: inline-block;
}
#header #logo img {
    display: block;
    width: 5.2rem;
    margin: 0 auto 2.0rem;
}
#header #logo a {
    color: #363746;
    text-align: left;
    display: block;
}

/* メガメニュー */
#header #megamenu {
    font-size: 1.3rem;
    font-weight: 500;
    font-feature-settings: "palt" 1;
    margin-bottom: 4.0rem;
    position: relative;
}
#header #megamenu ul#gnavi > li p a {
    color: #363746;
    display: block;
    padding: 1.0rem 0 1.0rem 3.0rem;
    overflow: hidden;
}
#header #megamenu ul#gnavi > li:hover p a {
    color: #006ee1;
}
#header #megamenu ul#gnavi > li p a span.line {
    display: inline-block;
    position: relative;
}
#header #megamenu ul#gnavi > li p a span.line::after {
    content: "";
    background: #006ee1;
    width: 5.0rem;
    height: 0.2rem;
    position: absolute;
    left: calc(100% + 1.0rem);
    top: 50%;
    transition: transform .2s;
    transform: scaleX(0) translateY(-50%);
    transform-origin: left;
}
#header #megamenu ul#gnavi > li:hover p a span.line::after {
    transform: scaleX(1) translateY(-50%);
}
#header #megamenu ul#gnavi > li .submenu {
    background: #006ee1;
    width: 0;
    height: 100vh;
    padding-top: 6.0rem;
    position: fixed;
    left: 18.5rem;
    top: 0;
    overflow: hidden;
    box-sizing: border-box;
    opacity: 0;
    visibility: hidden;
    transition: all .3s ease .2s;
    pointer-events: none;
}
#header #megamenu ul#gnavi > li:hover .submenu {
    width: 33.0rem;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}
#header #megamenu ul#gnavi > li .submenu ul {
    width: 24.0rem;
    padding: 0 4.5rem;
    margin: 0 auto;
}
#header #megamenu ul#gnavi > li .submenu ul li {
    margin-bottom: 4.5rem;
    position: relative;
}
#header #megamenu ul#gnavi > li .submenu ul li:last-child {
    margin-bottom: 0;
}
#header #megamenu ul#gnavi > li .submenu ul li a {
    display: block;
}
#header #megamenu ul#gnavi > li .submenu ul li .image {
    width: 100%;
    overflow: hidden;
}
#header #megamenu ul#gnavi > li .submenu ul li .image img {
    transform: scale(1);
    opacity: 1;
    transition: opacity .5s, transform .5s;
}
#header #megamenu ul#gnavi > li .submenu ul li a:hover .image img {
    transform: scale(1.1);
    opacity: 0.8;
}
#header #megamenu ul#gnavi > li .submenu ul li .cname {
    font-size: 1.4rem;
    font-weight: 500;
    font-feature-settings: "palt" 1;
    color: #fff;
    letter-spacing: 0.05em;
    position: absolute;
    left: 0;
    bottom: -1.4rem;
}
#header #megamenu ul#gnavi > li .submenu ul li .cname span {
    background : -moz-linear-gradient(21.6% -159% -45deg,rgba(202, 100, 128, 1) 0%,rgba(80, 152, 255, 1) 100%);
    background : -webkit-linear-gradient(-45deg, rgba(202, 100, 128, 1) 0%, rgba(80, 152, 255, 1) 100%);
    background : -webkit-gradient(linear,21.6% -159% ,78.4% 259% ,color-stop(0,rgba(202, 100, 128, 1) ),color-stop(1,rgba(80, 152, 255, 1) ));
    background : linear-gradient(135deg, rgba(202, 100, 128, 1) 0%, rgba(80, 152, 255, 1) 100%);
    display: inline-block;
    padding: 0.5rem;
    margin-top: 1px;
}

/* ボタン */
#header dl.header-btn {
    width: 14.0rem;
    margin-left: 2.0rem;
}
#header dl.header-btn dt {
    font-size: 1.1rem;
    font-weight: 500;
    margin-bottom: 1.0rem;
}
#header dl.header-btn dd {
    margin-bottom: 2.0rem;
}
#header dl.header-btn dd:last-of-type {
    margin-bottom: 0;
}
#header ul.btn {
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-align: center;
    width: 14.0rem;
}
#header ul.btn li {
    margin-bottom: 0.5rem;
}
#header ul.btn li:last-child {
    margin-bottom: 0;
}
#header ul.btn li a {
    color: #363746;
    background: #d0d6d7;
    vertical-align: middle;
    display: table-cell;
    width: 14.0rem;
    height: 3.5rem;
    border-radius: 9999px;
    transition: color .5s, background .5s;
}
#header ul.btn li a:hover {
    color: #fff;
    background: #363746;
}
#header ul.btn li span.disabled {
    font-feature-settings: "palt" 1;
    color: #d0d6d7;
    background: #fff;
    letter-spacing: 0.05em;
    vertical-align: middle;
    display: table-cell;
    width: 14.0rem;
    height: 3.5rem;
    border: 1px solid #d0d6d7;
    border-radius: 3.5rem;
    transition: color .5s, background .5s;
}

#header ul.btn li.internship {
    font-size: 1.2rem;
    font-weight: 500;
    font-feature-settings: "palt" 1;
    letter-spacing: normal;
    margin-top: 2.0rem;
}
#header ul.btn li.internship a {
    color: #fff;
    background: #363746;
}
#header ul.btn li.internship a:hover {
    color: #363746;
    background: #d0d6d7;
}
#header ul.btn li.mypage {
    font-size: 1.2rem;
    font-weight: 500;
}
#header ul.btn li.mypage a {
    color: #fff;
    background: #f02832;
}
#header ul.btn li.mypage a:hover {
    background: #006ee1;
}

/* 外部リンク */
#header ul.external {
    font-size: 1.2rem;
    font-feature-settings: "palt" 1;
    width: 14.0rem;
    position: absolute;
    left: 3.0rem;
    bottom: 2.0rem;
}
#header ul.external li a {
    color: #363746;
    display: inline-block;
    position: relative;
}
#header ul.external li a:hover {
    text-decoration: underline;
}
#header ul.external li a:after {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2010%208%22%20style%3D%22enable-background%3Anew%200%200%2010%208%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23363746%3B%7D%3C%2Fstyle%3E%3Cg%3E%20%3Cg%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M6.9%2C1.1v3.7H1V1.1H6.9%20M7.9%2C0.1H0v5.7h7.9V0.1L7.9%2C0.1z%22%2F%3E%20%3C%2Fg%3E%20%3Cg%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M8.9%2C3.1v3.7H3V3.1H8.9%20M9.9%2C2.1H2v5.7h7.9V2.1L9.9%2C2.1z%22%2F%3E%20%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: 0 0;
    width: 1.0rem;
    height: 0.8rem;
    position: absolute;
    left: calc(100% + 0.5rem);
    top: 50%;
    transform: translateY(-50%);
}

/* ────────────────────── *
 *                                              *
 * ナビゲーション                               *
 *                                              *
 * ────────────────────── */

/* 二本ボタン */
#header #hnavi p#btn-menu {
    background: #364246;
    width: 4.5rem;
    height: 4.5rem;
    position: fixed;
    right: 2.0rem;
    top: 2.0rem;
    z-index: 110;
    border-radius: 50%;
}
#header #hnavi p#btn-menu a {
    display: block;
    width: 100%;
    height: 100%;
}
#header #hnavi p#btn-menu span {
    background: #fff;
    display: block;
    width: 1.5rem;
    height: 1px;
    position: absolute;
    left: 1.5rem;
    transition: transform .5s;
}
#header #hnavi p#btn-menu span:nth-of-type(1) {
    top: 1.9rem;
}
#header #hnavi p#btn-menu span:nth-of-type(2) {
    top: 2.5rem;
}
#header #hnavi p#btn-menu a.active span:nth-of-type(1) {
    transform: translateY(0.3rem) rotate(-315deg);
}
#header #hnavi p#btn-menu a.active span:nth-of-type(2) {
    transform: translateY(-0.3rem) rotate(315deg);
}

#header #hnavi nav > dl.header-btn {
    display: none;
}


/* ナビゲーション本体 */
#header #hnavi nav {
    background: #fff;
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    bottom: 100%;
    z-index: 100;
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    transition: bottom .75s;
}
#header #hnavi nav.open {
    bottom: 0;
}
#header #hnavi nav .center {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
#header #hnavi nav .col {
    font-feature-settings: "palt" 1;
    letter-spacing: 0.03em;
}
#header #hnavi nav .col dl {
    padding: 1.0rem 5.0rem;
    margin-bottom: 4.0rem;
}
#header #hnavi nav .col dl:last-of-type {
    margin-bottom: 0;
}
#header #hnavi nav .col:nth-of-type(1) dl,
#header #hnavi nav .col:nth-of-type(2) dl {
    border-right: 1px solid #d0d6d7;
}
#header #hnavi nav .col dl dt {
    font-size: 2.6rem;
    font-weight: 300;
    color: #9a9ba2;
    margin-bottom: 2.5rem;
    pointer-events: none;
}
#header #hnavi nav .col dl dt a {
    color: #9a9ba2;
}
#header #hnavi nav .col dl dd {
    font-size: 1.5rem;
    font-weight: 500;
}
#header #hnavi nav .col:nth-of-type(2) dl dd ul.c02 {
    margin-bottom: 3.0rem;
}
#header #hnavi nav .col dl dd ul li {
    margin-bottom: 1.5rem;
    position: relative;
}
#header #hnavi nav .col dl dd ul li:last-child {
    margin-bottom: 0;
}
#header #hnavi nav .col dl dd ul li a {
    color: #363746;
    padding-left: 2.0rem;
}
#header #hnavi nav .col dl dd ul li a::before {
    content: "";
    background: #d0d6d7;
    width: 0.6rem;
    height: 0.6rem;
    position: absolute;
    left: 0;
    top: 0.6rem;
}
#header #hnavi nav .col dl.c01 dd ul li a:hover {
    color: #f02832;
    text-decoration: underline;
}
#header #hnavi nav .col dl.c02 dd ul li a:hover {
    color: #006ee1;
    text-decoration: underline;
}
#header #hnavi nav .col dl.c01 dd ul li a::before {
    background: #f02832;
}
#header #hnavi nav .col dl.c02 dd ul li a::before {
    background: #006ee1;
}

/* ボタン */
#header #hnavi nav .center dl.header-btn {
    width: auto;
    margin-left: 0;
    position: absolute;
    right: 0;
    bottom: -2.0rem;
    z-index: 110;
}
#header #hnavi nav .center ul.btn {
    width: auto;
    margin-left: 0;
    display: flex;
}
#header #hnavi nav .center ul.btn li {
    width: 14.0rem;
    margin-bottom: 0;
    margin-right: 0.5rem;
}
#header #hnavi nav .center ul.btn li:last-child {
    margin-right: 0;
}
#header #hnavi nav .center ul.btn li.internship {
    margin-top: 0;
}

/* ────────────────────── *
 *                                              *
 * 著作権表記                                   *
 *                                              *
 * ────────────────────── */

#copyright {
    font-family: "Manrope", sans-serif;
    font-size: 1.0rem;
    font-weight: 300;
    font-feature-settings: "palt" 1;
    color: #fff;
    background: #364246;
    letter-spacing: 0.05em;
    text-align: right;
    width: 100%;
    padding: 2.0rem;
    box-sizing: border-box;
    position: relative;
}
#copyright p.external {
    display: none;
}
#copyright small {
    color: rgba(255, 255, 255, 0.7);
}
