  @charset "utf-8";

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

body {
    padding-left: 0;
}
#header {
    background: #fff;
    width: 17.0rem;
    height: 19.0rem;
    padding-top: 4.0rem;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 100;
    box-sizing: border-box;
}
#header #logo {
    margin-bottom: 0;
}
#header #hnavi {
    display: none;
}
ul.btn-internship {
    font-size: 1.5rem;
    font-weight: 500;
    text-align: center;
    position: absolute;
    right: 3.5rem;
    top: 3.0rem;
    z-index: 10;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
ul.btn-internship li {
    padding: 0 3.5rem;
    position: relative;
}
ul.btn-internship li a {
    color: #fff;
    display: block;
    position: relative;
}
ul.btn-internship li a:hover {
    text-decoration: underline;
}
ul.btn-internship li.external::before {
    content: "";
    background: #fff;
    width: 1px;
    height: 2.5rem;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
ul.btn-internship li.external a {
    padding-right: 2.2rem;
}
ul.btn-internship li.external 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%20viewBox%3D%220%200%2014%2011%22%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20style%3D%22enable-background%3Anew%200%200%2014%2011%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cg%3E%3Cg%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M10%2C1.2V7H1.2V1.2H10%20M11.2%2C0H0v8.1h11.2V0L11.2%2C0z%22%2F%3E%3C%2Fg%3E%3Cg%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M12.8%2C4v5.8H4V4H12.8%20M14%2C2.9H2.8V11H14V2.9L14%2C2.9z%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 1.4rem;
    height: 1.1rem;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}
ul.btn-internship li.internship-entry {
    font-family: "Manrope", sans-serif;
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    padding: 0;
    margin-right: 1.0rem;
    position: relative;
}
/*
ul.btn-internship li.internship-entry::before {
    content: "";
    background: rgba(0, 0, 0, 0.5);
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
}
*/
ul.btn-internship li.internship-entry a {
    color: #fff;
    background: #f02832;
    vertical-align: middle;
    display: table-cell;
    width: 17.0rem;
    height: 4.0rem;
    transition: color .5s, background .5s;
}
ul.btn-internship li.internship-entry a:hover {
    text-decoration: none;
    background: #006ee1;
}
ul.btn-internship li.internship-entry span.disabled {
    color: #fff;
    background: #f02832;
    vertical-align: middle;
    display: table-cell;
    width: 17.0rem;
    height: 4.0rem;
    transition: color .5s, background .5s;
}
ul.btn-internship li.internship-mypage {
    font-family: "Manrope", sans-serif;
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    padding: 0;
    margin-right: 0;
    position: relative;
}
/*
ul.btn-internship li.internship-mypage::before {
    content: "";
    background: rgba(0, 0, 0, 0.5);
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
}
*/
ul.btn-internship li.internship-mypage a {
    color: #fff;
    background: #868790;
    vertical-align: middle;
    display: table-cell;
    width: 17.0rem;
    height: 4.0rem;
    transition: color .5s, background .5s;
}
ul.btn-internship li.internship-mypage a:hover {
    text-decoration: none;
    background: #363746;
}
ul.btn-internship li.internship-mypage span.disabled {
    color: #fff;
    background: #868790;
    vertical-align: middle;
    display: table-cell;
    width: 17.0rem;
    height: 4.0rem;
    transition: color .5s, background .5s;
}
#copyright {
    background: #363746;
}
#copyright ul {
    font-size: 1.2rem;
    line-height: 1.25;
    text-align: left;
    position: absolute;
    left: 3.0rem;
    top: 50%;
    transform: translateY(-50%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
#copyright ul li {
    padding-right: 1.5rem;
    margin-right: 1.5rem;
    border-right: 1px solid #fff;
}
#copyright ul li:last-child {
    padding-right: 0;
    margin-right: 0;
    border-right: none;
}
#copyright ul li a {
    color: #fff;
    display: block;
    position: relative;
}
#copyright ul li a:hover {
    text-decoration: underline;
}
#copyright ul li.external 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%20viewBox%3D%220%200%2014%2011%22%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20style%3D%22enable-background%3Anew%200%200%2014%2011%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cg%3E%3Cg%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M10%2C1.2V7H1.2V1.2H10%20M11.2%2C0H0v8.1h11.2V0L11.2%2C0z%22%2F%3E%3C%2Fg%3E%3Cg%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M12.8%2C4v5.8H4V4H12.8%20M14%2C2.9H2.8V11H14V2.9L14%2C2.9z%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 1.0rem;
    height: 0.78rem;
    position: absolute;
    left: 100%;
    top: 50%;
    transform: translateY(-50%);
}

/* ────────────────────── *
 *                                              *
 * ページ共通                                   *
 *                                              *
 * ────────────────────── */

/* 見出し */
#title {
    color: #fff;
    width: 100%;
    height: calc(100vw * 900 / 1600);
    min-height: 90.0rem;
    box-sizing: border-box;
    position: relative;
}
.internship-index #title {
    background: url("/saiyou/image/internship/index/mainvisual.jpg") no-repeat center center / cover;
}
.internship-office #title {
    background: url("/saiyou/image/internship/office/mainvisual.jpg") no-repeat center center / cover;
}
.internship-tech #title {
    background: url("/saiyou/image/internship/tech/mainvisual.jpg") no-repeat center center / cover;
}
#title .inner {
    text-align: center;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
#title .inner h1 {
    font-size: 4.5rem;
    font-weight: 300;
    letter-spacing: 0.1em;
    margin-bottom: 2.0rem;
}
#title .inner h1 em {
    font-weight: 700;
    font-style: normal;
}
#title .inner p.en {
    font-family: "Manrope", sans-serif;
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: 0.15em;
}

/* INDEX */
.internship-index #title .inner h1 {
    font-size: 5.6rem;
    font-feature-settings: "palt" 1;
    letter-spacing: -0.08em;
    margin-top: -7.5rem;
    position: relative;
    z-index: 1;
}
.internship-index #title .inner p.en {
    width: 98.0rem;
    filter: blur(1px);
}

/* 事務職向け */
.internship-office #title .inner h1 {
    font-size: 6.4rem;
    line-height: 1.375;
    font-weight: 400;
    letter-spacing: normal;
    margin-bottom: 3.0rem;
}
.internship-office #title .inner p.target {
    font-size: 2.6rem;
    font-weight: 500;
    background: rgba(240, 40, 50, 0.95);
    display: inline-block;
    padding: 1.0rem 1.5rem;
    margin-bottom: 2.0rem;
}
.internship-office #title .inner p.subtitle {
    font-size: 2.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

/* 技術職向け */
.internship-tech #title .inner h1 {
    font-size: 6.4rem;
    line-height: 1.375;
    font-weight: 400;
    letter-spacing: normal;
    margin-bottom: 3.0rem;
}
.internship-tech #title .inner p.target {
    font-size: 2.6rem;
    font-weight: 500;
    background: rgba(0, 110, 225, 0.95);
    display: inline-block;
    padding: 1.0rem 1.5rem;
    margin-bottom: 2.0rem;
}
.internship-tech #title .inner p.subtitle {
    font-size: 2.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

/* コンテンツ枠 */
.contents {
    width: 100%;
}
.contents .inner {
    width: 108.0rem;
    margin: 0 auto;
}

/* ページネーション */
p.pagination {
    font-family: "Manrope", sans-serif;
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-align: center;
    width: 8.0rem;
    position: absolute;
    left: 50%;
    bottom: 0;
    z-index: 10;
    transform: translateX(-50%);
}
p.pagination::after {
    content: "";
    background: #fff;
    width: 1px;
    height: 5.5rem;
    position: absolute;
    left: 50%;
    bottom: 0;
}
p.pagination a,
p.pagination span {
    display: block;
    padding-bottom: 6.5rem;
}

/* ────────────────────── *
 *                                              *
 * コンセプト                                   *
 *                                              *
 * ────────────────────── */

#concept {
    color: #fff;
    background: url("/saiyou/image/internship/index/bg-concept.jpg") no-repeat center center / cover;
    width: 100%;
    height: calc(100vw * 900 / 1600);
    min-height: 90.0rem;
    padding-top: 11.0rem;
    position: relative;
    box-sizing: border-box;
}
#concept .inner {
    width: 80.0rem;
    margin: 0 auto;
}
#concept .inner h2 {
    font-size: 1.5rem;
    font-weight: 500;
    text-align: center;
    margin-bottom: 8.0rem;
}
#concept .inner p.en {
    font-family: "Manrope", sans-serif;
    font-feature-settings: "palt" 1;
    font-size: 6.4rem;
    font-weight: 200;
    text-align: center;
    margin-bottom: 3.0rem;
}
#concept .inner .vertical {
    font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.8rem;
    line-height: 3.33;
    letter-spacing: 0.1em;
    width: 100%;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: upright;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

/* ────────────────────── *
 *                                              *
 * プログラム                                   *
 *                                              *
 * ────────────────────── */

#program {
    background: #fff;
    width: 100%;
    padding-top: 11.0rem;
    padding-bottom: 20.0rem;
    position: relative;
    box-sizing: border-box;
}
#program .inner {
    width: 80.0rem;
    margin: 0 auto;
}
#program .inner h2 {
    font-size: 1.5rem;
    font-weight: 500;
    text-align: center;
    margin-bottom: 8.0rem;
}
#program .inner p.en {
    font-family: "Manrope", sans-serif;
    font-feature-settings: "palt" 1;
    font-size: 6.4rem;
    font-weight: 200;
    text-align: center;
    margin-bottom: 3.0rem;
}
#program .flex {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#program .flex .item {
    width: 50%;
    position: relative;
}
#program .flex .item a {
    color: #fff;
    display: block;
}
#program .flex .item p.image {
    overflow: hidden;
}
#program .flex .item p.image img {
    width: 100%;
    transform: scale(1);
    opacity: 1;
    transition: opacity .5s, transform .5s;
}
#program .flex .item a:hover p.image img {
    transform: scale(1.1);
    opacity: 0.8;
}
#program .flex .item dl {
    width: 100%;
    position: absolute;
    left: 50%;
    top: 40%;
    transform: translate(-50%, -50%);
}
#program .flex .item dl dt {
    font-size: 3.6rem;
    line-height: 1.5;
    margin-bottom: 3.0rem;
}
#program .flex .item dl dd {
    font-size: 2.0rem;
    font-weight: 700;
}
#program .flex .item p.btn {
    font-size: 1.8rem;
    font-weight: 500;
    width: 51.0rem;
    padding: 3.6rem;
    margin: -5.0rem auto 0;
    box-sizing: border-box;
    position: relative;
    z-index: 2;
}
#program .flex .item p.btn::after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0.5rem 0 0.5rem 1.0rem;
    border-color: transparent transparent transparent #fff;
    position: absolute;
    right: 4.0rem;
    top: 50%;
    transform: translateY(-50%);
}
#program .flex .item:nth-of-type(1) p.btn {
    background: rgba(240, 40, 50, 0.95);
}
#program .flex .item:nth-of-type(2) p.btn {
    background: rgba(0, 110, 225, 0.95);
}

/* ────────────────────── *
 *                                              *
 * エントリー                                   *
 *                                              *
 * ────────────────────── */

#entry {
    width: 100%;
    position: relative;
    box-sizing: border-box;
}
#entry a {
    color: #fff;
    display: block;
}
#entry span.disabled {
    color: #fff;
    display: block;
}
#entry .inner {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
#entry p.image {
    overflow: hidden;
}
#entry p.image img {
    width: 100%;
    transform: scale(1);
    opacity: 1;
    transition: opacity .5s, transform .5s;
}
#entry a:hover p.image img {
    transform: scale(1.1);
    opacity: 0.8;
}
#entry h2 {
    font-size: 1.8rem;
    font-weight: 500;
    text-align: center;
}
#entry p.en {
    font-family: "Manrope", sans-serif;
    font-size: 6.2rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-align: center;
    margin-bottom: 3.0rem;
}

/* ────────────────────── *
 *                                              *
 * 詳細                                         *
 *                                              *
 * ────────────────────── */

.contents #detail {
    min-height: 100vh;
    position: relative;
}
.contents #detail .anchor {
    background: url("/saiyou/image/internship/office/bg-anchor.jpg") no-repeat center center / cover;
    width: 30%;
    height: 100vh;
    padding-top: 12.0rem;
    position: absolute;
    left: 0;
    top: 0;
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}
.contents #detail .anchor.position-under {
    display: none;
}
.contents #detail .anchor.fixed {
    position: fixed;
}
.contents #detail .anchor.active {
    top: auto;
    bottom: 0;
}
.contents #detail .anchor ol {
    font-size: 1.9rem;
    font-weight: 500;
    padding-right: 15%;
}
.contents #detail .anchor ol li {
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 2.5rem;
}
.contents #detail .anchor ol li.active {
    color: #fff;
}
.contents #detail .anchor ol li span.num {
    font-family: "Manrope", sans-serif;
    font-size: 2.0rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    display: inline-block;
    width: 3.0rem;
}


.contents #detail .outline {
    width: calc(100% - 30% - 8.125%);
    padding-top: 4.0rem;
    margin-left: auto;
}
.contents #detail .outline .section {
    max-width: 79.0rem;
    padding: 8.0rem 0;
    border-bottom: 1px solid #d7d7da;
    position: relative;
}
.contents #detail .outline .section:last-of-type {
    border-bottom: none;
}
.contents #detail .outline a {
    text-decoration: underline;
}
.internship-office .contents #detail .outline a {
    color: #f02832;
}
.internship-tech .contents #detail .outline a {
    color: #006ee1;
}
.contents #detail .outline h2 {
    font-size: 3.2rem;
    line-height: 1.71875;
    font-weight: 500;
    padding-left: 2.5rem;
    margin-bottom: 4.0rem;
}
.internship-office .contents #detail .outline h2 {
    border-left: 0.5rem solid #f02832;
}
.internship-tech .contents #detail .outline h2 {
    border-left: 0.5rem solid #006ee1;
}
.contents #detail .outline #map {
    width: 33.8rem;
    position: absolute;
    top: 7.5rem;
    right: -5.0rem;
}
.contents #detail .outline p.txt {
    font-size: 1.6rem;
    line-height: 1.875;
}
.contents #detail .outline .zeropadding {
    opacity: 0;
}
.contents #detail .outline dl.txt {
    font-size: 1.6rem;
    line-height: 1.875;
}
.contents #detail .outline dl.txt > dt {
    font-weight: 500;
}
.internship-office .contents #detail .outline dl.txt > dt {
    color: #f02832;
}
.internship-tech .contents #detail .outline dl.txt > dt {
    color: #006ee1;
}
.contents #detail .outline dl.txt > dd {
    margin-bottom: 3.0rem;
}
.contents #detail .outline dl.txt > dd:last-of-type {
    margin-bottom: 0;
}
.contents #detail .outline dl.txt > dd dl.breakdown {
    display: flex;
}
.contents #detail .outline dl.txt > dd dl.breakdown dt {
    width: 8.2em;
}
.contents #detail .outline .txt + .txt {
    margin-top: 3.0rem;
}
.contents #detail .outline ul.list {
    font-size: 1.6rem;
    line-height: 1.875;
}
.contents #detail .outline ul.list li::before {
    content: "● ";
    color: #f02832;
}
.contents #detail .outline ol.list {
    font-size: 1.6rem;
    line-height: 1.875;
    list-style-type: decimal;
    margin-left: 2.0rem;
}
.contents #detail .outline ul.voice {
    font-size: 1.6rem;
    line-height: 1.875;
    text-align: justify;
}
.contents #detail .outline ul.voice li {
    padding-left: 8.0rem;
    margin-bottom: 6.0rem;
    position: relative;
}
.contents #detail .outline ul.voice li:last-child {
    margin-bottom: 0;
}
.contents #detail .outline ul.voice li::before {
    content: "";
    width: 5.6rem;
    height: 5.1rem;
    position: absolute;
    left: 0;
    top: 0.5rem;
}
.internship-office .contents #detail .outline ul.voice li:nth-child(1)::before {
    background: url("/saiyou/image/internship/office/icon-voice-01.png") no-repeat center center / cover;
}
.internship-office .contents #detail .outline ul.voice li:nth-child(2)::before {
    background: url("/saiyou/image/internship/office/icon-voice-02.png") no-repeat center center / cover;
}
.internship-office .contents #detail .outline ul.voice li:nth-child(3)::before {
    background: url("/saiyou/image/internship/office/icon-voice-03.png") no-repeat center center / cover;
}
.internship-tech .contents #detail .outline ul.voice li:nth-child(1)::before {
    background: url("/saiyou/image/internship/tech/icon-voice-01.png") no-repeat center center / cover;
}
.internship-tech .contents #detail .outline ul.voice li:nth-child(2)::before {
    background: url("/saiyou/image/internship/tech/icon-voice-02.png") no-repeat center center / cover;
}

.contents #detail .outline ul.flow {
    font-size: 1.6rem;
    line-height: 1.875;
    margin-top: 8.0rem;
    position: relative;
}
.contents #detail .outline ul.flow::before {
    content: "";
    background-image: linear-gradient(to bottom, rgba(0, 110, 225, 0.7), rgba(0, 110, 225, 0.7) 0.3rem, transparent 0.3rem, transparent 0.5rem);
    background-repeat: repeat-y;
    background-size: 0.2rem 0.5rem;
    width: 0.2rem;
    height: 3.0rem;
    position: absolute;
    left: 0.7rem;
    bottom: calc(100% - 1.0rem);
}
.contents #detail .outline ul.flow::after {
    content: "";
    background-image: linear-gradient(to bottom, rgba(0, 110, 225, 0.7), rgba(0, 110, 225, 0.7) 0.3rem, transparent 0.3rem, transparent 0.5rem);
    background-repeat: repeat-y;
    background-size: 0.2rem 0.5rem;
    width: 0.2rem;
    height: 3.0rem;
    position: absolute;
    left: 0.7rem;
    top: calc(100% - 1.0rem);
}
.contents #detail .outline ul.flow li {
    padding-left: 3.0rem;
    margin-bottom: 4.0rem;
    position: relative;
    display: flex;
}
.contents #detail .outline ul.flow li:last-child {
    margin-bottom: 0;
}
.contents #detail .outline ul.flow li::before {
    content: "";
    background: #006ee1;
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 100%;
    position: absolute;
    left: 0;
    top: 0.8rem;
}
.contents #detail .outline ul.flow li::after {
    content: "";
    background: rgba(0, 110, 225, 0.7);
    width: 0.2rem;
    height: calc(100% + 4.0rem);
    position: absolute;
    left: 0.7rem;
    top: 1.0rem;
}
.contents #detail .outline ul.flow li:last-child::after {
    content: none;
}
.contents #detail .outline ul.flow li span.date {
    color: #006ee1;
    width: 7.5em;
    flex-shrink: 0;
    position: relative;
}
.contents #detail .outline ul.flow li span.date span.colon {
    position: absolute;
    right: 0;
}

