@charset "utf-8";

/*    ------------------------------------------------
headerArea
------------------------------------------------    */
.headerArea {
    height: 80px;
    background: #ffffff;
}

@media (max-width:750px) {
    .headerArea {
        height: 48px;
    }
}

/*    ------------------------------------------------
.pageTitle
------------------------------------------------    */
.pageHdArea {
    height: 240px;
    background: #2e7ca9;
}
.pageHdArea .secInner {
    display: flex;
    align-items: center;
    justify-content: center;
    height: inherit;
    padding: 0;
    background: url(../image/case/case_title_bg.png) no-repeat center center;
    background-size: cover;
    font-size: 32px;
    font-weight: bold;
    color: #ffffff;
    text-align: center;
}

@media (max-width:750px) {
    .pageHdArea {
        height: 120px;
    }

    .pageHdArea .secInner {
        background-size: cover;
        font-size: 18px;
    }
}

/*    ------------------------------------------------
breadcrumbs
------------------------------------------------    */
.breadcrumbs {
    overflow-x: auto;
    font-size: 12px;
    white-space: nowrap;
}

.breadcrumbs .secInner {
    padding: 24px 0;
}

.breadcrumbs .breadcrumbsBlock {
    display: flex;
}

.breadcrumbs .breadcrumbsBox::after {
    content: ">";
    margin: 0 8px;
 }

 .breadcrumbs .breadcrumbsBox:last-child::after {
    content: "";
 }

@media (max-width:750px) {
    .breadcrumbs {
        margin-bottom: 16px;
    }
}

/*    ------------------------------------------------
caseList
------------------------------------------------    */
.caseArea .secInner {
    padding: 40px 32px 120px;
}

.caseArea .secLead {
    margin-top: 80px;
}

.caseArea .secHd {
    margin-top: 0;
}

.caseListBox {
    display: flex;
    flex-wrap: wrap;
    margin-top: -24px;
    margin-left: -24px;
}

.caseListBlock {
    margin-top: 24px;
    margin-left: 24px;
    width: 317px;
    background: #ffffff;
}

.caseListBoxLink {
    display: flex;
    flex-direction: column;
    padding: 16px;
    text-decoration: none;
}

.caseListImg {
    margin: -16px -16px 0;
}

.caseListImg img {
    height: 176px;
    object-fit: cover;
}

.caseListName {
    flex: 1;
    margin-top: 14px;
    height: 100%;
    min-height: 0%;
    font-size: 16px;
}

.caseListNote {
    flex: 2;
    margin-top: 8px;
    height: 100%;
    min-height: 0%;
    line-height: 1.4;
    font-size: 16px;
    font-weight: bold;
}

.caseListProfileBox {
    flex: 3;
    margin-top: 16px;
}

.caseListProfileBlock {
    display: flex;
    align-items: baseline;
    margin-top: 8px;
}

.caseListProfileBoxHd {
    margin-right: 8px;
    min-width: 6em;
    padding: 2px 4px;
    background: #369ddc;
    color: #ffffff;
    font-size: 14px;
    text-align: center;
}

.caseListProfileBoxTxt {
    font-size: 14px;
    line-height: 1.2;
}

.caseListBox .annotationTxt {
    margin-top: 8px;
    font-size: 12px;
}

@media (max-width:750px) {
    .caseListBox {
        margin-top: 0;
        margin-left: 0;
    }

    .caseListBlock {
        display: block;
        width: 100%;
        margin-left: 0;
    }

    .caseListBlock:first-child {
        margin-top: 0;
    }

    .caseListName {
        height: auto;
    }

    .caseListNote {
        height: auto;
    }
}

/*    ------------------------------------------------
caseDetail
------------------------------------------------    */
.caseDetailArea .secHd {
    text-align: left;
}

.caseIntroduction {
    display: flex;
    justify-content: space-between;
    margin-top: 80px;
}

.caseIntroductionImg {
    width: 50%;
}

.caseIntroductionDetail {
    display: flex;
    flex-direction: column;
    position: relative;
    top: 40px;
    right: 64px;
    left: auto;
    margin-left: 0;
    margin-right: -64px;
    z-index: -1;
    width: 60%;
    min-height: 320px;
    padding: 40px 40px 40px 104px;
    background: #e5edf0;
}

.caseIntroductionName {
    font-size: 24px;
    font-weight: bold;
}

.caseIntroductionProfileBlock {
    margin-top: 16px;
}

.caseIntroductionProfileBox {
    display: flex;
    align-items: baseline;
    margin-top: 8px;
}

.caseIntroduction .annotationTxt  {
    margin-top: 16px;
    font-size: 12px;
}

.caseIntroductionProfileBoxHd {
    margin-right: 16px;
    min-width: 6em;
    padding: 2px 8px;
    background: #369ddc;
    color: #ffffff;
    font-size: 16px;
    text-align: center;
}

.caseIntroductionProfileBoxTxt {
    font-size: 16px;
    line-height: 1.2;
}

.caseSummary {
    margin-top: 104px;
}

.casePointHd {
    margin-top: 40px;
    line-height: 1.4;
    text-align: center;
    font-size: 36px;
    font-weight: bold;
}

.casePointBox {
    margin-top: 40px;
}

.casePointBlock {
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    margin-top: 40px;
    margin-left: 24px;
    min-height: 264px;
    padding: 40px 40px 40px 148px;
    background: #ffffff;
}

.casePointLabel {
    position: absolute;
    top: 50%;
    left: -24px;
    transform: translateY(-50%);
    width: 140px;
    background: #369ddc;
    color: #ffffff;
}

.casePointLabel::after {
    content: "";
    display: block;
    padding-top: 100%;
}

.casePointLabelInner {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    line-height: 1;
    font-size: 56px;
    font-weight: bold;
    text-align: center;
}

.casePointLabel .smallTxt {
    font-size: 22px;
    font-weight: normal;
}

.casePointBoxHd {
    font-size: 30px;
    font-weight: bold;
    color: #369ddc;
    margin-bottom: 24px;
}

.caseInterviewHd {
    margin-top: 64px;
    padding: 16px 0 16px 96px;
    border-bottom: 2px solid #999;
    background: url(../image/case/csse_ico_speech_bubble.png) no-repeat left center;
    background-size: 72px;
    line-height: 1.3;
    font-size: 36px;
    font-weight: bold;
}

.caseInterviewSubHd {
    margin-top: 40px;
    font-size: 22px;
    font-weight: bold;
}

.caseInterviewSummaryWrap {
    display: flex;
    justify-content: space-between;
    margin: 40px 0;
}

.caseInterviewSummaryTxt {
    flex: 2;
    font-size: 20px;
    font-weight: bold;
}

.caseInterviewSummaryImg {
    flex: 1;
    margin-left: 24px;
}

.caseInterviewTxt {
    margin-top: 24px;
}

.caseInterviewExplanation {
    margin-top: 24px;
    padding: 2px 24px 24px;
    background: #ffffff;
}

.caseInterviewExplanationHd {
    margin-top: 24px;
    font-size: 22px;
    font-weight: bold;
}

.caseInterviewExplanationTxt {
    margin-top: 16px;
    font-size: 16px;
}

.caseInterviewExplanationImg {
    margin-top: 24px;
    width: 100%;
}

.caseInterviewMessage {
    margin-top: 40px;
    padding: 32px 24px;
    border: 8px solid #369ddc;
    background: #ffffff;
}

.caseInterviewMessageHd {
    padding: 16px 0 16px 60px;
    background: url(../image/case/case_img_robo.png) no-repeat left center;
    background-size: 48px;
    line-height: 1.3;
    font-size: 28px;
    font-weight: bold;
    color: #369ddc;
}

.caseInterviewMessageTxt {
    margin-top: 24px;
    font-size: 16px;
}

.caseContactArea {
    background: #369ddc;
}

.caseContactArea .secInner {
    padding: 80px 0;
}

.caseContactHd {
    font-size: 28px;
    font-weight: bold;
    text-align: center;
    color: #ffffff;
}

.caseContactContents {
    margin-top: 40px;
    padding: 40px 0;
    background: #ffffff;
}

.caseContactBox {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.caseContactBlock {
    position: relative;
    width: 50%;
    padding-bottom: 176px;
    text-align: center;
}

.caseContactBlock:first-child {
    border-right: 1px solid #e5edf0;
}

.caseContactBoxHd {
    font-size: 24px;
    font-weight: bold;
}

.caseContactBoxDetail {
    position: absolute;
    bottom: 0;
    width: 100%;
    padding: 0 80px;
}

.caseBtn {
    font-size: 18px;
    line-height: 1.3;
}

.caseContactTel {
    margin-top: 40px;
    text-align: center;
}

.caseContactTelNum {
    font-size: 24px;
    font-weight: bold;
}

.caseContactTelNum::before {
    content: "\f095";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: var(--fa-display,inline-block);
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;

    margin-right: 8px;
    font-size: 18px;
}

.caseContactTelTime {
    font-size: 14px;
    font-weight: bold;
}

.contactBoxTxtSmall {
    font-size: 16px;
}

@media (max-width:750px) {
    .breadcrumbs .secInner {
        padding: 16px 16px;
    }

    .caseArea .secInner {
        width: auto;
        padding: 0 16px 40px;
    }

    .caseIntroduction {
        margin-top: 24px;
        display: block;
    }

    .caseIntroductionImg {
        width: 100%;
    }

    .caseIntroductionDetail {
        display: block;
        top: 0;
        right: auto;
        margin: 0;
        width: 100%;
        padding: 16px;
        min-height: auto;
    }

    .caseSummary {
        margin-top: 24px;
        font-size: 16px;
    }

    .casePointHd {
        font-size: 24px;
    }

    .casePointTxt {
        font-size: 16px;
    }

    .casePointLabel {
        top: 0%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 80px;
    }

    .casePointLabelInner {
        font-size: 36px;
    }

    .casePointLabel .smallTxt {
        font-size: 15px;
    }

    .casePointBlock {
        display: block;
        margin-top: 64px;
        margin-left: auto;
        min-height: auto;;
        padding: 56px 16px 16px;
    }

    .casePointBoxHd {
        font-size: 24px;
        margin-bottom: 16px;
        line-height: 1.3;
    }

    .caseInterviewHd {
        margin-top: 40px;
        padding: 8px 0 8px 48px;
        background-size: 32px;
        line-height: 1.2;
        font-size: 20px;
    }

    .caseInterviewSubHd {
        margin-top: 40px;
        font-size: 20px;
        font-weight: bold;
    }

    .caseInterviewSummaryWrap {
        display: block;
        margin: 24px 0;
    }

    .caseInterviewSummaryTxt {
        flex: auto;
        font-size: 18px;
    }

    .caseInterviewSummaryImg {
        flex: auto;
        margin-top: 24px;
        margin-left: 0;
    }

    .caseInterviewTxt {
        margin-top: 32px;
        font-size: 16px;
    }

    .caseInterviewMessage {
        padding: 24px 16px;
        border: 6px solid #369ddc;
    }

    .caseInterviewMessageHd {
        padding: 0 0 0 32px;
        background-size: 26px;
        font-size: 20px;
    }

    .caseInterviewMessageTxt {
        margin-top: 16px;
    }

    .caseContactArea .secInner {
        padding: 40px 16px;
    }

    .caseContactBox {
        display: block;
    }

    .caseContactBlock {
        width: auto;
        padding: 24px 0;
    }

    .caseContactBlock:first-child {
        padding-top: 0;
        border-right: none;
        border-bottom: 1px solid #e5edf0;
    }

    .caseBtn {
        font-size: 16px;
    }

    .caseContactContents {
        margin-top: 24px;
        padding: 24px 16px;
    }

    .caseContactBoxDetail {
        position: static;
        padding: 0;
    }

    .caseContactBoxTxt {
        margin-top: 8px;
    }

    .caseContactTel {
        margin-top: 8px;
    }

    .caseContactTel a {
        text-decoration: none;
    }

    .caseContactTelNum::before {
        margin-right: 6px;
    }
}

/*    ------------------------------------------------
otherCaseList
------------------------------------------------    */
.otherCaseArea {
    background: #e5edf0;
}

.otherCaseArea .secLead {
    margin-top: 80px;
}

.otherCaseArea .secHd {
    margin-top: 0;
}

.otherCaseListBox {
    display: flex;
    flex-wrap: wrap;
    margin-top: 40px;
    margin-left: -24px;
}

.otherCaseListBlock {
    margin-top: 24px;
    margin-left: 24px;
    width: 488px;
    background: #ffffff;
}

.otherCaseListBoxLink {
    display: flex;
    flex-direction: column;
    padding: 16px 16px 24px;
    text-decoration: none;
}

.otherCaseListBlockTop {
    display: flex;
    flex-wrap: wrap;
    margin: -16px 0 0 -16px;
}

.otherCaseListImg {
    width: 180px;
}

.otherCaseListImg img {
    height: 176px;
    object-fit: cover;
}

.otherCaseListName {
    flex: 1;
    margin-top: 14px;
    height: 100%;
    min-height: 0%;
    font-size: 16px;
}

.otherCaseListNote {
    flex: 2;
    margin-top: 8px;
    height: 100%;
    min-height: 0%;
    line-height: 1.4;
    font-size: 16px;
    font-weight: bold;
}

.otherCaseListProfileBox {
    margin-top: 16px;
    margin-left: 16px;
    width: 276px;
}

.otherCaseListProfileBlock {
    display: flex;
    align-items: baseline;
    margin-top: 8px;
}

.otherCaseListProfileBoxHd {
    margin-right: 8px;
    min-width: 6em;
    padding: 2px 4px;
    background: #369ddc;
    color: #ffffff;
    font-size: 14px;
    text-align: center;
}

.otherCaseListProfileBoxTxt {
    font-size: 14px;
    line-height: 1.2;
}

.otherCaseListBox .annotationTxt {
    margin-top: 8px;
    font-size: 12px;
}

@media (max-width:750px) {
    .otherCaseListBox {
        margin-top: 0;
        margin-left: 0;
    }

    .otherCaseListBlock {
        display: block;
        width: 100%;
        margin-left: 0;
    }

    .otherCaseListBlockTop {
        display: block;
        margin: -16px -16px 0 -16px;
    }

    .otherCaseListImg {
        width: auto;
    }

    .otherCaseListProfileBox {
        margin: 16px 16px 0;
        width: auto;
    }

    .otherCaseListName {
        height: auto;
    }

    .otherCaseListNote {
        height: auto;
    }
}

/*    ------------------------------------------------
documentArea
------------------------------------------------    */
.documentListBox {
    display: flex;
    flex-wrap: wrap;
    margin-top: 40px;
    margin-left: -24px;
}

.documentListBlock {
    display: flex;
    flex-direction: column;
    margin-top: 24px;
    margin-left: 24px;
    width: 317px;
    padding: 24px;
    background: #e5edf0;
}

.documentListName {
    flex: 1;
    margin-top: 16px;
    line-height: 1.4;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
}

.documentListDescription {
    margin-top: 16px;
    font-size: 14px;
}

.documentListBtnWrap {
    margin: 16px 16px 0;
}

.documentListBtn {
    display: block;
    padding: 4px;
    border-radius: 24px;
    text-align: center;
    text-decoration: none;
    font-size: 14px;
}

@media (max-width:750px) {
    .documentListBox {
        margin-top: 0;
        margin-left: 0;
    }

    .documentListBlock {
        display: block;
        width: 100%;
        margin-left: 0;
    }
    
    .documentListBtn {
        padding: 8px 0;
    }
}
