@charset "UTF-8";

/* common
---------------------------------------------------*/
#wrapper {
    background-color: #F9F9F9;
}
#Footer {
    margin-top: 120px;
}
.description {
    margin-bottom: 72px;
}
.description p {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.06em;
    text-align: center;
}
.description p:not(:last-of-type) {
    margin-bottom: 1.6em;
}
.description p.link a {
    border-bottom: 1px solid #3E3A39;
    padding-bottom: 8px;
}
.description p.link .icon {
    display: inline-block;
    width: 24px;
    aspect-ratio: 1 / 1;
    margin-left: 6px;
    -webkit-transition: opacity 0.5s, color 0.5s;
    transition: opacity 0.5s, color 0.5s;
}
.description p.link .icon img {
    width: 100%;
}
.description p.link a:hover,
.description p.link a:hover .icon{
    opacity: 0.8;
}


@media screen and (max-width: 1000px) {
    #Footer {
        margin-top: 20vw;
    }
    .page-title {
         margin-bottom: 8vw;
    }
    .description {
        margin-bottom: 12vw;
    }
    .description p {
        font-size: 3.75vw;
        letter-spacing: 0;
    }
    .description p.link a {
        padding-bottom: 2vw;
    }
    .description p.link .icon {
        width: 6vw;
        margin-left: 1.5vw;
    }
}


/* event
---------------------------------------------------*/
#event .event-list {
    width: 96%;
    max-width: 1200px;
    margin: 0 auto 120px;
}
#event .event-list .event-block {
    position: relative;
}
#event .event-list .event-block:not(:last-of-type) {
    margin-bottom: 72px;
}
/* event-content */
#event .event-list .event-block .event-content {
    position: relative;
    background-color: #fff;
    border: 1px solid #E4E4E4;
    border-radius: 16px;
}
#event .event-list .event-block .event-content .icon-new {
    position: absolute;
    top: -32px;
    right: -16px;
    width: 64px;
    z-index: 10;
}
#event .event-list .event-block .event-content .icon-new img {
    width: 100%;
}

#event .event-list .event-block .event-content-title {
    padding: 24px;
    border-bottom: 1px solid #E4E4E4;
}
#event .event-list .event-block .event-content-title .title {
    color: #0068AF;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.06em;
    text-align: left;
}
#event .event-list .event-block .event-content-body {
    padding: 32px  24px;
    border-radius: 16px;
}
#event .event-list .event-block .event-content-title + .event-content-body {
    border-radius: 0 0 16px 16px;
}
#event .event-list .event-block .event-content-body > p {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.06em;
    text-align: left;
}
#event .event-list .event-block .event-content-body ul.content-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
#event .event-list .event-block .event-content-body ul.content-list li {
    width: 57.03%;
    margin-right: 3.06%;
    margin-top: 24px;
    border-radius: 16px;
    overflow: hidden;
}
#event .event-list .event-block .event-content-body ul.content-list:has(> :nth-child(2)) li {
    width: 48.47%;
}
#event .event-list .event-block .event-content-body ul.content-list li:nth-child(2n),
#event .event-list .event-block .event-content-body ul.content-list li:last-child {
    margin-right: 0;
}
#event .event-list .event-block .event-content-body ul.content-list li .number {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    text-align: center;
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.08em;
    background: rgb(98, 200, 246);
    background: linear-gradient(180deg, #578FEF 10%, #62C7F6 90%);
    padding: 6px;
}
#event .event-list .event-block .event-content-body ul.content-list li .number span {
    position: relative;
    display: inline-block;
    min-width: 25px;
    color: #0068AD;
    font-size: 22px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.08em;
    text-align: center;
    padding-bottom: 0.1em;
    margin: 0 6px;
    z-index: 1;
}
#event .event-list .event-block .event-content-body ul.content-list li .number span::before {
    position: absolute;
    content: '';
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 25px;
    aspect-ratio: 1 / 1;
    background-color: #fff;
    border-radius: 50%;
    z-index: -1;
}
#event .event-list .event-block .event-content-body ul.content-list li .movie {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}
#event .event-list .event-block .event-content-body ul.content-list li .movie iframe,
#event .event-list .event-block .event-content-body ul.content-list li .movie video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}
#event .event-list .event-block .event-content-body ul.content-list li .figure {
    width: 100%;
    overflow: hidden;
}
#event .event-list .event-block .event-content-body ul.content-list li .figure img {
    width: 100%;
    transition: transform 0.5s, filter 0.5s;
}
#event .event-list .event-block .event-content-body ul.content-list li .figure a {
    position: relative;
    display: block;
    height: 100%;
}
#event .event-list .event-block .event-content-body ul.content-list li .figure a[target="_blank"]:after {
    position: absolute;
    content: '';
    bottom: 16px;
    right: 20px;
    width: 16px;
    height: 15px;
    background-image: url('../event/img/icon_window.svg');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
}
#event .event-list .event-block .event-content-body ul.content-list li .figure a:hover img {
    transform: scale(1.06);
    filter: brightness(110%) contrast(110%) saturate(120%);
}
#event .event-list .event-block .event-content-body ul.note {
    margin-top: 24px;
}
#event .event-list .event-block .event-content-body ul.note li {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.06em;
    text-align: left;
}
#event .event-list .event-block .event-content-body ul.note li a {
    color: #0068AD;
    text-decoration: underline;
}
/* event-caption */
#event .event-list .event-block .event-caption {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding: 8px 24px 0;
}
#event .event-list .event-block .event-caption .series {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.08em;
    text-align: left;
}
#event .event-list .event-block .event-caption .date {
    color: #7A7575;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.06em;
    text-align: right;
}

/* typeA */
#event .event-list .event-block.typeA .event-content-body {
    background-color: #E5F3FF;
}

/* typeB */
#event .event-list .event-block.typeB .event-content-body {
    background-color: #BCE7F1;
}

@media screen and (max-width: 1000px) {
    #event .event-list {
        width: 92vw;
        margin-bottom: 20vw;
    }
    #event .event-list .event-block {
        display: flex;
        flex-flow: column;
    }
    #event .event-list .event-block:not(:last-of-type) {
        margin-bottom: 12vw;
    }
    /* event-content */
    #event .event-list .event-block .event-content {
        border-radius: 2vw;
        order: 2;
    }
    #event .event-list .event-block .event-content .icon-new {
        position: absolute;
        top: -6vw;
        right: -2vw;
        width: 12vw;
    }
    #event .event-list .event-block .event-content-title {
        padding: 6vw 2vw;
    }
    #event .event-list .event-block .event-content-title .title {
        font-size: 4.5vw;
    }
    #event .event-list .event-block .event-content-body {
        padding: 4vw 2vw 8vw;
        border-radius: 2vw;
    }
    #event .event-list .event-block .event-content-title + .event-content-body {
        border-radius: 0 0 2vw 2vw;
    }
    #event .event-list .event-block .event-content-body > p {
        font-size: 3.75vw;
    }
    #event .event-list .event-block .event-content-body ul.content-list {
        display: block;
        margin-top: 2vw;
    }
    #event .event-list .event-block .event-content-body ul.content-list li {
        width: 100%;
        margin-right: 0;
        margin-top: 4vw;
        border-radius: 2vw;
    }
    #event .event-list .event-block .event-content-body ul.content-list:has(> :nth-child(2)) li {
        width: 100%;
    }
    #event .event-list .event-block .event-content-body ul.content-list li .number {
        font-size: 3.75vw;
        letter-spacing: 0;
        padding: 1.5vw;
    }
    #event .event-list .event-block .event-content-body ul.content-list li .number span {
        min-width: 6.25vw;
        font-size: 5.5vw;
        letter-spacing: 0;
        margin: 0 1.5vw;
    }
    #event .event-list .event-block .event-content-body ul.content-list li .number span::before {
        width: 6.25vw;
    }
    #event .event-list .event-block .event-content-body ul.content-list li .figure a[target="_blank"]:after {
        bottom: 4vw;
        right: 5vw;
        width: 4vw;
        height: 3.75vw;
    }
    #event .event-list .event-block .event-content-body ul.note {
        margin-top: 6vw;
    }
    #event .event-list .event-block .event-content-body ul.note li {
        font-size: 3.75vw;
    }
    /* event-caption */
    #event .event-list .event-block .event-caption {
        display: flex;
        justify-content: flex-start;
        align-items: flex-start;
        flex-flow: column;
        padding: 0 0 4vw 0;
        order: 1;
    }
    #event .event-list .event-block .event-caption .series {
        font-size: 3.5vw;
        order: 2;
    }
    #event .event-list .event-block .event-caption .date {
        font-size: 3.5vw;
        letter-spacing: 0;
        order: 1;
    }

}


/* past-event
---------------------------------------------------*/
#past-event ul.past-event-list {
    display: flex;
    flex-wrap: wrap;
    width: 96%;
    max-width: 1400px;
    margin: 0 auto 120px;
}
#past-event ul.past-event-list li {
    width: 31.94%;
    margin-right: 2.09%;
    margin-top: 40px;
}
#past-event ul.past-event-list li:nth-child(-n+3) {
    margin-top: 0;
}
#past-event ul.past-event-list li:nth-child(3n),
#past-event ul.past-event-list li:last-child {
    margin-right: 0;
}
#past-event ul.past-event-list li .figure {
    width: 100%;
    border: 1px solid #E4E4E4;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 16px;
}
#past-event ul.past-event-list li .figure img {
    width: 100%;
    transition: transform 0.5s, filter 0.5s;
}
#past-event ul.past-event-list li a:hover .figure img {
    transform: scale(1.06);
    filter: brightness(110%) contrast(110%) saturate(120%);
}
#past-event ul.past-event-list li .title {
    color: #0068AF;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.06em;
    text-align: left;
}

@media screen and (max-width: 1000px) {
    #past-event ul.past-event-list {
        display: block;
        width: 92vw;
        margin-bottom: 20vw;
    }
    #past-event ul.past-event-list li {
        width: 100%;
        margin-right: 0;
        margin-top: 10vw;
    }
    #past-event ul.past-event-list li:nth-child(-n+3) {
        margin-top: 10vw;
    }
    #past-event ul.past-event-list li:first-child {
        margin-top: 0;
    }
    #past-event ul.past-event-list li .figure {
        border-radius: 2vw;
        margin-bottom: 4vw;
    }
    #past-event ul.past-event-list li .title {
        font-size: 4vw;
    }
}


/* technology
---------------------------------------------------*/
#technology .technology-list {
    width: 96%;
    max-width: 1200px;
    margin: 0 auto;
}
#technology .technology-list .technology-block {
    display: flex;
    align-items: center;
}
#technology .technology-list .technology-block:not(:last-of-type) {
    margin-bottom: 48px;
}
#technology .technology-list .technology-block .figure {
    width: 35.93%;
    border: 1px solid #E4E4E4;
    border-radius: 16px;
    overflow: hidden;
    margin-right: 2.35%;
}
#technology .technology-list .technology-block .figure a {
    display: block;
    height: 100%;
}
#technology .technology-list .technology-block .figure img {
    width: 100%;
    transition: transform 0.5s, filter 0.5s;
}
#technology .technology-list .technology-block .figure a:hover img {
    transform: scale(1.06);
    filter: brightness(110%) contrast(110%) saturate(120%);
}
#technology .technology-list .technology-block .technology-content {
    width: 61.72%;
}
#technology .technology-list .technology-block .technology-content .title {
    text-align: left;
    border-bottom: 1px dashed #0068AF;
    padding-bottom: 16px;
    margin-bottom: 16px;
}
#technology .technology-list .technology-block .technology-content .title a {
    color: #0068AF;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.06em;
    transition: 0.5s;
}
#technology .technology-list .technology-block .technology-content .title a:hover {
    text-decoration: underline;
}
#technology .technology-list .technology-block .technology-content ul.information {
    display: flex;
    margin-bottom: 16px;
}
#technology .technology-list .technology-block .technology-content ul.information li {
    color: #7A7575;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.08em;
}
#technology .technology-list .technology-block .technology-content ul.information li:not(:last-child) {
    margin-right: 24px;
}
#technology .technology-list .technology-block .technology-content .explain {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.06em;
    text-align: left;
    /* text-2line */
    width: 100%;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    line-clamp: 2;
}

@media screen and (max-width: 1000px) {
    #technology .technology-list {
        width: 92vw;
    }
    #technology .technology-list .technology-block {
        display: block;
    }
    #technology .technology-list .technology-block:not(:last-of-type) {
        margin-bottom: 12vw;
    }
    #technology .technology-list .technology-block .figure {
        width: 100%;
        border-radius: 2vw;
        margin-right: 0;
        margin-bottom: 4vw;
    }
    #technology .technology-list .technology-block .technology-content {
        width: 100%;
    }
    #technology .technology-list .technology-block .technology-content .title {
        padding-bottom: 2vw;
        margin-bottom: 2vw;
    }
    #technology .technology-list .technology-block .technology-content .title a {
        font-size: 4.5vw;
        letter-spacing: 0;
    }
    #technology .technology-list .technology-block .technology-content ul.information {
        margin-bottom: 4vw;
    }
    #technology .technology-list .technology-block .technology-content ul.information li {
        font-size: 3.5vw;
    }
    #technology .technology-list .technology-block .technology-content ul.information li:not(:last-child) {
        margin-right: 6vw;
    }
    #technology .technology-list .technology-block .technology-content .explain {
        font-size: 3.75vw;
        letter-spacing: 0;
    }
}


/* column
---------------------------------------------------*/
#column .column-list {
    display: flex;
    flex-wrap: wrap;
    width: 96%;
    max-width: 1400px;
    margin: 0 auto;
}
#column .column-list .column-block {
    width: 23.725%;
    margin-right: 1.7%;
    margin-top: 48px;
}
#column .column-list .column-block:nth-child(-n+4) {
    margin-top: 0;
}
#column .column-list .column-block:nth-child(4n) {
    margin-right: 0;
}
#column .column-list .column-block .figure-wrap {
    position: relative;
}
#column .column-list .column-block .figure-wrap .figure {
    border: 1px solid #E4E4E4;
    border-radius: 16px;
    overflow: hidden;
}
#column .column-list .column-block .figure-wrap .figure img {
    width: 100%;
    transition: transform 0.5s, filter 0.5s;
}
#column .column-list .column-block a:hover .figure-wrap .figure img {
    transform: scale(1.06);
    filter: brightness(110%) contrast(110%) saturate(120%);
}
#column .column-list .column-block .figure-wrap .caption {
    position: absolute;
    bottom: 16px;
    left: 0;
    width: 100%;
    color: var(--white-color);
    padding: 0 10px;
}
#column .column-list .column-block .figure-wrap .caption .company {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.08em;
}
#column .column-list .column-block .figure-wrap .caption ul.ttl-list li {
    font-size: 14px;
    font-weight: 500;
    line-height: 1.6;
}
#column .column-list .column-block .comment-wrap {
    color: #0068AF;
    margin-top: 16px;
}
#column .column-list .column-block .comment-wrap .comment {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.06em;
}
#column .column-list .column-block .comment-wrap .name {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.08em;
    margin-top: 8px;
}
#column .column-list .column-block .comment-wrap .name span {
    font-size: 13px;
    margin-left: 4px;
}

@media screen and (max-width: 1000px) {
    #column .column-list {
        width: 95vw;
    }
    #column .column-list .column-block {
        width: 48.42%;
        margin-right: 3.16%;
        margin-top: 12vw;
    }
    #column .column-list .column-block:nth-child(-n+4) {
        margin-top: 12vw;
    }
    #column .column-list .column-block:nth-child(-n+2) {
        margin-top: 0;
    }
    #column .column-list .column-block:nth-child(2n) {
        margin-right: 0;
    }
    #column .column-list .column-block .figure-wrap .figure {
        border-radius: 2vw;
    }
    #column .column-list .column-block .figure-wrap .caption {
        bottom: 4vw;
        left: 0;
        padding: 0 1.5vw;
    }
    #column .column-list .column-block .figure-wrap .caption .company {
        font-size: 3.25vw;
        letter-spacing: 0;
    }
    #column .column-list .column-block .comment-wrap {
        margin-top: 4vw;
    }
    #column .column-list .column-block .comment-wrap .comment {
        font-size: 3.5vw;
        letter-spacing: 0;
    }
    #column .column-list .column-block .comment-wrap .name {
        font-size: 3.25vw;
        letter-spacing: 0;
        margin-top: 4vw;
    }
    #column .column-list .column-block .comment-wrap .name span {
        font-size: 3vw;
        margin-left: 1vw;
    }
    #column .column-list .column-block .comment-wrap ul.ttl-list {
        margin-top: 1vw;
    }
    #column .column-list .column-block .comment-wrap ul.ttl-list li {
        font-size: 3vw;
        font-weight: 500;
        line-height: 1.6;
    }
}


/* interview
---------------------------------------------------*/
#interview ul.interview-list {
    display: flex;
    flex-wrap: wrap;
    width: 96%;
    max-width: 1400px;
    margin: 0 auto;
}
#interview ul.interview-list li {
    width: 31.94%;
    background: rgb(98, 200, 246);
    background: linear-gradient(90deg, #578FEF 10%, #62C7F6 89.5%);
    border-radius: 16px;
    padding: 8px;
    margin-right: 2.09%;
    margin-top: 24px;
    overflow: hidden;
}
#interview ul.interview-list li:nth-child(-n+3) {
    margin-top: 0;
}
#interview ul.interview-list li:nth-child(3n),
#interview ul.interview-list li:last-child {
    margin-right: 0;
}
#interview ul.interview-list li a {
    display: block;
    border-radius: 16px;
    overflow: hidden;
}
#interview ul.interview-list li a img {
    width: 100%;
    transition: transform 0.5s, filter 0.5s;
}
#interview ul.interview-list li a:hover img {
    transform: scale(1.06);
    filter: brightness(110%) contrast(110%) saturate(120%);
}
#cboxClose {
    display: none;
}
#cboxOverlay::before,
#cboxOverlay::after {
    position: absolute;
    content: '';
    top: 36px;
    right: 36px;
    width: 32px;
    height: 2px;
    background-color: #fff;
}
#cboxOverlay::before {
    transform: rotate(-45deg);
}
#cboxOverlay::after {
    transform: rotate(45deg);
}
#cboxPrevious, #cboxNext {
    overflow: visible;
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    width: 24px;
    height: 24px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    z-index: 99;
    transition: opacity 0.5s;
}
#cboxPrevious:hover,
#cboxNext:hover {
    background-position: center;
    opacity: 0.8;
}
#cboxPrevious {
    left: calc(50% - 48vw);
    background-image: url('../img/top/icon_prev_fff.svg');
}
#cboxNext {
    right: calc(50% - 48vw);
    background-image: url('../img/top/icon_more_fff.svg');
}
#colorbox, #cboxOverlay, #cboxWrapper {
    overflow: visible !important;
}

@media screen and (max-width: 1000px) {
    #interview ul.interview-list {
        display: block;
        width: 96vw;
    }
    #interview ul.interview-list li {
        width: 100%;
        border-radius: 2vw;
        padding: 2vw;
        margin-right: 0;
        margin-top: 6vw;
    }
    #interview ul.interview-list li:nth-child(-n+3) {
        margin-top: 6vw;
    }
    #interview ul.interview-list li:first-child {
        margin-top: 0;
    }
    #interview ul.interview-list li a {
        border-radius: 2vw;
    }
    #cboxOverlay::before,
    #cboxOverlay::after {
        top: 24px;
        right: 16px;
    }
    #cboxPrevious, #cboxNext {
        top: calc(100% + 6vw);
        transform: translate(0, 0);
    }
    #cboxPrevious {
        left: 0;
    }
    #cboxNext {
        right: 0;
    }
}

/* btn-more
---------------------------------------------------*/
.btn-more {
    text-align: center;
}
.btn-more .btn-cover {
    position: relative;
    display: inline-block;
    width: 320px;
    height: 64px;
    background: rgb(98, 200, 246);
    background: linear-gradient(90deg, rgb(87, 142, 239) 0%, rgb(98, 200, 246) 100%);
    border-radius: 32px;
    padding: 8px;
    cursor: pointer;
    overflow: hidden;
}
.btn-more .btn-cover a,
.btn-more .btn-cover span {
    position: relative;
    display: inline-block;
    width: 100%;
    height: 100%;
    text-align: center;
    color: #0068AF;
    font-size: var(--font-size-m);
    font-weight: 500;
    letter-spacing: 0.18em;
    background-color: var(--white-color);
    border-radius: 24px;
    box-shadow: 0 2px 0 0 rgba(224, 224, 224, 0.3);
    padding: 14px 10px;
    overflow: hidden;
    z-index: 2;
    transition: color 0.5s;
}
.btn-more a::before,
.btn-more span::before {
    position: absolute;
    content: '';
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background-color: #0068ad;
    z-index: -1;
    transition: left 0.5s;
}
.btn-more a::after,
.btn-more span::after {
    position: absolute;
    content: '';
    top: 50%;
    right: 20px;
    transform: translate(0, -50%);
    width: 11px;
    height: 9px;
    background-image: url('../img/top/icon_more.svg');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    transition: background-image 0.5s;
    transition-delay: 0s;
}

/* hover */
.btn-more .btn-cover:hover a,
.btn-more .btn-cover:hover span {
    color: #fff;
}
.btn-more .btn-cover:hover a::before,
.btn-more .btn-cover:hover span::before {
    left: 0;
}
.btn-more .btn-cover:hover a::after,
.btn-more .btn-cover:hover span::after {
    background-image: url('../img/top/icon_more_fff.svg');
    transition-delay: 0.3s;
}


/* 1000 */
@media screen and (max-width: 1000px) {
    /* btn-more */
    .btn-more .btn-cover {
        width: 100%;
        max-width: 92vw;
        height: auto;
        background: none;
        border-radius: 2vw;
        padding: 0;
    }
    .btn-more .btn-cover::after {
        display: none;
    }
    .btn-more .btn-cover a,
    .btn-more .btn-cover span {
        color: var(--white-color);
        font-size: 3.5vw;
        font-weight: 700;
        letter-spacing: 0.08em;
        background-color: #0068AF;
        border-radius: 2vw;
        box-shadow: none;
        padding: 4.48717vw 0;
    }

    .btn-more a::after,
    .btn-more span::after {
        right: 18.5897vw;
        width: 3.25vw;
        height: 2.5vw;
        background-image: url('../img/top/icon_more_fff.svg');
    }
}
