@charset "UTF-8";

/* 採用情報用追加css */

       /* =========================
   タイトルボックス
========================= */

.st-title-box{
    border:3px solid #f7cdd8;
    border-radius:12px;
    padding:20px;
    background:#ffc0cb;
    text-align:center;
    color:#fff;
}

.st-title-box strong{
    font-size:25px;
    color:#fff;
}


/* =========================
   メッセージボックス
========================= */

.st-message-box{
    width:100%;
    padding:40px 20px;
    margin:40px 0;
    border:4px solid #bfe7ff;
    border-radius:18px;
    background:linear-gradient(to bottom,#fafdff,#eef8ff);
    box-shadow:
        0 6px 18px rgba(0,161,233,0.18),
        inset 0 1px 0 rgba(255,255,255,0.95);
    text-align:center;
    box-sizing:border-box;
}

.st-message-main{
    font-size:30px;
    font-weight:bold;
    margin-bottom:18px;
    color:#2b4c66;
}

.st-message-sub{
    font-size:24px;
    font-weight:bold;
    color:#007fc4;
}


/* =========================
   フェローシップ紹介
========================= */

.top_linkbox{
    list-style:none;
    margin:0;
    padding:0;
}

.top_linkbox::after{
    content:"";
    display:block;
    clear:both;
}

.top_linkbox li{
    float:left;
    width:33.333%;
    padding:30px 15px;
    box-sizing:border-box;
    text-align:center;
    color:#fff;
}

.top_linkbox li.area01{
    background:url(img/bg_1.png);
}

.top_linkbox li.area02{
    background:url(img/bg_2.png);
}

.top_linkbox li.area03{
    background:url(img/bg_3.png);
}

.top_linkbox li h2{
    min-height:70px;
    margin-bottom:15px;
    font-size:28px;
    font-weight:bold;
    line-height:1.4;
    display:flex;
    align-items:center;
    justify-content:center;
}

.top_linkbox li figure{
    margin:0;
}

.top_linkbox li figure img{
    width:100%;
    max-width:270px;
    border:5px solid #fff;
    border-radius:5px;
    display:block;
    margin:0 auto;
}

.top_linkbox li h3{
    width:180px;
    margin:15px auto 0;
    background:#fff;
    line-height:30px;
    border-radius:5px;
    font-size:14px;
}

.top_linkbox li.area01 h3{
    color:#29A4ED;
}

.top_linkbox li.area02 h3{
    color:#FF9326;
}

.top_linkbox li.area03 h3{
    color:#97BF0B;
}

.top_linkbox a{
    text-decoration:none;
}


/* =========================
   説明ボックス
========================= */

.dotted-box{
    border:3px dotted #7fc8f8;
    border-radius:15px;
    padding:35px;
    margin:30px 0;
    background:#fff;
    font-size:16px;
    line-height:2;
    color:#333;
}

.dotted-box p{
    margin-bottom:24px;
}

.dotted-box ol{
    margin:25px 0 30px 1.5em;
    padding:20px 25px;
    background:#f7fbff;
    border-radius:10px;
}

.dotted-box li{
    margin-bottom:12px;
    line-height:1.8;
}


/* =========================
   セクションタイトル
========================= */

.recruit-title{
    font-size:25px;
    text-align:center;
    margin:70px 0 35px;
}

.recruit-title span{
    position:relative;
    display:inline-block;
    padding:0 90px;
}

.recruit-title span::before,
.recruit-title span::after{
    content:"";
    position:absolute;
    top:50%;
    width:80px;
    height:2px;
    background:#77ba18;
    transform:translateY(-50%);
}

.recruit-title span::before{
    left:0;
}

.recruit-title span::after{
    right:0;
}

.st-recruit-title{
    color:#e88ca3;
    font-size:2.4rem;
    font-weight:700;
    margin:30px 0;
}


/* =========================
   共通ボックス
========================= */

.recruit-box{
    background:#fff;
    border-radius:18px;
    padding:40px;
    margin-bottom:50px;
    box-shadow:0 4px 18px rgba(0,0,0,0.06);
}

.lead-text{
    font-size:18px;
    line-height:2;
    margin-bottom:35px;
}


/* =========================
   募集要項テーブル
========================= */

.recruit-table{
    width:100%;
    border-collapse:collapse;
}

.recruit-table th{
    width:220px;
    padding:20px;
    background:#f3f9fd;
    color:#007fc4;
    border-bottom:1px solid #dceaf3;
    text-align:left;
    vertical-align:top;
}

.recruit-table td{
    padding:20px;
    border-bottom:1px solid #dceaf3;
    line-height:1.9;
}


/* =========================
   カリキュラム
========================= */

.curriculum-wrapper{
    max-width:1000px;
}

.program-container{
    margin-bottom:40px;
}

.title{
    font-size:1.2rem;
    font-weight:bold;
    margin-bottom:15px;
    padding-left:10px;
    border-left:5px solid #00a1e9;
}

.curriculum-table{
    width:100%;
    border-collapse:separate;
    border-spacing:20px 0;
}

.curriculum-table th{
    width:50%;
    text-align:center;
    color:#666;
    padding-bottom:10px;
}

.bar{
    display:flex;
    height:90px;
    overflow:hidden;
    border-radius:12px;
}

.cell{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    text-align:center;
    font-weight:bold;
}

.cell span{
    font-size:0.9rem;
    font-weight:normal;
}

.w-75{flex:0 0 75%;}
.w-50{flex:0 0 50%;}
.w-25{flex:0 0 25%;}

.pink{
    background:#ffe4f1;
    color:#c53f7b;
}

.yellow{
    background:#fff7d6;
    color:#b7791f;
}

.blue{
    background:#dff3ff;
    color:#006fb4;
}

.gray{
    background:#f0f0f0;
    color:#666;
}


/* =========================
   給与テーブル
========================= */

.salary-table{
    width:100%;
    border-collapse:collapse;
    table-layout:fixed;
}

.salary-table th,
.salary-table td{
    border:1px solid #dceaf3;
    padding:16px;
    text-align:center;
    vertical-align:middle;
}

.salary-table th{
    background:#00a1e9;
    color:#fff;
}

.salary-table .wide-cell{
    text-align:left;
    line-height:1.8;
}

.salary-table .note{
    display:block;
    margin-top:5px;
    font-size:14px;
    color:#666;
}

.salary-table p{
	font-size: 1.2rem;
    color:#007fc4;
    text-align:left;
}

/* =========================
   ダウンロードボックス
========================= */

.download-box{
    display:inline-flex;
    align-items:center;
    padding:15px 25px;
    border:1px solid #EAB308;
    border-radius:6px;
    background:#fff;
    text-decoration:none;
}

.download-box:hover{
    background:#fffef0;
}

.icon-section{
    margin-right:15px;
}

.excel-icon{
    width:30px;
    height:38px;
    border:2px solid #EAB308;
    position:relative;
}

.excel-icon::after{
    content:"";
    position:absolute;
    top:-2px;
    right:-2px;
    border-width:8px;
    border-style:solid;
    border-color:#fff #fff transparent transparent;
}

.x-mark{
    position:absolute;
    bottom:2px;
    left:4px;
    color:#EAB308;
    font-weight:bold;
}

.main-text{
    font-weight:bold;
    color:#4A5568;
}

.sub-text{
    font-size:0.9rem;
    color:#718096;
}


/* =========================
   見学・面談
========================= */

.visit-card{
    background:#f9fcff;
    border:2px solid #d9eef9;
    border-radius:18px;
    padding:35px;
    margin-bottom:30px;
    text-align:center;
}

.visit-card h2{
    color:#007fc4;
    margin-bottom:20px;
}

.visit-card p{
    line-height:2;
    margin-bottom:25px;
}

.visit-btn{
    display:inline-block;
    padding:14px 35px;
    background:#77ba18;
    color:#fff;
    border-radius:50px;
    text-decoration:none;
    font-weight:bold;
}

.visit-btn:hover{
    background:#5e9910;
}


/* =========================
   スマホ対応
========================= */

@media screen and (max-width:767px){

    .top_linkbox li{
        float:none;
        width:100%;
    }

    .top_linkbox li h2{
        min-height:auto;
        font-size:24px;
    }

    .dotted-box{
        padding:22px;
        font-size:14px;
    }

    .recruit-box{
        padding:25px;
    }

    .recruit-title span{
        padding:0 50px;
    }

    .recruit-title span::before,
    .recruit-title span::after{
        width:40px;
    }

    .recruit-table th,
    .recruit-table td{
        display:block;
        width:100%;
        box-sizing:border-box;
    }

    .curriculum-table,
    .curriculum-table tbody,
    .curriculum-table tr,
    .curriculum-table td{
        display:block;
        width:100%;
    }

    .curriculum-table thead{
        display:none;
    }

    .curriculum-table td{
        padding:0;
        margin-bottom:15px;
    }

    .visit-card{
        padding:25px;
    }
}

/* =========================
   トップへ戻る
========================= */

.page-top-wrap{
    text-align:right;
    margin:60px 0 20px;
}

.page-top-btn{
    display:inline-block;
    padding:14px 40px;
    background:#00a1e9;
    color:#fff;
    text-decoration:none;
    border-radius:50px;
    font-weight:bold;
    font-size:16px;
    transition:0.3s;
    box-shadow:0 3px 10px rgba(0,161,233,0.2);
}

.page-top-btn:hover{
    background:#007fc4;
    transform:translateY(-2px);
}

@media screen and (max-width:767px){

    .page-top-btn{
        width:90%;
        max-width:300px;
        box-sizing:border-box;
    }

}