@charset "UTF-8";
/* Scss Document */
.flex_30 {
    width: 30%;
}
.flex_31 {
    width: 31%;
}
.flex_32 {
    width: 32%;
}
.flex_33 {
    width: 33%;
}
.flex_34 {
    width: 34%;
}
.flex_35 {
    width: 35%;
}
.flex_36 {
    width: 36%;
}
.flex_37 {
    width: 37%;
}
.flex_38 {
    width: 38%;
}
.flex_39 {
    width: 39%;
}
.flex_40 {
    width: 40%;
}
.flex_41 {
    width: 41%;
}
.flex_42 {
    width: 42%;
}
.flex_43 {
    width: 43%;
}
.flex_44 {
    width: 44%;
}
.flex_45 {
    width: 45%;
}
.flex_46 {
    width: 46%;
}
.flex_47 {
    width: 47%;
}
.flex_48 {
    width: 48%;
}
.flex_49 {
    width: 49%;
}
.flex_50 {
    width: 50%;
}
.flex_51 {
    width: 51%;
}
.flex_52 {
    width: 52%;
}
.flex_53 {
    width: 53%;
}
.flex_54 {
    width: 54%;
}
.flex_55 {
    width: 55%;
}
.flex_56 {
    width: 56%;
}
.flex_57 {
    width: 57%;
}
.flex_58 {
    width: 58%;
}
.flex_59 {
    width: 59%;
}
.flex_60 {
    width: 60%;
}
.flex_61 {
    width: 61%;
}
.flex_62 {
    width: 62%;
}
.flex_63 {
    width: 63%;
}
.flex_64 {
    width: 64%;
}
.flex_65 {
    width: 65%;
}
.flex_66 {
    width: 66%;
}
.flex_67 {
    width: 67%;
}
.flex_68 {
    width: 68%;
}
.flex_69 {
    width: 69%;
}
.flex_70 {
    width: 70%;
}
.padding100 {
    padding-top: 100px;
    padding-bottom: 100px;
}
.padding110 {
    padding-top: 110px;
    padding-bottom: 110px;
}
.padding120 {
    padding-top: 120px;
    padding-bottom: 120px;
}
.padding130 {
    padding-top: 130px;
    padding-bottom: 130px;
}
.padding140 {
    padding-top: 140px;
    padding-bottom: 140px;
}
.padding150 {
    padding-top: 150px;
    padding-bottom: 150px;
}
.padding160 {
    padding-top: 160px;
    padding-bottom: 160px;
}
.padding170 {
    padding-top: 170px;
    padding-bottom: 170px;
}
.padding180 {
    padding-top: 180px;
    padding-bottom: 180px;
}
.padding190 {
    padding-top: 190px;
    padding-bottom: 190px;
}
.padding200 {
    padding-top: 200px;
    padding-bottom: 200px;
}
.padding210 {
    padding-top: 210px;
    padding-bottom: 210px;
}
.padding220 {
    padding-top: 220px;
    padding-bottom: 220px;
}
.padding230 {
    padding-top: 230px;
    padding-bottom: 230px;
}
.padding240 {
    padding-top: 240px;
    padding-bottom: 240px;
}
.padding250 {
    padding-top: 250px;
    padding-bottom: 250px;
}
.padding260 {
    padding-top: 260px;
    padding-bottom: 260px;
}
.padding270 {
    padding-top: 270px;
    padding-bottom: 270px;
}
.padding280 {
    padding-top: 280px;
    padding-bottom: 280px;
}
.padding290 {
    padding-top: 290px;
    padding-bottom: 290px;
}
.padding300 {
    padding-top: 300px;
    padding-bottom: 300px;
}
.margin100 {
    margin-top: 100px;
    margin-bottom: 100px;
}
.margin110 {
    margin-top: 110px;
    margin-bottom: 110px;
}
.margin120 {
    margin-top: 120px;
    margin-bottom: 120px;
}
.margin130 {
    margin-top: 130px;
    margin-bottom: 130px;
}
.margin140 {
    margin-top: 140px;
    margin-bottom: 140px;
}
.margin150 {
    margin-top: 150px;
    margin-bottom: 150px;
}
.margin160 {
    margin-top: 160px;
    margin-bottom: 160px;
}
.margin170 {
    margin-top: 170px;
    margin-bottom: 170px;
}
.margin180 {
    margin-top: 180px;
    margin-bottom: 180px;
}
.margin190 {
    margin-top: 190px;
    margin-bottom: 190px;
}
.margin200 {
    margin-top: 200px;
    margin-bottom: 200px;
}
.margin210 {
    margin-top: 210px;
    margin-bottom: 210px;
}
.margin220 {
    margin-top: 220px;
    margin-bottom: 220px;
}
.margin230 {
    margin-top: 230px;
    margin-bottom: 230px;
}
.margin240 {
    margin-top: 240px;
    margin-bottom: 240px;
}
.margin250 {
    margin-top: 250px;
    margin-bottom: 250px;
}
.margin260 {
    margin-top: 260px;
    margin-bottom: 260px;
}
.margin270 {
    margin-top: 270px;
    margin-bottom: 270px;
}
.margin280 {
    margin-top: 280px;
    margin-bottom: 280px;
}
.margin290 {
    margin-top: 290px;
    margin-bottom: 290px;
}
.margin300 {
    margin-top: 300px;
    margin-bottom: 300px;
}
.pt-110 {
    padding-top: 110px;
}
.pt-120 {
    padding-top: 120px;
}
.pt-130 {
    padding-top: 130px;
}
.pt-140 {
    padding-top: 140px;
}
.pt-150 {
    padding-top: 150px;
}
.pt-160 {
    padding-top: 160px;
}
.pt-170 {
    padding-top: 170px;
}
.pt-180 {
    padding-top: 180px;
}
.pt-190 {
    padding-top: 190px;
}
.pt-200 {
    padding-top: 200px;
}
.pt-210 {
    padding-top: 210px;
}
.pt-220 {
    padding-top: 220px;
}
.pt-230 {
    padding-top: 230px;
}
.pt-240 {
    padding-top: 240px;
}
.pt-250 {
    padding-top: 250px;
}
.pt-260 {
    padding-top: 260px;
}
.pt-270 {
    padding-top: 270px;
}
.pt-280 {
    padding-top: 280px;
}
.pt-290 {
    padding-top: 290px;
}
.pt-300 {
    padding-top: 300px;
}
.pb-110 {
    padding-bottom: 110px;
}
.pb-120 {
    padding-bottom: 120px;
}
.pb-130 {
    padding-bottom: 130px;
}
.pb-140 {
    padding-bottom: 140px;
}
.pb-150 {
    padding-bottom: 150px;
}
.pb-160 {
    padding-bottom: 160px;
}
.pb-170 {
    padding-bottom: 170px;
}
.pb-180 {
    padding-bottom: 180px;
}
.pb-190 {
    padding-bottom: 190px;
}
.pb-200 {
    padding-bottom: 200px;
}
.pb-210 {
    padding-bottom: 210px;
}
.pb-220 {
    padding-bottom: 220px;
}
.pb-230 {
    padding-bottom: 230px;
}
.pb-240 {
    padding-bottom: 240px;
}
.pb-250 {
    padding-bottom: 250px;
}
.pb-260 {
    padding-bottom: 260px;
}
.pb-270 {
    padding-bottom: 270px;
}
.pb-280 {
    padding-bottom: 280px;
}
.pb-290 {
    padding-bottom: 290px;
}
.pb-300 {
    padding-bottom: 300px;
}
.mt-110 {
    margin-top: 110px;
}
.mt-120 {
    margin-top: 120px;
}
.mt-130 {
    margin-top: 130px;
}
.mt-140 {
    margin-top: 140px;
}
.mt-150 {
    margin-top: 150px;
}
.mt-160 {
    margin-top: 160px;
}
.mt-170 {
    margin-top: 170px;
}
.mt-180 {
    margin-top: 180px;
}
.mt-190 {
    margin-top: 190px;
}
.mt-200 {
    margin-top: 200px;
}
.mt-210 {
    margin-top: 210px;
}
.mt-220 {
    margin-top: 220px;
}
.mt-230 {
    margin-top: 230px;
}
.mt-240 {
    margin-top: 240px;
}
.mt-250 {
    margin-top: 250px;
}
.mt-260 {
    margin-top: 260px;
}
.mt-270 {
    margin-top: 270px;
}
.mt-280 {
    margin-top: 280px;
}
.mt-290 {
    margin-top: 290px;
}
.mt-300 {
    margin-top: 300px;
}
.mb-110 {
    margin-bottom: 110px;
}
.mb-120 {
    margin-bottom: 120px;
}
.mb-130 {
    margin-bottom: 130px;
}
.mb-140 {
    margin-bottom: 140px;
}
.mb-150 {
    margin-bottom: 150px;
}
.mb-160 {
    margin-bottom: 160px;
}
.mb-170 {
    margin-bottom: 170px;
}
.mb-180 {
    margin-bottom: 180px;
}
.mb-190 {
    margin-bottom: 190px;
}
.mb-200 {
    margin-bottom: 200px;
}
.mb-210 {
    margin-bottom: 210px;
}
.mb-220 {
    margin-bottom: 220px;
}
.mb-230 {
    margin-bottom: 230px;
}
.mb-240 {
    margin-bottom: 240px;
}
.mb-250 {
    margin-bottom: 250px;
}
.mb-260 {
    margin-bottom: 260px;
}
.mb-270 {
    margin-bottom: 270px;
}
.mb-280 {
    margin-bottom: 280px;
}
.mb-290 {
    margin-bottom: 290px;
}
.mb-300 {
    margin-bottom: 300px;
}
* {
    text-decoration: none !important;
}
.m_header {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% - 400px);
    z-index: 99999;
    padding: 50px 0;
}
.m_logo {
    display: flex;
    align-items: flex-end;
    width: 90%;
    max-width: 1500px;
    margin: 0 auto;
}
.m_logo img:nth-child(1) {
    margin-right: 18px;
}
.m_logo img:nth-child(2) {
    position: relative;
    top: 5px;
}
/************************/
.cy_header {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% - 400px);
    padding: 50px 0;
    z-index: 500;
}
.logo {
    display: flex;
    align-items: flex-end;
    width: 90%;
    max-width: 1500px;
    margin: 0 auto;
}
.logo img:nth-child(1) {
    margin-right: 18px;
}
.logo img:nth-child(2) {
    position: relative;
    top: 5px;
}
.h_entry {
    font-family: "BarlowCondensed-SemiBold";
    position: fixed;
    top: 0;
    right: 100px;
    z-index: 99999;
}
.h_entry a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 240px;
    height: 100px;
    background-color: #000080;
    color: #FFF;
    letter-spacing: 0.13em;
    font-size: 30px;
}
/******/
.top_main {
    position: relative;
    background-color: #FFF;
}
.top_main, .flexslider, .flexslider li {
    height: 970px;
}
#fade1 {
    background: url("../images/fade1.jpg") 50% 0/cover no-repeat;
}
#fade2 {
    background: url("../images/fade2.jpg") 50% 0/cover no-repeat;
}
#fade3 {
    background: url("../images/fade3.jpg") 50% 0/cover no-repeat;
}
.flexslider li {
    animation: fade 5s ease 0s forwards;
    clip-path: inset(0 100% -20% 0);
    background-color: #FFF;
}
@keyframes fade {
    0% {
        clip-path: inset(0 100% -20% 0);
    }
    10% {
        clip-path: inset(0 0 -20% 0);
    }
    90% {
        clip-path: inset(0 0 -20% 0);
    }
    100% {
        clip-path: inset(0 0 -20% 100%);
    }
}
/*
.fade_flex {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    span {
        display: block;
        position: absolute;
        right: 0;
        top: 0;
        height: 100%;
        width: 25%;
        background-color: #000;
        opacity: 0.5;
        animation: fade 0.6s ease 0.2s forwards;
        &:nth-child(2) {
            right: 25%;
        }
        &:nth-child(3) {
            right: 50%;
        }
        &:nth-child(4) {
            right: 75%;
        }
    }
}
@keyframes fade {
    0% {
        width: 25%;
    }
    100% {
        width: 0;
    }
}
*/
.top_title {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    text-align: center;
    padding-top: 80px;
}
.top_title h2 {
    font-size: 149px;
    line-height: 1em;
    color: #FFF;
    font-style: italic;
    letter-spacing: 0.05em;
}
.top_title i {
    margin: 0 0 0 10px;
}
.top_title h3 {
    font-size: 35px;
    line-height: 1em;
    color: #FFF;
    font-style: italic;
    letter-spacing: 0.05em;
    margin-top: 40px;
}
.top_title h2, .top_title h3 {
    animation: title 0.8s ease 0.8s forwards;
    clip-path: inset(100% 0 0 0);
}
@keyframes title {
    0% {
        clip-path: inset(100% 0 0 0);
    }
    100% {
        clip-path: inset(0);
    }
}
.scroll {
    position: absolute;
    left: 70px;
    bottom: 0;
    z-index: 500;
    color: #FFF;
    writing-mode: vertical-rl;
    font-style: italic;
    font-size: 10px;
    height: 120px;
    cursor: pointer;
}
.scroll:after {
    content: "";
    border-left: 1px solid #FFF;
    height: 60px;
    position: absolute;
    bottom: 0;
    left: 10px;
    animation: scroll 2s ease infinite;
}
@keyframes scroll {
    0% {
        height: 60px;
    }
    80% {
        height: 0;
    }
    100% {
        height: 0;
    }
}
/******************/
.sec01_padding {
    padding: 400px 0;
}
.sec01_flex {
    display: flex;
    justify-content: space-between;
}
.sec01_left {
    width: 680px;
    font-size: 105px;
    line-height: 1.4em;
    font-feature-settings: "palt";
    margin-top: -40px;
}
.ita {
    font-style: italic;
}
.sec01_right {
    width: calc(100% - 680px);
    max-width: 820px;
    padding-right: 90px;
}
.sec01_text {
    font-size: 22px;
    font-weight: bold;
    line-height: 2.6em;
}
.more.more_r a {
    margin: 0 0 0 auto;
}
.more a {
    width: 210px;
    height: 90px;
    display: flex;
    align-items: center;
    position: relative;
    color: inherit;
    font-size: 18px;
}
.more a .shape {
    width: 90px;
    height: 90px;
    background-color: #0b3b67;
    border-radius: 50%;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 0.3s ease;
}
.more a .bb {
    border-bottom: 2px solid #0b3b67;
}
.more a:hover .shape {
    transform: translateY(-50%) scale(1.1);
}
.more.more_size80 {
    height: 80px;
}
.more.more_size80 .shape {
    width: 80px;
    height: 80px;
}
.more.more_white a {
    color: #FFF;
}
.more.more_white a .bb {
    border-color: #FFF;
}
.more.more_white a .shape {
    background-color: #FFF;
}
/******************/
.sec02_eng {
    left: -10px;
    /*top: -10px;*/
    top: -100px;
}
.eng_style {
    letter-spacing: 0.01em;
    position: absolute;
    font-size: 200px;
    line-height: 0.8em;
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 1px rgba(255, 255, 255, 0.5);
    text-stroke: 1px rgba(255, 255, 255, 0.5);
    font-style: italic;
}
.sec02_flex {
    padding-top: 100px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.sec02_left {
    width: 48%;
    max-width: 897px;
}
.sec02_left img {
    width: 100%;
    height: 1020px;
    object-fit: cover;
}
.sec02_right {
    width: 46%;
    max-width: 870px;
    padding-top: 50px;
}
.sec02_width {
    width: 90%;
    max-width: 665px;
}
.title_60 {
    font-size: 60px;
    line-height: 1.3em;
    font-style: italic;
}
.ml_minus {
    margin-left: -3px;
}
.line_height20 {
    line-height: 2em;
}
.line_height22 {
    line-height: 2.2em;
}
.line_height24 {
    line-height: 2.4em;
}
/***********/
.bg_blue_0b3b67 {
    background-color: #0b3b67;
}
.sec03_eng {
    right: 15px;
    top: 50px;
    z-index: 400;
}
.sec03_flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 880px;
    overflow: hidden;
}
.sec03_left {
    width: calc(100% - 700px);
    display: flex;
    align-items: center;
}
.sec03_right {
    width: 670px;
    display: flex;
    justify-content: space-between;
}
.sec03_right > div {
    width: 48%;
}
.sec03_right > div:nth-child(1) {
    margin-top: -460px;
}
/* ------------------------------
   loopSlider
------------------------------ */
.loopSliderWrap {
    top: 0;
    left: 0;
    height: 385px;
    position: absolute;
}
.loopSlider {
    width: 100%;
    height: 385px;
    text-align: left;
    position: relative;
}
.loopSlider ul {
    height: 385px;
    float: left;
}
.loopSlider ul li {
    height: 385px;
    display: block;
    overflow: hidden;
    width: 320px;
}
.loopSlider ul li img {
    height: auto;
    width: 100%;
}
/* ------------------------------
   loopSlider
------------------------------ */
.loopSliderWrap2 {
    bottom: 0;
    left: 0;
    height: 385px;
    position: absolute;
    padding-top: 250px;
}
.loopSlider2 {
    width: 100%;
    height: 385px;
    text-align: left;
    position: relative;
}
.loopSlider2 ul {
    height: 385px;
    float: left;
}
.loopSlider2 ul li {
    height: 385px;
    display: block;
    overflow: hidden;
    width: 320px;
}
.loopSlider2 ul li img {
    height: auto;
    width: 100%;
}
/* ------------------------------
   CLEARFIX ELEMENTS
------------------------------ */
.loopSliderWrap:after, .loopSliderWrap2:after {
    content: "";
    display: none;
    clear: none;
}
/***************************************/
.sec04_flex {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.sec04_flex > div {
    width: 48%;
    max-width: 680px;
    position: relative;
}
.sec04_flex > div .img100 img {
    width: 100%;
    height: 100%;
    max-height: 630px;
    min-height: 400px;
    object-fit: cover;
    transition: 0.5s ease;
}
.sec04_flex > div .img100 {
    overflow: hidden;
}
.sec04_flex > div a {
    color: #FFF;
}
.sec04_flex > div a:hover .img100 img {
    transform: scale(1.05);
}
.sec04_flex > div a:hover .shape {
    transform: translateY(-50%) scale(1.1);
}
.sec04_eng_left {
    position: absolute;
    top: -100px;
    left: -4vw;
    z-index: 500;
}
.sec04_eng_right {
    position: absolute;
    top: -100px;
    right: -1vw;
    z-index: 500;
}
.sec04_title {
    font-size: 55px;
    line-height: 1.3em;
    font-style: italic;
    margin: 30px 0 25px;
}
.banner_more {
    width: 210px;
    height: 80px;
    display: flex;
    align-items: center;
    position: absolute;
    right: 40px;
    bottom: 40px;
    color: inherit;
    font-size: 18px;
}
.banner_more .shape {
    width: 80px;
    height: 80px;
    background-color: #FFF;
    border-radius: 50%;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFF;
    transition: 0.3s ease;
}
.banner_more .bb {
    border-bottom: 2px solid #FFF;
}
/******************************/
.sec05_bg {
    background: url("../images/top6.jpg") 10% 0/cover no-repeat;
    position: relative;
    overflow: hidden;
}
.sec05_eng {
    right: 25px;
    bottom: -3px;
}
/****************************/
.sec06_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.sec06_right {
    order: 2;
    width: 46%;
}
.sec06_width {
    max-width: 580px;
    margin-left: auto;
}
.sec06_left {
    width: 51%;
}
.sec06_left img {
    width: 100%;
    height: 680px;
    max-width: 750px;
    object-fit: cover;
}
.sec06_eng {
    position: absolute;
    top: -100px;
    left: -20px;
    z-index: 900;
}
/***************/
.sec07_bg {
    background: url("../images/top8.jpg") 50% 0/cover no-repeat;
    color: #FFF;
    position: relative;
    padding-bottom: 290px;
    overflow: hidden;
}
.sec07_eng {
    right: -5px;
    top: -20px;
    writing-mode: vertical-rl;
    white-space: nowrap;
}
.title_80 {
    font-size: 80px;
    line-height: 1em;
    font-style: italic;
}
.center {
    text-align: center;
}
/************/
.under_banner {
    margin-top: 20px;
    display: flex;
    justify-content: space-between;
    position: relative;
    top: -150px;
    width: 90%;
    max-width: 1580px;
    margin-left: auto;
    margin-right: auto;
}
.under_banner > div {
    width: calc(50% - 2px);
}
.under_banner > div a {
    display: block;
    padding: 70px 90px;
    color: #FFF;
    position: relative;
}
.under_banner > div:nth-child(1) a {
    background-color: #000000;
}
.under_banner > div:nth-child(2) a {
    background-color: #0b3b67;
}
.under_banner > div:hover .banner_shape {
    transform: translateY(-50%) scale(1.1);
}
.banner_eng {
    font-size: 60px;
    line-height: 1.3em;
}
.banner_ja {
    font-size: 23px;
}
.banner_shape {
    position: absolute;
    right: 90px;
    top: 50%;
    transform: translateY(-50%);
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #FFF;
    transition: 0.3s ease;
}
/**********/
.cy_footer {
    background-color: #FFF;
    padding: 250px 0 0;
    margin-top: -280px;
}
.n_flex {
    display: flex;
    justify-content: space-between;
}
.n_flex a {
    color: inherit;
}
.n_flex .f_mt {
    margin-top: 20px;
}
.n_eng {
    color: #0b3b67;
    font-size: 14px;
}
.n_ja {
    color: #000000;
}
.sub_menu {
    font-size: 14px;
    margin-top: 15px;
}
.sub_menu p {
    margin: 10px 0;
}
/**/
.f_bt {
    border-top: 1px solid #e5e5e5;
    margin-top: 120px;
    padding: 120px 0;
}
.f_flex {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}
.f_logo {
    display: flex;
    align-items: flex-end;
}
.f_logo img:nth-child(2) {
    margin-bottom: 7px;
    margin-left: 15px;
}
.t17 {
    font-size: 17px;
}
.t15 {
    font-size: 15px;
}
.f_map {
    font-size: 12px;
    margin-left: 10px;
    display: inline-block;
}
.f_map a {
    color: #44494d;
    margin-left: 8px;
    border-bottom: 1px solid #44494d;
    padding-bottom: 2px;
}
.fff {
    display: flex;
    justify-content: flex-end;
}
.fff > p {
    padding: 0 20px;
    line-height: 1em;
}
.fff > p:last-child {
    padding-right: 0;
}
.fff a {
    color: inherit;
    font-size: 14px;
}
.fff > p:nth-child(1) {
    border-right: 2px solid #d1d1d1;
}
.fff > p:nth-child(1) img {
    margin: 0 0 3px 5px;
}
.copy {
    margin-top: 25px;
    text-align: right;
    font-size: 13px;
    color: #44494d;
}
/**animation****/
.wow_bg_list {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.wow_bg_list > div {
    position: absolute;
    top: 0;
    right: 0;
    width: 25%;
    height: 100%;
    background-color: #FFF;
    z-index: 600;
}
.wow_bg_list > div:nth-child(1) {
    right: 0;
}
.wow_bg_list > div:nth-child(2) {
    right: 25%;
}
.wow_bg_list > div:nth-child(3) {
    right: 50%;
}
.wow_bg_list > div:nth-child(4) {
    right: 75%;
}
/*******************************************************

    トップメッセージ

*******************************************************/
.message_main {
    background: url("../images/message1.jpg") 50% 0/cover no-repeat;
}
.main_size {
    height: 700px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFF;
    padding-top: 100px;
}
.main_size h2 {
    font-size: 75px;
    line-height: 1.3em;
    letter-spacing: 0.08em;
}
.main_size h2 span {
    display: inline-block;
    transform: skewX(-10deg);
}
.main_size p {
    font-size: 40px;
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 1px rgba(255, 255, 255, 0.7);
    text-stroke: 1px rgba(255, 255, 255, 0.7);
    font-style: italic;
    margin-top: 15px;
}
/************/
.eng_style230 {
    letter-spacing: 0.01em;
    position: absolute;
    font-size: 230px;
    line-height: 0.8em;
    color: rgba(255, 255, 255, 0);
    -webkit-text-stroke: 1px rgba(255, 255, 255, 0.5);
    text-stroke: 1px rgba(255, 255, 255, 0.5);
    font-style: italic;
}
.g_eng1 {
    right: 13px;
    top: 220px;
}
.title_55 {
    font-size: 55px;
    font-style: italic;
    line-height: 1.5em;
}
.eng_35 {
    font-size: 35px;
    color: #0b3b67;
    font-style: italic;
    letter-spacing: 0.08em;
}
.gree_img img {
    width: 100%;
    height: 620px;
    object-fit: cover;
}
.name {
    background-color: #e8ebed;
    padding: 40px 45px 20px 45px;
    position: absolute;
    right: 0;
    bottom: 0;
}
/***************/
.message_bg {
    background: url("../images/message4.jpg") 50% 0/1920px 580px no-repeat;
}
.message_bg_w {
    background-color: #FFF;
    padding: 70px 30px;
}
.goal_img {
    text-align: center;
}
.goal_img img {
    max-width: 100%;
    height: auto;
}
.normal {
    font-style: normal;
}
.text_18 {
    font-size: 18px;
}
.message_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.message_left {
    width: 52%;
}
.message_left h3 {
    font-size: 35px;
    font-weight: bold;
    position: relative;
    padding-left: 170px;
    line-height: 1.4em;
}
.message_left h3 img {
    position: absolute;
    top: 1px;
    left: 0;
}
.message_right {
    width: 46%;
    max-width: 540px;
}
.message_right img {
    width: 100%;
    min-height: 360px;
    height: 100%;
    object-fit: cover;
}
/**********/
.g_eng2 {
    left: -17px;
    bottom: 50px;
}
.message_bg_w2 {
    background-color: #FFF;
    padding: 160px 100px;
}
.m_text {
    text-align: center;
    word-break: break-all;
}
/*******************************************************

    事業内容

*******************************************************/
.business_main {
    background: url("../images/business1.jpg") 50% 0/cover no-repeat;
}
/***************/
.b_bb {
    border-bottom: 1px solid #e1e4e6;
    padding-bottom: 100px;
}
.b_eng2 {
    /*right: 0;*/
    right: 25px;
    top: 15px;
}
.business_list {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.business_list > div {
    width: 49.3%;
    margin: 0.8% 0;
}
.business_list > div:nth-child(3) {
    width: 100%;
}
.business_list > div:nth-child(3) img {
    max-height: 600px;
    min-height: 400px;
}
.business_list > div img {
    width: 100%;
    height: 100%;
    max-height: 420px;
    min-height: 300px;
    object-fit: cover;
}
.title_35 {
    font-size: 35px;
    font-weight: bold;
    line-height: 1.5em;
}
.af_bb:after {
    content: "";
    display: block;
    border-bottom: 2px solid #0b3b67;
    width: 60px;
    margin: 20px 0 0;
}
.business_text_list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 20px;
    row-gap: 10px;
}
.business_text_list > p {
    background-color: #FFF;
    font-size: 18px;
    padding: 28px 30px;
    line-height: 1.5em;
}
.indent_p {
    text-indent: -1.1em;
    padding-left: 1.1em;
}
/***********/
.business_border {
    border: 2px solid #000;
    padding: 70px 100px;
}
.title_40 {
    font-size: 40px;
    font-weight: bold;
    line-height: 1.5em;
}
.more.more_c a {
    margin: 0 auto;
}
.business_img1 img {
    width: 100%;
    height: 100%;
    max-height: 600px;
    min-height: 400px;
    object-fit: cover;
}
/*************/
.business_list2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 80px;
    row-gap: 70px;
}
.business_list2 h3 {
    font-size: 35px;
    font-weight: bold;
    display: flex;
    align-items: center;
    margin: 30px 0 20px;
    line-height: 1.5em;
}
.business_list2 h3:before {
    content: "";
    border-bottom: 2px solid #0b3b67;
    margin-right: 20px;
    width: 60px;
}
.business_list2 img {
    width: 100%;
    height: 100%;
    max-height: 400px;
    min-height: 300px;
    object-fit: cover;
}
/**********/
.message_flexbox {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.message_box_left {
    width: 33%;
}
.message_box_left img {
    width: 100%;
}
.message_box_right {
    width: 64%;
}
.message_name {
    font-size: 12px;
}
.message_name span {
    font-size: 20px;
    margin-top: 10px;
    display: block;
}
/*******************************************************

    SDGs

*******************************************************/
.sdgs_main {
    background: url("../images/sdgs1.jpg") 70% 0/cover no-repeat;
}
/***************/
.sdgs_img img {
    width: 100%;
    height: 100%;
    max-height: 630px;
    min-height: 400px;
    object-fit: cover;
}
.sdgs_flex > div {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding-bottom: 120px;
    border-bottom: 1px solid #e1e4e6;
}
.sdgs_flex > div:nth-child(n+2) {
    padding-top: 120px;
}
.sdgs_left {
    width: 60%;
}
.sdgs_left h3 {
    position: relative;
    display: flex;
    align-items: center;
}
.sdgs_left h3 img {
    margin-right: 30px;
}
.sdgs_bg_w {
    background-color: #FFF;
    padding: 50px 40px;
}
.sdgs_bg_w .title_25 {
    padding-left: 3px;
}
.title_25 {
    font-size: 25px;
    font-weight: bold;
    line-height: 1.6em;
}
.sdgs_list p {
    margin: 7px 0;
    text-indent: -1.1em;
    padding-left: 1.1em;
}
.sdgs_right {
    width: 32%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 10px;
    row-gap: 10px;
}
/*****************/
.sdgs_flex2 > div {
    display: flex;
    justify-content: space-between;
}
.sdgs_flex2 > div:nth-child(n+2) {
    padding-top: 100px;
}
.sdgs_left2 {
    width: 47%;
}
.sdgs_left2 img {
    width: 100%;
    height: 100%;
    max-height: 350px;
    min-height: 300px;
    object-fit: cover;
}
.sdgs_right2 {
    width: 47%;
    padding-top: 25px;
}
.sdgs_right2 h3:after {
    content: "";
    display: block;
    border-bottom: 2px solid #0b3b67;
    width: 60px;
    margin: 20px 0 0;
}
/*******************************************************

    会社概要

*******************************************************/
.company_main {
    background: url("../images/company1.jpg") 70% 0/cover no-repeat;
}
/***************/
.com_table > div {
    display: flex;
    justify-content: space-between;
    border-right: 1px solid #707070;
}
.com_table > div:nth-child(1) {
    border-top: 1px solid #707070;
}
.com_cell1 {
    width: 300px;
    background-color: #0b3b67;
    padding: 40px 35px;
    border-bottom: 1px solid #FFF;
    font-size: 18px;
    color: #FFF;
}
.com_cell2 {
    width: calc(100% - 300px);
    padding: 40px 35px;
    border-bottom: 1px solid #707070;
    padding: 40px 60px;
}
.circle_list > p {
    position: relative;
    margin: 10px 0;
    padding-left: 20px;
    line-height: 1.6em;
}
.circle_list > p:before {
    content: "";
    background-color: #0b3b67;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 11px;
}
.p_list_mt5 p:nth-child(n+2) {
    margin-top: 5px;
}
/***************/
.tab ul {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 0;
    row-gap: 0;
    border: 1px solid #000;
}
.tab ul a {
    display: block;
    border-right: 1px solid #000;
    padding: 23px 5px;
    text-align: center;
    color: #000;
    transition: 0.5s ease;
    font-size: 18px;
}
.tab ul a:hover {
    background-color: #000;
    color: #FFF;
}
.tab ul li:last-child a {
    border-right: 0;
}
.tab ul .active {
    background-color: #000;
    color: #FFF;
}
.title_42 {
    font-size: 42px;
    font-style: italic;
    font-weight: bold;
    line-height: 1.3em;
}
.history {
    padding-left: 100px;
    position: relative;
}
.history > div {
    display: flex;
    justify-content: space-between;
    position: relative;
}
.history > div:before {
    content: "";
    background-color: #0b3b67;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    position: absolute;
    left: -80px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 500;
}
.history > div:nth-child(n+2) {
    margin-top: 20px;
}
.history > div:last-child:after {
    content: "";
    border-left: 3px solid #e8ebed;
    position: absolute;
    left: -74px;
    bottom: -30px;
    height: 100%;
    z-index: 1;
}
.b_none .history > div:last-child:after {
    content: "";
    border-left: none;
}
.history p {
    line-height: 1.8em;
}
.history:after {
    content: "";
    border-left: 1px solid #0b3b67;
    width: 1px;
    height: 100%;
    position: absolute;
    left: 26.5px;
    top: 20px;
}
.b_none.history:after {
    content: "";
    border-left: 1px #e8ebed;
    width: 1px;
    height: 100%;
    position: absolute;
    left: 26.5px;
    top: 20px;
}
.his_cell1 {
    width: 260px;
    font-size: 22px;
    color: #FFF;
    background-color: #0b3b67;
    padding: 3px 0 5px 40px;
    position: relative;
    display: flex;
    align-items: center;
}
.his_cell1:before {
    content: "";
    background: url("../images/company2.png") left 0/100% 100% no-repeat;
    width: 25px;
    height: 100%;
    position: absolute;
    left: -25px;
    top: 0;
}
.his_cell2 {
    width: calc(100% - 260px);
    background-color: #FFF;
    padding: 8px 25px;
    font-size: 18px;
}
/*******************************************************

    インタビュー

*******************************************************/
.interview_main {
    background: url("../images/interview1.jpg") 70% 0/cover no-repeat;
}
/***************/
.inter_eng {
    top: 180px;
    left: 0;
}
.interview_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 35px;
    row-gap: 70px;
}
.interview_grid > div {
    cursor: pointer;
}
.interview_grid > div img {
    transition: 0.5s ease;
}
.interview_grid > div .img100 {
    overflow: hidden;
}
.interview_grid > div .img100:hover img {
    transform: scale(1.1);
}
.type {
    width: fit-content;
    background-color: #0b3b67;
    color: #FFF;
    position: absolute;
    left: 0;
    bottom: 0;
    font-size: 18px;
    padding: 0 15px;
}
.inter_name {
    margin: 20px 0 10px;
    font-size: 27px;
    line-height: 1.5em;
    font-weight: bold;
}
/**ポップアップ*********/
.popup {
    display: none;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    z-index: 9999999;
}
.pop_close {
    position: fixed;
    top: 55px;
    right: 65px;
    cursor: pointer;
    z-index: 999;
}
.bg_pop {
    background-color: rgba(0, 0, 0, 0.3);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.pop_contents {
    padding: 78px;
    background-color: #ffffff;
    width: 90%;
    max-width: 1585px;
    height: 92.5%;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    overflow-y: scroll;
}
.pop_flex {
    display: flex;
    justify-content: space-between;
}
.pop_left {
    width: 32.7%;
    max-width: 470px;
}
.pop_name_box {
    background-color: #0b3b67;
    padding: 25px 45px;
    width: 90%;
    max-width: 400px;
    margin: -60px auto 0;
    color: #FFF;
    position: relative;
    z-index: 500;
}
.pop_name {
    font-size: 27px;
    margin-bottom: 5px;
    line-height: 1.5em;
}
.pop_right {
    width: 62.5%;
    padding-top: 50px;
}
.pop_right h3 {
    color: #0b3b67;
    font-size: 30px;
    font-weight: bold;
    font-style: italic;
    line-height: 1.5em;
    margin-bottom: 15px;
}
.pop_right h3:nth-child(n+2) {
    margin-top: 40px;
}
.pop_right p {
    line-height: 1.8em;
}
/*******************************************************

    数字で見るハラダ工業

*******************************************************/
.data_main {
    background: url("../images/data1.jpg") 50% 0/cover no-repeat;
}
/***************/
.data_grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 35px;
    row-gap: 35px;
}
.data_grid > div {
    background-color: #FFF;
    padding: 50px 10px;
}
.data_grid > div h3 {
    background-color: #0b3b67;
    color: #FFF;
    text-align: center;
    font-size: 25px;
    line-height: 1.8em;
    max-width: 500px;
    margin: 0 auto;
    padding: 5px;
}
.data_grid .icon {
    height: 250px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.num_flex {
    display: flex;
    justify-content: center;
    text-align: center;
    flex-wrap: wrap;
    align-items: flex-end;
}
.num_flex > p {
    position: relative;
    font-size: 50px;
    line-height: 1.5em;
    font-weight: bold;
}
.num_flex > p .big100 {
    color: #0b3b67;
    font-size: 100px;
}
.num_flex > p .big120 {
    color: #0b3b67;
    font-size: 120px;
}
.num_flex > p .big90 {
    color: #0b3b67;
    font-size: 90px;
}
.ver {
    writing-mode: vertical-rl;
    font-size: 35px;
    font-family: "NotoSansCJKjp-Regular_ver";
    position: relative;
    top: 3px;
}
.t20_center {
    font-size: 20px;
    text-align: center;
}
/****/
.data_graph {
    margin-top: 35px;
    background-color: #FFF;
    padding: 50px 10px;
    text-align: center;
}
.data_graph h3 {
    background-color: #0b3b67;
    color: #FFF;
    text-align: center;
    font-size: 25px;
    line-height: 1.8em;
    max-width: 800px;
    margin: 0 auto;
    padding: 5px;
}
/*******************************************************

    エントリー

*******************************************************/
.entry_main {
    background: url("../images/entry1.jpg") 50% 0/cover no-repeat;
}
/***************/
.flow_list > div:not(.flow_shape) {
    display: flex;
    justify-content: space-between;
}
.flow_cell1 {
    width: 280px;
    background-color: #0b3b67;
    padding-left: 60px;
    display: flex;
    align-items: center;
}
.flow_cell2 {
    width: calc(100% - 280px);
    background-color: #FFF;
    padding: 40px 50px;
}
.blue_0b3b67 {
    color: #0b3b67;
}
.flow_shape {
    text-align: center;
    margin: 30px 0;
}
/****************/
.entry_table > div {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.entry_table > div:nth-child(n+2) {
    margin-top: 40px;
}
.e_cell1 {
    width: 310px;
    display: flex;
    align-items: center;
    font-size: 23px;
    line-height: 1.5em;
    padding-top: 30px;
}
.hissu {
    background-color: #a40000;
    width: 60px;
    color: #FFF;
    text-align: center;
    font-size: 18px;
    margin-right: 15px;
}
.nini {
    background-color: #626262;
    width: 60px;
    color: #FFF;
    text-align: center;
    font-size: 18px;
    margin-right: 15px;
}
.e_cell2 {
    width: calc(100% - 310px);
}
.size input, .area textarea {
    width: 100%;
    background-color: #FFF;
    border: 1px solid #aaaaaa;
    padding: 10px 20px;
}
.size input {
    height: 90px;
}
.area textarea {
    height: 300px;
}
.postal_flex {
    display: flex;
    align-items: center;
    max-width: 400px;
    width: 100%;
}
.postal_cell1 {
    margin-right: 20px;
    font-size: 25px;
}
.postal_cell2 {
    flex-grow: 2;
}
.label_flex {
    font-size: 20px;
    padding-top: 30px;
    padding-bottom: 30px;
}
.label_flex > span {
    display: flex;
}
.label_flex .wpcf7-list-item {
    margin-right: 30px;
}
.label_flex label {
    cursor: pointer;
}
input[type="radio"] {
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
input[type="radio"] {
    width: 20px;
    height: 20px;
    border-radius: 100px;
    position: relative;
    vertical-align: sub;
    margin-right: 20px;
}
input[type="radio"]::before, input[type="radio"]::after {
    content: "";
    display: block;
    border-radius: 50%;
    position: absolute;
    transform: translateY(-50%);
    top: 50%;
    transition: 0.5s ease;
}
input[type="radio"]::before {
    background-color: #fff;
    border: 1px solid #aaaaaa;
    height: 27px;
    width: 27px;
    left: 0px;
}
input[type="radio"]::after {
    background-color: #0b3b67;
    opacity: 0;
    height: 15px;
    width: 15px;
    left: 6px;
}
input[type="radio"]:checked::after {
    opacity: 1;
}
.sub {
    width: 100%;
    max-width: 600px;
    background-color: #000080;
    border: 2px solid #000080;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    transition: 0.5s ease;
    color: #FFF;
}
.sub input {
    border: 0;
    background: rgba(0, 0, 0, 0);
    display: block;
    width: 100%;
    font-size: 30px;
    text-align: center;
    padding: 50px 0;
    position: relative;
    z-index: 500;
    letter-spacing: 0.08em;
}
.sub .shape {
    position: absolute;
    right: 50px;
    top: 50%;
    transform: translateY(-50%);
}
.sub .shape img {
    width: 22px;
    height: auto;
    transition: 0.5s ease;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
}
.sub .shape .on {
    opacity: 0;
}
.sub:hover {
    background-color: #FFF;
    border-color: #000;
    color: #000;
}
.sub:hover .shape .off {
    opacity: 0;
}
.sub:hover .shape .on {
    opacity: 1;
}
/*******************************************************

    福利厚生

*******************************************************/
.welfare_main {
    background: url("../images/welfare1.jpg") 70% 0/cover no-repeat;
}
/***************/
.wel_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 30px;
    row-gap: 30px;
}
.wel_grid > div {
    padding: 60px 10px 50px;
    text-align: center;
    background-color: #FFF;
}
.wel_grid h3 {
    font-size: 25px;
    font-weight: bold;
    margin-top: 18px;
    line-height: 1.5em;
}
.wel_grid h3.line_15 {
    line-height: 1.2em;
}
.wel_grid h3:not(.min_none) {
    min-height: 90px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}
.wel_grid p {
    margin-top: 10px;
}
/********/
.be_bb {
    display: flex;
    align-items: center;
}
.be_bb:before {
    content: "";
    border-bottom: 2px solid #0b3b67;
    width: 60px;
    margin-right: 25px;
}
.wel_flex {
    display: flex;
    justify-content: space-between;
}
.wel_flex > div {
    width: 48%;
}
.wel_flex img {
    width: 100%;
    height: 100%;
    min-height: 380px;
    max-height: 460px;
    object-fit: cover;
}
/*******************************************************

    募集要項

*******************************************************/
.recruit_main {
    background: url("../images/recruit1.jpg") 40% 0/cover no-repeat;
}
/***************/
.rec_table > div {
    display: flex;
    justify-content: space-between;
    margin-top: 2px;
}
.rec_cell1 {
    width: 300px;
    background-color: #0b3b67;
    padding: 40px 35px;
    font-size: 20px;
    color: #FFF;
}
.rec_cell2 {
    width: calc(100% - 300px);
    background-color: #FFF;
    padding: 40px 35px;
}
.entry_button {
    width: 100%;
    max-width: 600px;
    background-color: #000080;
    border: 2px solid #000080;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    transition: 0.5s ease;
}
.entry_button a {
    border: 0;
    background: rgba(0, 0, 0, 0);
    display: block;
    width: 100%;
    font-size: 30px;
    text-align: center;
    padding: 50px 0;
    position: relative;
    z-index: 500;
    color: #FFF;
    letter-spacing: 0.08em;
    transition: 0.5s ease;
}
.entry_button .shape {
    position: absolute;
    right: 50px;
    top: 50%;
    transform: translateY(-50%);
}
.entry_button .shape img {
    width: 22px;
    height: auto;
    transition: 0.5s ease;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
}
.entry_button .shape .on {
    opacity: 0;
}
.entry_button:hover {
    background-color: #FFF;
    border-color: #000;
}
.entry_button:hover a {
    color: #000;
}
.entry_button:hover .shape .off {
    opacity: 0;
}
.entry_button:hover .shape .on {
    opacity: 1;
}
/*******************************************************

    プライバシーポリシー

*******************************************************/
.privacy_main {
    background: url("../images/privacy1.jpg") 60% 0/cover no-repeat;
}
/***************/
.title_45 {
    font-size: 45px;
    font-weight: bold;
    font-style: italic;
    line-height: 1.5em;
}
.num_p p {
    text-indent: -0.9em;
    padding-left: 0.9em;
}
.pri_pl {
    padding-left: 1.1em;
}
/**/
.font_kizuna {
    font-family: system-ui;
    font-weight: bold;
}

/********************/

.rec_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 20px;
    row-gap: 20px;
}
.rec_grid > div {
    background-color: #FFF;
}
.rec_grid a{
    padding: 15px;
    color: inherit;
    font-size: 15px;
    height: 100%;
    display: block;
}
.rec_grid a:hover .img100 img{
    transform:scale(1.05);
        
}
.rec_grid .img100 {
    overflow: hidden;
}
.rec_grid .img100 img{
    height: 300px;
    object-fit: cover;
    transition: 0.3s ease;
}
.rec_table2 {
    margin-top: 10px;
}
.rec_table2 > div {
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid rgba(205,205,205,1.00);
}
.rec_table2 > div:last-child {
    border-bottom: 0;
}
.rec_1 {
    width: 90px;
    font-weight: bold;
    color: #000080;
}
.rec_2 {
    width: calc(100% - 90px);
}

.rec_cell2 .t-b:nth-child(n+2) {
    margin-top: 10px;
}
.rec_pl {
    padding-left: 17px;
}
/* PC用
------------------------------------------------------------*/
@media only screen and (max-width: 1699px) {
    /******************/
    .sec01_right {
        padding-right: 0;
    }
}
@media only screen and (max-width: 1650px) {
    /******************/
}
@media only screen and (max-width: 1500px) {
    /******/
    .top_title h2 {
        font-size: 120px;
    }
    .top_title i img {
        width: 100px;
        height: auto;
    }
    .message_box_left {
        width: 40%;
    }
    .message_box_right {
        width: 56%;
    }
}
@media only screen and (max-width: 1400px) {
    .num_flex > p {
        font-size: 35px;
    }
    .num_flex > p .big100 {
        font-size: 70px;
    }
    .num_flex > p .big120 {
        font-size: 80px;
    }
    .num_flex > p .big90 {
        font-size: 70px;
    }
}
@media only screen and (max-width: 1200px) {
    .m_header {
        width: calc(100% - 350px);
    }
    .m_logo img:nth-child(1) {
        width: auto;
        height: 40px;
    }
    .m_logo img:nth-child(2) {
        width: auto;
        height: 20px;
    }
    /************************/
    .cy_header {
        width: calc(100% - 350px);
    }
    .logo img:nth-child(1) {
        width: auto;
        height: 40px;
    }
    .logo img:nth-child(2) {
        width: auto;
        height: 20px;
    }
    /******/
    .top_main {
        position: relative;
    }
    .top_main, .flexslider, .flexslider li {
        height: 970px;
    }
    .top_title {
        padding-top: 80px;
    }
    .top_title h2 {
        font-size: 90px;
        line-height: 1em;
        letter-spacing: 0.05em;
    }
    .top_title i {
        margin: 0 0 0 10px;
    }
    .top_title i img {
        width: 60px;
        height: auto;
    }
    .top_title h3 {
        font-size: 28px;
        line-height: 1em;
        color: #FFF;
        font-style: italic;
        letter-spacing: 0.05em;
        margin-top: 40px;
    }
    /******************/
    .sec01_padding {
        padding: 200px 0;
    }
    .sec01_left {
        width: 450px;
        font-size: 70px;
        line-height: 1.4em;
        margin-top: 0;
    }
    .sec01_right {
        width: calc(100% - 450px);
        max-width: 820px;
        padding-right: 0;
    }
    /***********/
    .sec03_left {
        width: calc(100% - 550px);
    }
    .sec03_right {
        width: 500px;
        display: flex;
        justify-content: space-between;
    }
    .sec03_right > div {
        width: 48%;
    }
    .sec03_right > div:nth-child(1) {
        margin-top: -300px;
    }
    .eng_style {
        font-size: 150px;
    }
    /* ************ */
    .message_flexbox {
        flex-wrap: wrap;
    }
    .message_box_left {
        width: 50%;
        min-width: 340px;
        margin: 30px auto 0;
        order: 2;
    }
    .message_box_right {
        width: 100%;
    }
    .message_bg_w2 {
        background-color: #FFF;
        padding: 100px 60px;
    }
    /* ------------------------------
   loopSlider
------------------------------ */
    .loopSliderWrap {
        height: 288px;
    }
    .loopSlider {
        height: 288px;
    }
    .loopSlider ul {
        height: 288px;
    }
    .loopSlider ul li {
        height: 288px;
        width: 240px;
    }
    /* ------------------------------
   loopSlider
------------------------------ */
    .loopSliderWrap2 {
        height: 288px;
        padding-top: 350px;
    }
    .loopSlider2 {
        height: 288px;
    }
    .loopSlider2 ul {
        height: 288px;
    }
    .loopSlider2 ul li {
        height: 288px;
        width: 240px;
    }
    /************/
    .under_banner {
        top: -130px;
    }
    .under_banner > div a {
        padding: 50px 40px;
    }
    .banner_shape {
        right: 40px;
    }
    /**/
    .fff {
        display: block;
        text-align: right;
    }
    .fff > p {
        padding: 10px 0;
        line-height: 1em;
    }
    .fff > p:last-child {
        padding-right: 0;
    }
    .fff a {
        color: inherit;
        font-size: 14px;
    }
    .fff > p:nth-child(1) {
        border-right: 0;
    }
    .fff > p:nth-child(1) img {
        margin: 0 0 3px 5px;
    }
    /**ポップアップ*********/
    .pop_name_box {
        padding: 15px 20px;
    }


/********************/

.rec_grid a{
    font-size: 14px;
}
.rec_grid .img100 img{
    height: 200px;
}



}
@media only screen and (max-width: 1024px) {
    .padding100 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding110 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding120 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding130 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding140 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding150 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding160 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding170 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding180 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding190 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding200 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding210 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding220 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding230 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding240 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding250 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding260 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding270 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding280 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding290 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .padding300 {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .margin100 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin110 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin120 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin130 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin140 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin150 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin160 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin170 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin180 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin190 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin200 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin210 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin220 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin230 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin240 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin250 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin260 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin270 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin280 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin290 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .margin300 {
        margin-top: 120px;
        margin-bottom: 120px;
    }
    .pt-120 {
        padding-top: 120px;
    }
    .pt-130 {
        padding-top: 120px;
    }
    .pt-140 {
        padding-top: 120px;
    }
    .pt-150 {
        padding-top: 120px;
    }
    .pt-160 {
        padding-top: 120px;
    }
    .pt-170 {
        padding-top: 120px;
    }
    .pt-180 {
        padding-top: 120px;
    }
    .pt-190 {
        padding-top: 120px;
    }
    .pt-200 {
        padding-top: 120px;
    }
    .pt-210 {
        padding-top: 120px;
    }
    .pt-220 {
        padding-top: 120px;
    }
    .pt-230 {
        padding-top: 120px;
    }
    .pt-240 {
        padding-top: 120px;
    }
    .pt-250 {
        padding-top: 120px;
    }
    .pt-260 {
        padding-top: 120px;
    }
    .pt-270 {
        padding-top: 120px;
    }
    .pt-280 {
        padding-top: 120px;
    }
    .pt-290 {
        padding-top: 120px;
    }
    .pt-300 {
        padding-top: 120px;
    }
    .pb-120 {
        padding-bottom: 120px;
    }
    .pb-130 {
        padding-bottom: 120px;
    }
    .pb-140 {
        padding-bottom: 120px;
    }
    .pb-150 {
        padding-bottom: 120px;
    }
    .pb-160 {
        padding-bottom: 120px;
    }
    .pb-170 {
        padding-bottom: 120px;
    }
    .pb-180 {
        padding-bottom: 120px;
    }
    .pb-190 {
        padding-bottom: 120px;
    }
    .pb-200 {
        padding-bottom: 120px;
    }
    .pb-210 {
        padding-bottom: 120px;
    }
    .pb-220 {
        padding-bottom: 120px;
    }
    .pb-230 {
        padding-bottom: 120px;
    }
    .pb-240 {
        padding-bottom: 120px;
    }
    .pb-250 {
        padding-bottom: 120px;
    }
    .pb-260 {
        padding-bottom: 120px;
    }
    .pb-270 {
        padding-bottom: 120px;
    }
    .pb-280 {
        padding-bottom: 120px;
    }
    .pb-290 {
        padding-bottom: 120px;
    }
    .pb-300 {
        padding-bottom: 120px;
    }
    .mt-120 {
        margin-top: 120px;
    }
    .mt-130 {
        margin-top: 120px;
    }
    .mt-140 {
        margin-top: 120px;
    }
    .mt-150 {
        margin-top: 120px;
    }
    .mt-160 {
        margin-top: 120px;
    }
    .mt-170 {
        margin-top: 120px;
    }
    .mt-180 {
        margin-top: 120px;
    }
    .mt-190 {
        margin-top: 120px;
    }
    .mt-200 {
        margin-top: 120px;
    }
    .mt-210 {
        margin-top: 120px;
    }
    .mt-220 {
        margin-top: 120px;
    }
    .mt-230 {
        margin-top: 120px;
    }
    .mt-240 {
        margin-top: 120px;
    }
    .mt-250 {
        margin-top: 120px;
    }
    .mt-260 {
        margin-top: 120px;
    }
    .mt-270 {
        margin-top: 120px;
    }
    .mt-280 {
        margin-top: 120px;
    }
    .mt-290 {
        margin-top: 120px;
    }
    .mt-300 {
        margin-top: 120px;
    }
    .mb-120 {
        margin-bottom: 120px;
    }
    .mb-130 {
        margin-bottom: 120px;
    }
    .mb-140 {
        margin-bottom: 120px;
    }
    .mb-150 {
        margin-bottom: 120px;
    }
    .mb-160 {
        margin-bottom: 120px;
    }
    .mb-170 {
        margin-bottom: 120px;
    }
    .mb-180 {
        margin-bottom: 120px;
    }
    .mb-190 {
        margin-bottom: 120px;
    }
    .mb-200 {
        margin-bottom: 120px;
    }
    .mb-210 {
        margin-bottom: 120px;
    }
    .mb-220 {
        margin-bottom: 120px;
    }
    .mb-230 {
        margin-bottom: 120px;
    }
    .mb-240 {
        margin-bottom: 120px;
    }
    .mb-250 {
        margin-bottom: 120px;
    }
    .mb-260 {
        margin-bottom: 120px;
    }
    .mb-270 {
        margin-bottom: 120px;
    }
    .mb-280 {
        margin-bottom: 120px;
    }
    .mb-290 {
        margin-bottom: 120px;
    }
    .mb-300 {
        margin-bottom: 120px;
    }
    .m_header {
        padding: 20px 0;
    }
    .m_logo img:nth-child(2) {
        display: block;
        position: relative;
        top: 10px;
        width: auto;
        height: 20px;
        margin-left: 54px;
    }
    /************************/
    .cy_header {
        padding: 20px 0;
    }
    .logo img:nth-child(2) {
        display: block;
        position: relative;
        top: 10px;
        width: auto;
        height: 20px;
        margin-left: 54px;
    }
    /******************/
    .sec01_padding {
        padding: 150px 0;
    }
    .sec01_flex {
        display: block;
    }
    .sec01_left {
        width: 100%;
        font-size: 70px;
        line-height: 1.4em;
        font-feature-settings: "palt";
        margin-top: 0;
    }
    .ita {
        font-style: italic;
    }
    .sec01_right {
        width: 100%;
        max-width: 100%;
        padding-right: 0;
        margin-top: 40px;
    }
    /***********/
    .sec03_flex {
        height: 600px;
    }
    .sec03_left {
        width: calc(100% - 400px);
        display: flex;
        align-items: center;
    }
    .sec03_right {
        width: 380px;
        display: flex;
        justify-content: space-between;
    }
    .sec03_right > div {
        width: 48%;
    }
    .sec03_right > div:nth-child(1) {
        margin-top: -300px;
    }
    .eng_style {
        font-size: 130px;
    }
    /* ------------------------------
   loopSlider
------------------------------ */
    .loopSliderWrap {
        height: 216px;
    }
    .loopSlider {
        height: 216px;
    }
    .loopSlider ul {
        height: 216px;
    }
    .loopSlider ul li {
        height: 216px;
        width: 180px;
    }
    /* ------------------------------
   loopSlider
------------------------------ */
    .loopSliderWrap2 {
        height: 216px;
        padding-top: 350px;
    }
    .loopSlider2 {
        height: 216px;
    }
    .loopSlider2 ul {
        height: 216px;
    }
    .loopSlider2 ul li {
        height: 216px;
        width: 180px;
    }
    /***************/
    .sec07_bg {
        padding-bottom: 240px;
    }
    /************/
    .banner_eng {
        font-size: 40px;
        line-height: 1.3em;
    }
    .banner_ja {
        font-size: 18px;
    }
    .banner_shape {
        right: 40px;
        width: 60px;
        height: 60px;
    }
    /**********/
    .n_flex {
        flex-wrap: wrap;
    }
    .n_flex > div {
        width: 33.33%;
    }
    .n_flex > div:nth-child(n+4) {
        margin-top: 40px;
    }
    /**/
    .f_flex {
        display: block;
    }
    .fff {
        display: flex;
        justify-content: center;
        text-align: right;
        margin-top: 20px;
    }
    .fff > p {
        padding: 0 20px;
        line-height: 1em;
    }
    .fff > p:last-child {
        padding-right: 0;
    }
    .fff a {
        color: inherit;
        font-size: 14px;
    }
    .fff > p:nth-child(1) {
        border-right: 2px solid #d1d1d1;
    }
    .fff > p:nth-child(1) img {
        margin: 0 0 3px 5px;
    }
    .copy {
        margin-top: 25px;
        text-align: center;
        font-size: 13px;
        color: #44494d;
    }
    /*******************************************************

    トップメッセージ

*******************************************************/
    .message_left {
        width: 52%;
    }
    .message_left h3 {
        font-size: 30px;
        font-weight: bold;
        position: relative;
        padding-left: 0;
        line-height: 1.4em;
    }
    .message_left h3 img {
        position: static;
        display: block;
        top: 1px;
        left: 0;
        margin-bottom: 15px;
    }
    /*******************************************************

    SDGs

*******************************************************/
    .sdgs_right {
        width: 32%;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 10px;
        row-gap: 10px;
    }
    /*******************************************************

    インタビュー

*******************************************************/
    /**ポップアップ*********/
    .pop_close {
        top: 30px;
        right: 30px;
    }
    .pop_close img {
        width: 40px;
        height: auto;
    }
    .pop_contents {
        padding: 40px;
    }
    .pop_left {
        width: 32.7%;
        max-width: 470px;
    }
    .pop_name_box {
        background-color: #0b3b67;
        padding: 10px 10px;
        width: 90%;
        max-width: 400px;
        margin: -35px auto 0;
        color: #FFF;
        position: relative;
        z-index: 500;
    }
    .pop_name_box p:not(.pop_name) {
        font-size: 13px;
        line-height: 1.8em;
    }
    .pop_name {
        font-size: 20px;
        margin-bottom: 5px;
        line-height: 1.5em;
    }
    .pop_right {
        width: 62.5%;
        padding-top: 50px;
    }
    .pop_right h3 {
        color: #0b3b67;
        font-size: 24px;
        font-weight: bold;
        font-style: italic;
        line-height: 1.5em;
        margin-bottom: 15px;
    }
    .pop_right h3:nth-child(n+2) {
        margin-top: 40px;
    }
    .pop_right p {
        line-height: 1.8em;
    }
    /*******************************************************

    数字で見るハラダ工業

*******************************************************/
    .num_flex {
        display: flex;
        justify-content: center;
        text-align: center;
        flex-wrap: wrap;
        align-items: flex-end;
    }
    .num_flex > p {
        position: relative;
        font-size: 30px;
        line-height: 1.5em;
        font-weight: bold;
    }
    .num_flex > p .big100 {
        color: #0b3b67;
        font-size: 60px;
    }
    .num_flex > p .big120 {
        color: #0b3b67;
        font-size: 70px;
    }
    .num_flex > p .big90 {
        color: #0b3b67;
        font-size: 50px;
    }
    .ver {
        writing-mode: vertical-rl;
        font-size: 22px;
        font-family: "NotoSansCJKjp-Regular_ver";
        position: relative;
        top: 3px;
    }
    /*******************************************************

    プライバシーポリシー

*******************************************************/
    .privacy_main {
        background: url("../images/privacy1.jpg") 60% 0/cover no-repeat;
    }
    /***************/
    .title_45 {
        font-size: 30px;
        font-weight: bold;
        font-style: italic;
        line-height: 1.5em;
    }
    .num_p p {
        text-indent: -0.9em;
        padding-left: 0.9em;
    }
    .pri_pl {
        padding-left: 1.1em;
    }


/********************/

.rec_grid {
    grid-template-columns: repeat(2, 1fr);
}
.rec_grid .img100 img{
    height: 220px;
}

}
@media only screen and (max-width: 740px) {
    .flex_30 {
        width: 100%;
    }
    .flex_31 {
        width: 100%;
    }
    .flex_32 {
        width: 100%;
    }
    .flex_33 {
        width: 100%;
    }
    .flex_34 {
        width: 100%;
    }
    .flex_35 {
        width: 100%;
    }
    .flex_36 {
        width: 100%;
    }
    .flex_37 {
        width: 100%;
    }
    .flex_38 {
        width: 100%;
    }
    .flex_39 {
        width: 100%;
    }
    .flex_40 {
        width: 100%;
    }
    .flex_41 {
        width: 100%;
    }
    .flex_42 {
        width: 100%;
    }
    .flex_43 {
        width: 100%;
    }
    .flex_44 {
        width: 100%;
    }
    .flex_45 {
        width: 100%;
    }
    .flex_46 {
        width: 100%;
    }
    .flex_47 {
        width: 100%;
    }
    .flex_48 {
        width: 100%;
    }
    .flex_49 {
        width: 100%;
    }
    .flex_50 {
        width: 100%;
    }
    .flex_51 {
        width: 100%;
    }
    .flex_52 {
        width: 100%;
    }
    .flex_53 {
        width: 100%;
    }
    .flex_54 {
        width: 100%;
    }
    .flex_55 {
        width: 100%;
    }
    .flex_56 {
        width: 100%;
    }
    .flex_57 {
        width: 100%;
    }
    .flex_58 {
        width: 100%;
    }
    .flex_59 {
        width: 100%;
    }
    .flex_60 {
        width: 100%;
    }
    .flex_61 {
        width: 100%;
    }
    .flex_62 {
        width: 100%;
    }
    .flex_63 {
        width: 100%;
    }
    .flex_64 {
        width: 100%;
    }
    .flex_65 {
        width: 100%;
    }
    .flex_66 {
        width: 100%;
    }
    .flex_67 {
        width: 100%;
    }
    .flex_68 {
        width: 100%;
    }
    .flex_69 {
        width: 100%;
    }
    .flex_70 {
        width: 100%;
    }
    .padding100 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding110 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding120 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding130 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding140 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding150 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding160 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding170 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding180 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding190 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding200 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding210 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding220 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding230 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding240 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding250 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding260 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding270 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding280 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding290 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .padding300 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .margin100 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin110 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin120 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin130 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin140 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin150 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin160 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin170 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin180 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin190 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin200 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin210 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin220 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin230 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin240 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin250 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin260 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin270 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin280 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin290 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .margin300 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .pt-110 {
        padding-top: 80px;
    }
    .pt-120 {
        padding-top: 80px;
    }
    .pt-130 {
        padding-top: 80px;
    }
    .pt-140 {
        padding-top: 80px;
    }
    .pt-150 {
        padding-top: 80px;
    }
    .pt-160 {
        padding-top: 80px;
    }
    .pt-170 {
        padding-top: 80px;
    }
    .pt-180 {
        padding-top: 80px;
    }
    .pt-190 {
        padding-top: 80px;
    }
    .pt-200 {
        padding-top: 80px;
    }
    .pt-210 {
        padding-top: 80px;
    }
    .pt-220 {
        padding-top: 80px;
    }
    .pt-230 {
        padding-top: 80px;
    }
    .pt-240 {
        padding-top: 80px;
    }
    .pt-250 {
        padding-top: 80px;
    }
    .pt-260 {
        padding-top: 80px;
    }
    .pt-270 {
        padding-top: 80px;
    }
    .pt-280 {
        padding-top: 80px;
    }
    .pt-290 {
        padding-top: 80px;
    }
    .pt-300 {
        padding-top: 80px;
    }
    .pb-110 {
        padding-bottom: 80px;
    }
    .pb-120 {
        padding-bottom: 80px;
    }
    .pb-130 {
        padding-bottom: 80px;
    }
    .pb-140 {
        padding-bottom: 80px;
    }
    .pb-150 {
        padding-bottom: 80px;
    }
    .pb-160 {
        padding-bottom: 80px;
    }
    .pb-170 {
        padding-bottom: 80px;
    }
    .pb-180 {
        padding-bottom: 80px;
    }
    .pb-190 {
        padding-bottom: 80px;
    }
    .pb-200 {
        padding-bottom: 80px;
    }
    .pb-210 {
        padding-bottom: 80px;
    }
    .pb-220 {
        padding-bottom: 80px;
    }
    .pb-230 {
        padding-bottom: 80px;
    }
    .pb-240 {
        padding-bottom: 80px;
    }
    .pb-250 {
        padding-bottom: 80px;
    }
    .pb-260 {
        padding-bottom: 80px;
    }
    .pb-270 {
        padding-bottom: 80px;
    }
    .pb-280 {
        padding-bottom: 80px;
    }
    .pb-290 {
        padding-bottom: 80px;
    }
    .mt-110 {
        margin-top: 80px;
    }
    .mt-120 {
        margin-top: 80px;
    }
    .mt-130 {
        margin-top: 80px;
    }
    .mt-140 {
        margin-top: 80px;
    }
    .mt-150 {
        margin-top: 80px;
    }
    .mt-160 {
        margin-top: 80px;
    }
    .mt-170 {
        margin-top: 80px;
    }
    .mt-180 {
        margin-top: 80px;
    }
    .mt-190 {
        margin-top: 80px;
    }
    .mt-200 {
        margin-top: 80px;
    }
    .mt-210 {
        margin-top: 80px;
    }
    .mt-220 {
        margin-top: 80px;
    }
    .mt-230 {
        margin-top: 80px;
    }
    .mt-240 {
        margin-top: 80px;
    }
    .mt-250 {
        margin-top: 80px;
    }
    .mt-260 {
        margin-top: 80px;
    }
    .mt-270 {
        margin-top: 80px;
    }
    .mt-280 {
        margin-top: 80px;
    }
    .mt-290 {
        margin-top: 80px;
    }
    .mt-300 {
        margin-top: 80px;
    }
    .mb-110 {
        margin-bottom: 80px;
    }
    .mb-120 {
        margin-bottom: 80px;
    }
    .mb-130 {
        margin-bottom: 80px;
    }
    .mb-140 {
        margin-bottom: 80px;
    }
    .mb-150 {
        margin-bottom: 80px;
    }
    .mb-160 {
        margin-bottom: 80px;
    }
    .mb-170 {
        margin-bottom: 80px;
    }
    .mb-180 {
        margin-bottom: 80px;
    }
    .mb-190 {
        margin-bottom: 80px;
    }
    .mb-200 {
        margin-bottom: 80px;
    }
    .mb-210 {
        margin-bottom: 80px;
    }
    .mb-220 {
        margin-bottom: 80px;
    }
    .mb-230 {
        margin-bottom: 80px;
    }
    .mb-240 {
        margin-bottom: 80px;
    }
    .mb-250 {
        margin-bottom: 80px;
    }
    .mb-260 {
        margin-bottom: 80px;
    }
    .mb-270 {
        margin-bottom: 80px;
    }
    .mb-280 {
        margin-bottom: 80px;
    }
    .mb-290 {
        margin-bottom: 80px;
    }
    .mb-300 {
        margin-bottom: 80px;
    }
    .m_header {
        width: calc(100% - 100px);
        padding: 20px 0;
    }
    .m_logo img:nth-child(1) {
        margin-right: 0;
        height: 25px;
    }
    .m_logo img:nth-child(2) {
        top: 5px;
        height: 12px;
        margin-left: 35px;
    }
    /************************/
    .cy_header {
        width: calc(100% - 100px);
        padding: 20px 0;
    }
    .logo img:nth-child(1) {
        margin-right: 0;
        height: 25px;
    }
    .logo img:nth-child(2) {
        top: 5px;
        height: 12px;
        margin-left: 35px;
    }
    .h_entry {
        position: fixed;
        top: auto;
        bottom: 0;
        right: 0;
        width: 100%;
    }
    .h_entry a {
        width: 100%;
        height: 50px;
        font-size: 22px;
    }
    /******/
    .top_main {
        position: relative;
    }
    .top_main, .flexslider, .flexslider li {
        height: 550px;
    }
    .top_title {
        padding-top: 160px;
    }
    .top_title h2 {
        font-size: 50px;
        line-height: 1.2em;
        letter-spacing: 0.05em;
    }
    .top_title i {
        margin: 5px 0 0 10px;
        display: inline-block;
    }
    .top_title i img {
        width: 40px;
        height: auto;
    }
    .top_title h3 {
        font-size: 20px;
        line-height: 1.6em;
        margin-top: 30px;
    }
    .scroll {
        display: none;
        left: 10px;
    }
    /******************/
    .sec01_padding {
        padding: 80px 0 30px;
    }
    .sec01_left {
        font-size: 35px;
    }
    .sec01_right {
        margin-top: 30px;
    }
    .sec01_text {
        font-size: 16px;
        line-height: 2.2em;
    }
    .more a {
        width: 170px;
        height: 60px;
        font-size: 16px;
    }
    .more a .shape {
        width: 60px;
        height: 60px;
        transition: 0s ease;
    }
    .more a .shape img {
        width: 13px;
        height: auto;
    }
    .more a:hover .shape {
        transform: translateY(-50%) scale(1);
    }
    .more.more_size80 {
        height: 60px;
    }
    .more.more_size80 .shape {
        width: 60px;
        height: 60px;
    }
    /******************/
    .sec02_eng {
        left: auto;
        right: 0;
        top: 25px;
        z-index: 1;
    }
    .eng_style {
        font-size: 70px;
        line-height: 1em;
    }
    .font54 {
        font-size: 54px !important;
    }
    .sec02_flex {
        padding-top: 0;
        display: block;
        width: 90%;
        margin: 0 auto;
    }
    .sec02_left {
        width: 100%;
        max-width: 100%;
        margin-top: 40px;
    }
    .sec02_left img {
        width: 100%;
        height: 300px;
    }
    .sec02_right {
        width: 100%;
        padding-top: 50px;
        margin-left: 0;
    }
    .sec02_width {
        width: 100%;
        max-width: 100%;
    }
    .title_60 {
        font-size: 32px;
        line-height: 1.3em;
        font-style: italic;
    }
    .ml_minus {
        margin-left: -1px;
    }
    /***********/
    .sec03_eng {
        right: 15px;
        top: 130px;
        z-index: 400;
        opacity: 0.2;
    }
    .sec03_flex {
        display: flex;
        align-items: center;
        justify-content: space-between;
        height: auto;
        padding: 80px 0;
        overflow: hidden;
    }
    .sec03_left {
        width: calc(100% - 310px);
        display: block;
        align-items: center;
        position: relative;
        z-index: 500;
    }
    .sec03_left > div {
        width: calc(100% + 310px);
    }
    .sec03_right {
        width: 260px;
        display: flex;
        justify-content: space-between;
        opacity: 0.4;
    }
    .sec03_right > div {
        width: 48%;
    }
    .sec03_right > div:nth-child(1) {
        margin-top: -270px;
    }
    /* ------------------------------
   loopSlider
------------------------------ */
    .loopSliderWrap {
        height: 156px;
    }
    .loopSlider {
        height: 156px;
    }
    .loopSlider ul {
        height: 156px;
    }
    .loopSlider ul li {
        height: 156px;
        width: 130px;
    }
    /* ------------------------------
   loopSlider
------------------------------ */
    .loopSliderWrap2 {
        height: 156px;
        padding-top: 150px;
    }
    .loopSlider2 {
        height: 156px;
    }
    .loopSlider2 ul {
        height: 156px;
    }
    .loopSlider2 ul li {
        height: 156px;
        width: 130px;
    }
    /***************************************/
    .sec04_flex {
        display: block;
    }
    .sec04_flex > div {
        width: 100%;
        max-width: 100%;
    }
    .sec04_flex > div:nth-child(2) {
        margin-top: 50px;
    }
    .sec04_flex > div .img100 img {
        max-height: 300px;
        min-height: 300px;
        transition: 0s ease;
    }
    .sec04_flex > div a:hover .img100 img {
        transform: scale(1);
    }
    .sec04_flex > div a:hover .shape {
        transform: translateY(-50%) scale(1);
    }
    .sec04_eng_left {
        position: absolute;
        top: -40px;
        left: -20px;
        z-index: 500;
    }
    .sec04_eng_right {
        position: absolute;
        top: -40px;
        right: -5px;
        z-index: 500;
    }
    .sec04_title {
        font-size: 24px;
        line-height: 1.3em;
        font-style: italic;
        margin: 30px 0 20px;
    }
    .banner_more {
        width: 180px;
        height: 60px;
        right: 20px;
        bottom: 20px;
        font-size: 18px;
    }
    .banner_more .shape {
        width: 60px;
        height: 60px;
        transition: 0s ease;
    }
    /****************************/
    .sec06_flex {
        display: block;
    }
    .sec06_right {
        width: 100%;
    }
    .sec06_width {
        max-width: 100%;
    }
    .sec06_left {
        width: 100%;
        margin-top: 40px;
    }
    .sec06_left img {
        width: 100%;
        height: 300px;
        max-width: 100%;
    }
    .sec06_eng {
        position: absolute;
        top: -27px;
        left: auto;
        right: 0;
        z-index: 1;
    }
    /***************/
    .sec07_bg {
        padding-bottom: 160px;
    }
    .sec07_eng {
        right: -5px;
        top: 50%;
        transform: translateY(-50%);
        writing-mode: vertical-rl;
        white-space: nowrap;
    }
    .title_80 {
        font-size: 36px;
        line-height: 1.3em;
        font-style: italic;
    }
    .center.minita-l {
        text-align: left;
    }
    /************/
    .under_banner {
        margin-top: 20px;
        display: block;
        top: -85px;
    }
    .under_banner > div {
        width: 100%;
        margin: 2px 0;
    }
    .under_banner > div a {
        padding: 20px 20px;
        color: #FFF;
        position: relative;
    }
    .banner_eng {
        font-size: 30px;
        line-height: 1.3em;
    }
    .banner_ja {
        font-size: 16px;
    }
    .banner_shape {
        right: 20px;
        width: 50px;
        height: 50px;
    }
    .banner_shape img {
        width: 12px;
        height: auto;
    }
    /**********/
    .cy_footer {
        padding: 230px 0 60px;
        margin-top: -280px;
    }
    .n_flex {
        display: none;
        justify-content: space-between;
        flex-wrap: wrap;
    }
    .n_flex > div {
        width: 50%;
    }
    .n_flex > div:nth-child(n+3) {
        margin-top: 20px;
    }
    .n_flex > div:nth-child(1) {
        order: 1;
    }
    .n_flex > div:nth-child(2) {
        order: 2;
    }
    .n_flex > div:nth-child(3) {
        order: 5;
    }
    .n_flex > div:nth-child(4) {
        order: 3;
    }
    .n_flex > div:nth-child(5) {
        order: 4;
    }
    .n_flex > div:nth-child(6) {
        order: 6;
    }
    .n_flex a {
        color: inherit;
    }
    .n_flex .f_mt {
        margin-top: 20px;
    }
    .sub_menu {
        font-size: 12px;
        margin-top: 10px;
    }
    .sub_menu p {
        margin: 10px 0;
    }
    /**/
    .f_bt {
        border-top: 0;
        margin-top: 0;
        padding: 50px 0;
    }
    .f_flex {
        display: block;
        text-align: center;
    }
    .f_logo {
        display: block;
    }
    .f_logo img:nth-child(1) {
        margin-right: 0;
        width: auto;
        height: 30px;
    }
    .f_logo img:nth-child(2) {
        width: auto;
        height: 15px;
        display: block;
        margin: 10px auto 0;
    }
    .t17 {
        font-size: 16px;
    }
    .t15 {
        font-size: 14px;
    }
    .f_map {
        font-size: 12px;
        margin-left: 0;
        margin: 5px 0 10px;
    }
    .f_map a {
        color: #44494d;
        margin-left: 8px;
        border-bottom: 1px solid #44494d;
        padding-bottom: 2px;
    }
    .fff {
        display: flex;
        text-align: center;
        margin-top: 20px;
    }
    .fff > p {
        padding: 0 10px;
        line-height: 1em;
        letter-spacing: 0;
    }
    .fff > p:last-child {
        padding-right: 0;
    }
    .fff a {
        color: inherit;
        font-size: 14px;
    }
    .fff > p:nth-child(1) img {
        margin: 0 0 3px 5px;
    }
    .copy {
        margin-top: 25px;
        font-size: 10px;
    }
    /*******************************************************

    トップメッセージ

*******************************************************/
    .main_size {
        height: 300px;
        display: flex;
        justify-content: center;
        align-items: center;
        color: #FFF;
        padding-top: 100px;
    }
    .main_size h2 {
        font-size: 26px;
        line-height: 1.3em;
        letter-spacing: 0.08em;
    }
    .main_size p {
        font-size: 20px;
        margin-top: 0px;
    }
    /************/
    .eng_style230 {
        font-size: 70px;
        line-height: 0.8em;
    }
    .g_eng1 {
        right: 13px;
        top: 95px;
    }
    .title_55 {
        font-size: 28px;
    }
    .eng_35 {
        font-size: 20px;
    }
    .gree_img img {
        width: 100%;
        height: 350px;
        object-position: 30%;
    }
    .name {
        background-color: #e8ebed;
        padding: 20px 20px 10px;
        position: absolute;
        right: 0;
        bottom: 0;
    }
    .name img {
        width: 220px;
        height: auto;
    }
    /***************/
    .message_bg {
        background: url("../images/message4.jpg") 50% 0/1059px 320px no-repeat;
    }
    .message_bg_w {
        padding: 40px 20px;
    }
    .text_18 {
        font-size: 15px;
    }
    .message_flex {
        display: block;
    }
    .message_left {
        width: 100%;
    }
    .message_left h3 {
        font-size: 22px;
        line-height: 1.4em;
    }
    .message_left h3 img {
        width: 80px;
        height: auto;
        margin-bottom: 15px;
    }
    .message_right {
        width: 100%;
        max-width: 100%;
        margin-top: 40px;
    }
    .message_right img {
        width: 100%;
        min-height: 300px;
        height: 100%;
        object-fit: cover;
    }
    /**********/
    .g_eng2 {
        left: -5px;
        bottom: 20px;
    }
    .message_bg_w2 {
        padding: 60px 20px;
    }
    .m_text {
        text-align: left;
        word-break: break-all;
    }
    .message_box_left {
        width: 100%;
        margin: 30px auto 0;
        order: 2;
        min-width: auto;
        max-width: 420px;
    }
    /*******************************************************

    事業内容

*******************************************************/
    .b_bb {
        padding-bottom: 80px;
    }
    .b_eng2 {
        /*right: 0;*/
        right: 20px;
        top: 15px;
    }
    .business_list {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
    }
    .business_list > div {
        width: 49.3%;
        margin: 0.8% 0;
    }
    .business_list > div:nth-child(3) {
        width: 100%;
    }
    .business_list > div:nth-child(3) img {
        min-height: 150px;
    }
    .business_list > div img {
        min-height: 150px;
    }
    .title_35 {
        font-size: 20px;
    }
    .af_bb:after {
        width: 30px;
        margin: 20px 0 0;
    }
    .business_text_list {
        grid-template-columns: repeat(1, 1fr);
        column-gap: 0;
        row-gap: 5px;
    }
    .business_text_list > p {
        font-size: 15px;
        padding: 15px;
        line-height: 1.5em;
    }
    .indent_p {
        text-indent: -1.1em;
        padding-left: 1.1em;
    }
    /***********/
    .business_border {
        border: 2px solid #000;
        padding: 30px 20px;
    }
    .title_40 {
        font-size: 22px;
        font-weight: bold;
        line-height: 1.5em;
    }
    .more.more_c a {
        margin: 0 auto;
    }
    .business_img1 img {
        min-height: 200px;
    }
    /*************/
    .business_list2 {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        column-gap: 0;
        row-gap: 30px;
    }
    .business_list2 h3 {
        font-size: 20px;
        font-weight: bold;
        display: flex;
        align-items: center;
        margin: 20px 0 10px;
        line-height: 1.5em;
    }
    .business_list2 h3:before {
        margin-right: 10px;
        width: 20px;
    }
    .business_list2 img {
        min-height: 200px;
    }
    /*******************************************************

    SDGs

*******************************************************/
    .sdgs_img img {
        max-height: 630px;
        min-height: 200px;
        object-fit: cover;
    }
    .sdgs_flex > div {
        display: block;
        padding-bottom: 40px;
    }
    .sdgs_flex > div:nth-child(n+2) {
        padding-top: 40px;
    }
    .sdgs_left {
        width: 100%;
    }
    .sdgs_left h3 {
        position: relative;
        display: flex;
        align-items: center;
    }
    .sdgs_left h3 img {
        margin-right: 20px;
        width: 60px;
        height: auto;
    }
    .sdgs_bg_w {
        background-color: #FFF;
        padding: 30px 20px;
    }
    .sdgs_bg_w .title_25 {
        padding-left: 2px;
    }
    .title_25 {
        font-size: 20px;
        font-weight: bold;
        line-height: 1.6em;
    }
    .sdgs_list p {
        margin: 7px 0;
        text-indent: -1.1em;
        padding-left: 1.1em;
    }
    .sdgs_right {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        column-gap: 10px;
        row-gap: 10px;
        margin-top: 30px;
    }
    /*****************/
    .sdgs_flex2 > div {
        display: block;
    }
    .sdgs_flex2 > div:nth-child(n+2) {
        padding-top: 40px;
    }
    .sdgs_left2 {
        width: 100%;
    }
    .sdgs_left2 img {
        width: 100%;
        height: 100%;
        max-height: 350px;
        min-height: 250px;
        object-fit: cover;
    }
    .sdgs_right2 {
        width: 100%;
        padding-top: 20px;
    }
    .sdgs_right2 h3:after {
        width: 30px;
        margin: 20px 0 0;
    }
    /*******************************************************

    会社概要

*******************************************************/
    .com_table > div {
        display: flex;
        justify-content: space-between;
    }
    .com_table > div:nth-child(1) {
        border-top: 1px solid #707070;
    }
    .com_cell1 {
        width: 120px;
        padding: 20px 10px;
        font-size: 15px;
    }
    .com_cell2 {
        width: calc(100% - 120px);
        padding: 21px 15px;
    }
    .circle_list > p {
        margin: 10px 0;
        padding-left: 20px;
    }
    .circle_list > p:nth-child(1) {
        margin-top: 3px;
    }
    .circle_list > p:before {
        top: 9px;
    }
    .p_list_mt5 p:nth-child(n+2) {
        margin-top: 5px;
    }
    /***************/
    .tab ul {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 0;
        row-gap: 0;
        border: 1px solid #000;
    }
    .tab ul a {
        display: block;
        padding: 10px 5px;
        font-size: 14px;
    }
    .tab ul li:nth-child(n+3) a {
        border-top: 1px solid #000;
    }
    .tab ul li:nth-child(2n) a {
        border-right: 0;
    }
    .tab ul .active {
        background-color: #000;
        color: #FFF;
    }
    .title_42 {
        font-size: 24px;
        font-style: italic;
        font-weight: bold;
        line-height: 1.3em;
    }
    .history {
        padding-left: 60px;
        position: relative;
    }
    .history > div {
        display: block;
        justify-content: space-between;
        position: relative;
    }
    .history > div:before {
        content: "";
        background-color: #0b3b67;
        width: 14px;
        height: 14px;
        border-radius: 50%;
        position: absolute;
        left: -60px;
        top: 12px;
        transform: translateY(0);
        z-index: 500;
    }
    .history > div:nth-child(n+2) {
        margin-top: 20px;
    }
    .history > div:last-child:after {
        content: "";
        border-left: 3px solid #e8ebed;
        position: absolute;
        left: -55px;
        bottom: 0;
        height: calc(100% - 20px);
        z-index: 1;
    }
    .history p {
        line-height: 1.8em;
    }
    .history:after {
        content: "";
        border-left: 1px solid #0b3b67;
        width: 1px;
        height: calc(100% - 20px);
        position: absolute;
        left: 6.2px;
        top: 20px;
        transform: translateY(0);
    }
    .his_cell1 {
        width: 100%;
        font-size: 16px;
        padding: 3px 0 5px 15px;
    }
    .his_cell1:before {
        content: "";
        background: url("../images/company2.png") left 0/100% 100% no-repeat;
        width: 25px;
        height: 100%;
        position: absolute;
        left: -25px;
        top: 0;
    }
    .his_cell2 {
        width: 100%;
        background-color: #FFF;
        padding: 8px 15px;
        font-size: 14px;
    }
    /*******************************************************

    インタビュー

*******************************************************/
    .inter_eng {
        top: 20px;
        left: 0;
    }
    .interview_grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 10px;
        row-gap: 20px;
    }
    .interview_grid > div {
        cursor: pointer;
    }
    .interview_grid p {
        line-height: 1.8em;
    }
    .type {
        font-size: 14px;
        padding: 0 15px;
    }
    .inter_name {
        margin: 15px 0 5px;
        font-size: 20px;
        line-height: 1.5em;
    }
    /**ポップアップ*********/
    .popup {
        display: none;
        position: fixed;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 100%;
        height: 100%;
        z-index: 9999999;
    }
    .pop_close {
        position: fixed;
        top: 10px;
        right: 10px;
        cursor: pointer;
        z-index: 999;
    }
    .pop_close img {
        width: 30px;
        height: auto;
    }
    .bg_pop {
        background-color: rgba(0, 0, 0, 0.3);
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }
    .pop_contents {
        padding: 20px;
        width: 85%;
        height: 92%;
        position: fixed;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        overflow-y: scroll;
    }
    .pop_flex {
        display: block;
    }
    .pop_left {
        width: 100%;
        max-width: 100%;
    }
    .pop_name_box {
        margin: -35px auto 0;
        width: 94%;
    }
    .pop_name_box p:not(.pop_name) {
        font-size: 13px;
        line-height: 1.8em;
    }
    .type {
        padding: 0 10px 2px;
    }
    .pop_name {
        font-size: 18px;
        margin-bottom: 5px;
        line-height: 1.5em;
    }
    .pop_right {
        width: 100%;
        padding-top: 30px;
    }
    .pop_right h3 {
        color: #0b3b67;
        font-size: 20px;
        margin-bottom: 15px;
    }
    .pop_right h3:nth-child(n+2) {
        margin-top: 40px;
    }
    .pop_right p {
        line-height: 1.8em;
    }
    /*******************************************************

    数字で見るハラダ工業

*******************************************************/
    .data_main {
        background: url("../images/data1.jpg") 50% 0/cover no-repeat;
    }
    /***************/
    .data_grid {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        column-gap: 0;
        row-gap: 20px;
    }
    .data_grid > div {
        background-color: #FFF;
        padding: 30px 10px;
    }
    .data_grid > div h3 {
        font-size: 17px;
        width: 80%;
        margin: 0 auto;
        padding: 5px;
    }
    .data_grid .icon {
        height: 170px;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .data_grid .icon img {
        transform: scale(0.6);
        display: block;
    }
    .num_flex {
        width: 100%;
        display: inline-block;
    }
    .num_flex > p {
        font-size: 20px;
        width: 100%;
    }
    .num_flex > p .big100 {
        font-size: 45px;
    }
    .num_flex > p .big120 {
        color: #0b3b67;
        font-size: 60px;
    }
    .num_flex > p .big90 {
        color: #0b3b67;
        font-size: 42px;
    }
    .ver {
        writing-mode: vertical-rl;
        font-size: 16px;
        font-family: "NotoSansCJKjp-Regular_ver";
        position: relative;
        top: 3px;
    }
    .t20_center {
        font-size: 20px;
        text-align: center;
    }
    /****/
    .data_graph {
        margin-top: 35px;
        background-color: #FFF;
        padding: 30px 10px;
        text-align: center;
    }
    .data_graph h3 {
        background-color: #0b3b67;
        color: #FFF;
        text-align: center;
        font-size: 17px;
        max-width: 800px;
        width: 80%;
    }
    /*******************************************************

    エントリー

*******************************************************/
    .flow_list > div:not(.flow_shape) {
        display: block;
        justify-content: space-between;
    }
    .flow_cell1 {
        width: 100%;
        padding-left: 0;
        text-align: center;
        display: block;
        padding: 15px 0 13px;
    }
    .flow_cell1 img {
        height: 30px;
        width: auto;
    }
    .flow_cell2 {
        width: 100%;
        padding: 20px 20px;
    }
    .flow_shape {
        margin: 20px 0;
    }
    /****************/
    .entry_table > div {
        display: block;
    }
    .entry_table > div:nth-child(n+2) {
        margin-top: 20px;
    }
    .e_cell1 {
        width: 100%;
        font-size: 16px;
        padding-top: 0;
    }
    .hissu {
        width: 40px;
        font-size: 14px;
        margin-right: 15px;
    }
    .nini {
        width: 40px;
        font-size: 14px;
        margin-right: 15px;
    }
    .e_cell2 {
        width: 100%;
        margin-top: 10px;
    }
    .size input, .area textarea {
        width: 100%;
        background-color: #FFF;
        border: 1px solid #aaaaaa;
        padding: 10px 20px;
    }
    .size input {
        height: 40px;
    }
    .area textarea {
        height: 200px;
    }
    .postal_flex {
        display: flex;
        align-items: center;
        max-width: 200px;
        width: 100%;
    }
    .postal_cell1 {
        margin-right: 10px;
        font-size: 18px;
    }
    .postal_cell2 {
        flex-grow: 2;
    }
    .label_flex {
        font-size: 16px;
        padding-top: 10px;
        padding-bottom: 0;
    }
    .label_flex > span {
        display: block;
    }
    .label_flex .wpcf7-list-item {
        margin-right: 30px;
    }
    .label_flex label {
        display: block;
        cursor: pointer;
    }
    .sub input {
        font-size: 20px;
        padding: 20px 0;
    }
    /*******************************************************

    福利厚生

*******************************************************/
    .wel_grid {
        grid-template-columns: repeat(2, 1fr);
        column-gap: 10px;
        row-gap: 10px;
    }
    .wel_grid > div {
        padding: 20px 10px;
    }
    .wel_grid h3 {
        font-size: 16px;
        margin-top: 18px;
    }
    .wel_grid h3:not(.min_none) {
        min-height: 50px;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
    }
    .wel_grid p {
        margin-top: 10px;
    }
    .wel_grid img {
        width: 90px;
        height: auto;
    }
    /********/
    .be_bb {
        display: flex;
        align-items: center;
    }
    .be_bb:before {
        content: "";
        border-bottom: 2px solid #0b3b67;
        width: 30px;
        margin-right: 20px;
    }
    .wel_flex > div {
        width: 49%;
    }
    .wel_flex img {
        min-height: 180px;
    }
    /*******************************************************

    募集要項

*******************************************************/
    .recruit_main {
        background: url("../images/recruit1.jpg") 40% 0/cover no-repeat;
    }
    /***************/
    .rec_table > div {
        display: flex;
        justify-content: space-between;
        margin-top: 2px;
    }
    .rec_cell1 {
        width: 100px;
        padding: 10px 15px;
        font-size: 14px;
    }
    .rec_cell2 {
        width: calc(100% - 100px);
        padding: 10px 15px;
    }
    .entry_button a {
        font-size: 20px;
        padding: 20px 0;
    }
    /*******************************************************

    プライバシーポリシー

*******************************************************/
    .title_45 {
        font-size: 20px;
        line-height: 1.5em;
    }
    .num_p p {
        text-indent: -1em;
        padding-left: 1em;
    }
    .pri_pl {
        padding-left: 1.1em;
    }

/********************/

.rec_grid {
    grid-template-columns: repeat(1, 1fr);
    column-gap: 0;
    row-gap: 20px;
}
.rec_grid a{
    font-size: 13px;
    padding: 15px;
}
.rec_grid .img100 img{
    height: 220px;
}
.rec_pl {
    padding-left: 15px;
}


}
/* スマートフォン 縦(ポートレート) */