/* ヒーロー */
.p-hero-box {
    display: flex;
    justify-content: space-between;
    margin: 24px 0 0;
}

.c-hero-text {
    flex-basis: calc(100% - 260px);
    max-width: calc(100% - 260px);
}

.c-hero-fig {
    flex-basis: 260px;
    max-width: 260px;
    padding: 0 0 0 40px;
}

.u-hero-reset {
    flex-basis: initial;
    max-width: initial;
}

.p-links-box .c-btn-link {
    margin: 0 auto;
}

/* 大見出し */
.p-heading {
    position: relative;
    margin-top: 50px;
}

.p-heading .p-links-box {
    position: absolute;
    top: -40px;
    left: 50%;
    margin: 0;
    padding: 0 16px;
    transform: translate(-50%);
}

/* スケジュール */
.p-schedule-section {
    margin: 64px 0 0;
}

.p-schedule-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.p-schedule-item {
    flex-basis: calc((100% - 32px) / 3);
    max-width: calc((100% - 32px) / 3);
    margin: 24px 0 0;
}

.c-schedule-image {
    position: relative;
}

.c-schedule-time {
    position: absolute;
    top: -8px;
    left: 0;
    padding: 8px 0;
    width: 64px;
    font-size: 13px;
    letter-spacing: 2px;
    text-align: center;
    color: #fff;
    background-color: #e56f94;
}

.c-schedule-title {
    padding-left: 16px;
    font-size: 13px;
}

.c-schedule-time + .c-schedule-title {
    padding-left: 72px;
}

.c-schedule-fig::before {
    content: '';
    display: block;
    width: 100%;
    height: 12px;
    background-color: #e56f94;
}

.c-schedule-time_edit,
.c-schedule-fig_edit::before {
    background-color: #54b469;
}

.c-schedule-time_edit::after {
    border-color: transparent  transparent  transparent #54b469;
}

.c-schedule-time_plan,
.c-schedule-fig_plan::before {
    background-color: #966fa6;
}

.c-schedule-time_plan::after {
    border-color: transparent  transparent  transparent #966fa6;
}

.c-schedule-time_contents,
.c-schedule-fig_contents::before {
    background-color: #51a2cc;
}

.c-schedule-time_contents::after {
    border-color: transparent  transparent  transparent #51a2cc;
}

.c-schedule-time_admin,
.c-schedule-fig_admin::before {
    background-color: #eb871e;
}

.c-schedule-time_admin::after {
    border-color: transparent  transparent  transparent #eb871e;
}

.c-schedule-text {
    margin: 8px;
    line-height: 1.5;
}

/* 先輩社員の声 */
.p-voice-section {
    margin: 64px 0 0;
}

.c-voice-lead {
    margin: 24px 0 0;
}

.p-colleague-wrap {
    margin: 0 0 64px;
}

.p-colleague-wrap:last-child {
    margin: 0;
}

.p-colleague-box {
    display: flex;
    /* justify-content: space-between; */
    align-items: flex-end;
    margin: 24px 0 0;
}

.c-colleague-fig {
    flex-basis: 320px;
    max-width: 320px;
    padding: 0 40px 0 0;
}

.c-colleague-text {
    flex-basis: calc(100% - 320px);
    max-width: calc(100% - 320px);
}

.c-colleague-name {
    color: #e56f94;
}

.c-colleague-department {
    margin: 0 16px;
}

.c-colleague-job {
    margin-top: 16px;
}

.c-colleague-heading {
    margin: 32px 0 0;
    color: #e56f94;
}

.u-color_edit {
    color: #54b469;
}

.u-color_plan {
    color: #966fa6;
}

.u-color_contents {
    color: #51a2cc;
}

.u-color_admin {
    color: #eb871e;
}

/* SP */
@media screen and (max-width: 767px) {
    /* ヒーロー */
    .p-hero-box {
        flex-direction: column;
    }

    .c-hero-text {
        flex-basis: 100%;
        max-width: 100%;
    }

    .c-hero-fig {
        flex-basis: 100%;
        max-width: 100%;
        margin: 24px 0 0;
        padding: 0 40px;
    }

    /* 見出し */
    .p-heading .p-links-box {
        top: -32px;
    }

    /* スケジュール */
    .p-schedule-item {
        flex-basis: calc((100% - 16px) / 2);
        max-width: calc((100% - 16px) / 2);
        margin: 24px 0 0;
    }

    .c-schedule-time {
        padding: 16px 0;
    }

    .c-schedule-title {
        display: flex;
        align-items: center;
        height: 40px;
    }

    /* 声 */
    .p-colleague-box {
        flex-direction: column;
        align-items: stretch;
    }

    .c-colleague-fig {
        flex-basis: 100%;
        max-width: 100%;
        padding: 0 40px;
    }

    .p-colleague-text {
        flex-basis: 100%;
        max-width: 100%;
        margin: 8px 0 0;
    }

    .p-colleague-text {
        flex-basis: 100%;
        max-width: 100%;
        margin: 8px 0 0;
    }

    .c-colleague-division {
        text-align: center;
    }
}

/* SMALL SP */
@media screen and (max-width: 349px) {
    .c-schedule-title {
        font-size: 12px;
    }
}

/* TAB */
@media screen and (min-width: 768px) {
    /* リンクボタン位置調整 */
    .p-bcnav {
        margin-bottom: 40px;
    }
}

/* WIDE PC */
@media screen and (min-width: 1600px) {
    .c-schedule-title {
        font-size: 14px;
    }
}
