@charset "utf-8";

/******************/
/* import css
/******************/
@import url("top.css");
@import url("sillicagel.css");
@import url("product.css");
@import url("company.css");
@import url("notice.css");
@import url("recruit.css");
@import url("contact.css");

/*pc版(画面幅 1121px~)
------------------------------------*/
@media screen and (min-width:1120px){
    header{
        width:100%;
        height: 100px;
        background-color: #FFF;
        z-index: 100;
    }
    header .header_contents{
        width:90vw;
        min-width:1120px;
        height:100px;
        margin: 0 auto;
        display: flex;
        justify-content: space-between;
    }

    header .header_contents .header_logo{
        width:242px;
        height: 100px;
        left: 0;
    }

    header .header_contents .header_logo .header_logo_img{
    	width:240px;
        height: auto;
    }

    header .header_contents .header_logo a{
        width:242px;
        height: 100px;
        display: flex;
        align-items:center;
        justify-content: space-between;
    }

    header .header_contents .header_menu{
    	display: flex;
        height: 100px;
        justify-content:center;
    }

    header .header_contents .header_menu li{
        display: block;
        position: relative;
    }

    header .header_contents .header_menu li a.gnav_link,
    header .header_contents .header_menu li span.gnav_link{
        display: block;
        position: relative;
    	color:#333;
        height: 100px;
        line-height: 100px;
        text-decoration: none;
        padding-right:20px;
        padding-left:20px;
        text-align: center;
        font-size: 16px;
    }
    header .header_contents .header_menu li a.gnav_link::after,
    header .header_contents .header_menu li span.gnav_link::after{
        position: absolute;
        bottom: 0px;
        left:0px;
        content:"";
        width:0%;
        height: 1px;
        border-bottom:solid 3px #0547f4;
        transition: all 0.3s;
    }
    header .header_contents .header_menu li:hover a.gnav_link::after,
    header .header_contents .header_menu li:hover span.gnav_link::after{
        width:100%;
    }
    header .header_contents .header_menu li ul{
        display: none;
        position: absolute;
        top:100%;
        left: 0px;
        width:240px;
        background-color: #FFF;
        z-index:10;
        opacity: 0;
        transition: all 0.3s;
    }
    header .header_contents .header_menu li:hover ul{
        display: block;
        top:100%;
        opacity: 1;
    }
    header .header_contents .header_menu li ul li{
        display: block;
    }
    header .header_contents .header_menu li ul li a{
        display: block;
        color:black;
        position: relative;
        width:100%;
        padding:16px 8px;
    }
    header .header_contents .header_menu li ul li a i{
        color:blue;
        margin-right:8px;
    }
    header .header_contents .header_menu li ul li:hover a{
        background-color: #EFEFEF;
    }

    header .global_menu{
        display: none;
    }

    header #menu.popup .nav_items_box{
        display: none;
    }

    footer{
        width:100%;
        background-color: #EFEFEF;
        color:#333;
    }
    footer .footer_box{
        width:1120px;
        margin: 0 auto;
    }

    footer .footer_box .footer_contents{
        padding:40px 0px;
    }

    footer .footer_box .footer_contents .footer_address_box{
        width:372px;
    }
    footer .footer_box .footer_contents .footer_address_box .footer_name{
        border-bottom: 1px solid #666;
        font-size: 20px;
        padding-bottom:10px;

    }
    footer .footer_box .footer_contents .footer_address_box .footer_address{
        margin-top: 30px;
        font-size: 16px;
        line-height: 26px;
    }

    footer .footer_box .footer_contents .footer_menu_box{
        display: flex;
        flex-direction: column;
        width:350px;
        margin-left: 114px;
    }
    footer .footer_box .footer_contents .footer_menu_box a{
        color: #666666;
        text-decoration: none;
        transition: all 0.3s;
    }
    footer .footer_box .footer_contents .footer_menu_box a:hover{
        color:#0547f4;
        border-bottom: 1px solid #0547f4;
    }
    footer .footer_box .footer_contents .footer_menu_box li{
        color: #666666;
        margin:8px 0;
    }
    footer .footer_box .footer_contents .footer_menu_box li i{
        margin-right:8px;
    }
    footer .footer_box .footer_contents .footer_menu_box .footer_nav_link{
        color: #666666;
        font-size: 16px;
    }
    footer .footer_box .footer_contents .footer_menu_box li ul{
        display: block;
    }
    footer .footer_box .footer_contents .footer_menu_box li ul li{
        display: block;
        padding-left:12px;
    }
    footer .footer_box .footer_contents .footer_menu_box li ul li i{
        font-size:8px;
    }

    footer .footer_box .footer_contents .footer_logo_box{
        margin: 40px auto 20px auto;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_logo_img{
        text-align: center;
        object-fit: contain;
        width:100%;
        height: 60px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_iso_box{
        display: flex;
        justify-content: space-around;
        margin:20px auto;
        width:200px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_iso_box .footer_iso_img{
        width:45%;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_sbt_box{
        display: flex;
        justify-content: space-around;
        margin:20px auto;
        width:200px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_sbt_box .footer_sbt_img{
        width:100%;
    }

    /* copyrights */
    .copyrights{
        color:#FFF;
        text-align: center;
        padding:20px 0px;
        background-color:#0547f4;
    }

    /* scroll */
    .jump_button_box {
        position:fixed;
        right:8px;
        bottom:84px;
        color:white;
        font-size:24px;
        line-height: 64px;
        text-align: center;
        height:64px;
        width:64px;
        background-color: rgba(0,0,0,0.8);
        border-radius: 4px;
        cursor: pointer;
        z-index: 100;
    }

    /* Page Main Visual */
    .page_title_image{
        position: relative;
        width: 100%;
        height:640px;
    }
    .page_title_image img{
        position: relative;
        bottom:240px;
        width: 100%;
    }

    .page_title{
        display: inline-block;
        color: white;
        font-size: 40px; 
        line-height: 80px;
        padding-right: 72px;
        padding-left:max(calc(50vw - 450px),30px);
        height:80px;
        margin-top: 392px;
        background-color:#0547f4;
    }
    .page_title_image.subtitle{
        height:348px;
        background-image: url('../img/common/main_img.png');
        background-size:cover;
        background-position: center center;
        background-repeat: no-repeat;
    }
    .page_title_image .page_subtitle{
        position: absolute;
        bottom:60px;
        color: white;
        font-size: 40px; 
        line-height: 80px;
        height:80px;
        padding-right: 72px;
        padding-left: max(calc(40vw - 456px),30px);
        background-color:#0547f4;
    }
}

/*タブレット版(画面幅 600px~1120px)
------------------------------------*/
@media screen and (max-width:1119px) and (min-width : 600px){
    header{
        height: 80px;
        background-color: #FFF;
        box-shadow: 0 2px 6px rgba(0,0,0,0.2);
        position: relative;
        z-index: 100;
    }

    header .header_contents{
        width:100%;
        height:80px;
        position: relative;
    }

    header .header_contents .header_logo{
        width:242px;
        height: 100px;
        position: absolute;
        left: 20px;
    }

    header .header_contents .header_logo .header_logo_img{
        width:240px;
        height: auto;
    }

    header .header_contents .header_logo a{
        width:242px;
        height: 80px;
        display: flex;
        align-items:center;
        justify-content: space-between;
    }

    header .header_contents .header_menu{
        display: none;
    }

    /*ハンバーガーメニュー*/
    /*ハンバーガー部*/
    header .global_menu{
        position: absolute;
        right:10px;
        top:10px;
        background:none;
        border: none;
        height:60px;
        width:50px;
        z-index: 1000;
    }

    header .global_menu span {
        width: 100%;
        height: 4px;
        background-color: #333;
        border-radius: 4px;
        position: relative;
        transition: ease .4s; /*ハンバーガーメニュークリック時の三本線の動きを遅延*/
        display: block;
    }
    header .global_menu.bgcolor_wh span{
        background-color:white;
    }
    header .global_menu span:nth-child(1) {
        top: 0;
    }
    header .global_menu span:nth-child(2) {
        margin: 8px 0;
    }
    header .global_menu span:nth-child(3) {
        top: 0;
    }
    header .global_menu.active{
        position: fixed;
    }
    header .global_menu.active span:nth-child(1) {
        top: 12px;
        transform: rotate(45deg);
    }
    header .global_menu.active span:nth-child(2) {
        opacity: 0;
    }
    header .global_menu.active span:nth-child(3) {
        top: -12px;
        transform: rotate(-45deg);
    }

    /* メニュー部　*/
    header #menu .header_menu_box{
        position: fixed;
        top:0;
        right:-100vw;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-flow: column;
        width:100vw;
        height:100vh;
        background-color: rgba(0,0,0,0.8);
        z-index: 100;
        border-radius:0px 0px 0px 10vh;
        transition: all 0.2s ease-in-out;
    }
    header #menu.open .header_menu_box{
        top:0px;
        right:0px;
    }
    /*
    header #menu.popup .nav_items_box{
        display: flex;
        position: fixed;
        justify-content: center;
        align-items: center;
        z-index: 100;
        width:100vw;
        height:100vh;
        background-color: rgba(0,0,0,0.9);
        text-align: center;
    }*/

     header #menu.popup .header_menu_box > ul{
        display: block;
        margin:0px auto;
        width:60%;
        text-align: center;
        margin-bottom: 30px;
    }

    header #menu.popup .header_menu_box > ul > li{
        display: block;
        width:100%;
        list-style:none;
        padding:0px 20px;
        margin-bottom: 12px;
    }
    header #menu.popup .gnav_link{
        color: white;
        font-size: 24px;
        line-height: 60px;
        text-align: left;
        margin-bottom:12px;
        border-bottom:solid 1px #FFF;
    }
    header #menu.popup li > ul{
        display: block;
        width: 100%;
    }
    header #menu.popup li > ul > li{
        text-align: left;
    }

    header  #menu.popup a{
        display: block;
        color: white;
        font-size: 20px;
        padding:8px 0px;
    }

    header #menu.popup a:hover{
        color: #ADE0EE;
    }

    header #menu.popup .global_close_button{
        margin-top: 32px;
        width:120px;
        height:40px;
        border-radius: 2px;
        background: none;
        color:white;
        border: 1px solid white;
        font-size: 18px;
        font-family: inherit;
        transition: 0.4s;
    }


     /*  TOPボタン　*/
    header #jump-top {
        position:fixed;
        right: 10px;
        bottom:10px;
        z-index: 10;
        height:70px;
        width:70px;
        background-color: rgba(0,0,0,0.9);
        padding: 10px;
        border-radius: 4px;
        text-align: center;
    }

    header #jump-top a{
        color: white;
        font-size: 12px;
        text-align: center;
    }

    footer{
        width:100%;
        background-color: #EFEFEF;
        color:#333;
        paddding-bottom:20px;
        min-width:360px;
    }

    footer .footer_box{
        width:100%;
    }
    footer .footer_box .footer_contents{
        display:flex;
        flex-wrap: wrap;
        padding-top:30px;

    }

    footer .footer_box .footer_contents .footer_address_box{
        padding-left:30px;
        width:60%;
    }

    footer .footer_box .footer_contents .footer_address_box .footer_name{
        width:250px;
        border-bottom: 1px solid #666;
        padding-bottom:10px;
        font-size: 20px;
    }
    footer .footer_box .footer_contents .footer_address_box .footer_address{
        margin-top: 10px;
        font-size: 14px;
        line-height: 26px;
    }

    footer .footer_box .footer_contents .footer_menu_box{
        display:flex;
        flex-direction: column;
        width:100%;
        margin-top: 10px;
        padding-left:30px;
    }
    footer .footer_box .footer_contents .footer_menu_box .footer_nav_link{
        font-size:14px;
    }
    footer .footer_box .footer_contents .footer_menu_box .footer_nav_link i{
        margin-right:8px;
    }
    footer .footer_box .footer_contents .footer_menu_box ul{
        margin:6px 0;
    }
    footer .footer_box .footer_contents .footer_menu_box li{
        color: #666666;
        margin:6px 0;
    }
    footer .footer_box .footer_contents .footer_menu_box a{
        color: #666666;
        text-decoration: none;
    }
    footer .footer_box .footer_contents .footer_menu_box a i{
        margin-right:8px;
    }

    footer .footer_box .footer_contents .footer_menu_box a:hover{
        color:#0547f4;
        border-bottom: 1px solid #0547f4;
    }

    footer .footer_box .footer_contents .footer_logo_box{
        width: 100%;
        margin: 40px auto 20px auto;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_logo_img{
        text-align: center;
        object-fit: contain;
        width:100%;
        height: 80px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_iso_box{
        display: flex;
        justify-content: space-around;
        margin:20px auto;
        width:200px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_iso_box .footer_iso_img{
        width:40%;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_sbt_box{
        display: flex;
        justify-content: space-around;
        margin:20px auto;
        width:200px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_sbt_box .footer_sbt_img{
        width:100%;
    }

    footer .footer_box .footer_contents .footer_logo_box .pda8{
        margin:0 auto;
        text-align: center;
    }

    footer .footer_box .copyright{
        text-align: center;
        margin-top: 70px;
    }

    /* copyrights */
    .copyrights{
        color:#FFF;
        text-align: center;
        padding:10px 0px;
        background-color:#0547f4;
    }

    /* scroll */
    .jump_button_box {
        position:fixed;
        right:12px;
        bottom:42px;
        color:white;
        font-size:18px;
        line-height: 42px;
        text-align: center;
        height:42px;
        width:42px;
        background-color: rgba(0,0,0,0.8);
        border-radius: 4px;
        cursor: pointer;
        z-index: 100;
    }

    /* Page Main Visual */
    .page_title_image{
        position: relative;
        width: 100%;
        height:400px;
    }
    .page_title_image img{
        position: relative;
        bottom:100px;
        width: 100%;
    }

    .page_title{
        height:60px;
        padding-right: 70px;
        padding-left:max(calc(50vw - 300px),30px);
        line-height: 60px;
        display: inline-block;
        margin-top: 280px;
        background-color:#0547f4;
        color: white;
        font-size: 34px; 
    }
    .page_title_image.subtitle{
        height:320px;
        background-image: url('../img/common/main_img.png');
        background-size:cover;
        background-position: center center;
        background-repeat: no-repeat;
    }
    .page_title_image .page_subtitle{
        position: absolute;
        bottom:60px;
        color: white;
        font-size: 32px; 
        line-height: 60px;
        height:60px;
        padding-right: 40px;
        padding-left:max(calc(50vw - 450px),40px);
        background-color:#0547f4;
    }
}

/*スマホ版(画面幅 ~599px)
------------------------------------*/
@media screen and (max-width :599px){
    header{
        width:100%;
        min-width:360px;
        height: 60px;
        background-color: #FFF;
        box-shadow: 0 2px 6px rgba(0,0,0,0.2);
        position: relative;
    }

    header .header_contents{
        width:100%;
        height:60px;
        position: relative;
    }

    header .header_contents .header_logo{
        margin:0 auto;
        width:242px;
        height: 100px;
        position: absolute;
        left: 4px;
    }

    header .header_contents .header_logo .header_logo_img{
        width:200px;
        height: auto;
    }

    header .header_contents .header_logo a{
        width:232px;
        height: 60px;
        display: flex;
        align-items:center;
        justify-content: space-between;
    }

    header .header_contents .header_menu{
        display: none;
    }

    /*ハンバーガーメニュー*/
    header .global_menu{
        position: absolute;
        right:10px;
        background:none;
        border: none;
        height:60px;
        width:50px;
        z-index: 1000;
    }

    header .global_menu span{
        width: 100%;
        height: 4px;
        background-color: #333;
        border-radius: 4px;
        position: relative;
        transition: ease .4s;
        display: block;
    }
    header .global_menu.bgcolor_wh span{
        background-color:white;
    }
    header .global_menu span:nth-child(1) {
        top: 0;
    }
    header .global_menu span:nth-child(2) {
        margin: 8px 0;
    }
    header .global_menu span:nth-child(3) {
        top: 0;
    }
    header .global_menu.active{
        position: fixed;
    }
    header .global_menu.active span:nth-child(1) {
        top: 12px;
        transform: rotate(45deg);
    }
    header .global_menu.active span:nth-child(2) {
        opacity: 0;
    }
    header .global_menu.active span:nth-child(3) {
        top: -12px;
        transform: rotate(-45deg);
    }


    /* メニュー部　*/
    header #menu.popup .header_menu_box{
        position: fixed;
        top:0;
        right:-100vw;
        padding-top: 24px;
        width:100vw;
        height:100vh;
        background-color: rgba(0,0,0,0.8);
        z-index: 100;
        border-radius:0px 0px 0px 10vh;
        transition: all 0.2s ease-in-out;
        overflow: scroll;
    }
    header #menu.open .header_menu_box{
        top:0px;
        right:0px;
    }

    header #menu.popup ul{
        display: block;
        width:100%;
        text-align: center;
    }
    header #menu.popup li{
        display: block;
        width:100%;
        list-style:none;
        padding:0px 20px;
        margin-bottom: 8px;
    }
    header #menu.popup .gnav_link{
        color: white;
        font-size: 16px;
        line-height: 24px;
        text-align: left;
        margin-bottom:12px;
        border-bottom:solid 1px #FFF;
    }
    header #menu.popup li > ul > li{
        text-align: left;
    }

    header  #menu.popup a{
        display: block;
        color: white;
        font-size: 14px;
        padding:8px 0px;
    }

    header #menu.popup .global_close_button{
        margin-top: 20px;
        width:120px;
        height:40px;
        border-radius: 2px;
        background: none;
        color:white;
        border: 1px solid white;
        font-size: 18px;
        font-family: inherit;
        transition: 0.4s;
    }

    /*  TOPボタン　*/

    header #jump-top {
        position:fixed;
        right: 10px;
        bottom:10px;
        z-index: 10;
        height:70px;
        width:70px;
        background-color: rgba(0,0,0,0.9);
        padding: 10px;
        border-radius: 4px;
        text-align: center;
    }

     header #jump-top a{
        color: white;
        font-size: 12px;
        text-align: center;
    }

    footer{
        width:100%;
        background-color: #EFEFEF;
        color:#333;
        min-width:360px;
    }

    footer iframe{
        width:100%;
        height:350px; 
        border:none; 
    }
    footer .footer_box{
        width:100%;
    }
    footer .footer_box .footer_contents{
        display:flex;
        flex-direction: column;
        padding:30px 0px;
    }

    footer .footer_box .footer_contents .footer_address_box{
        padding-left:30px;
        width:100%;
    }

    footer .footer_box .footer_contents .footer_address_box .footer_name{
        width:250px;
        border-bottom: 1px solid #666;
        padding-bottom:10px;
        font-size: 20px;
    }
    footer .footer_box .footer_contents .footer_address_box .footer_address{
        margin-top: 10px;
        font-size: 14px;
        line-height: 26px;
    }


    footer .footer_box .footer_contents .footer_menu_box{
        display:flex;
        flex-direction: column;
        width:100%;
        margin-top: 20px;
        padding-left:30px;
    }
    footer .footer_box .footer_contents .footer_menu_box .footer_nav_link{
        font-size:14px;
    }
    footer .footer_box .footer_contents .footer_menu_box .footer_nav_link i{
        margin-right:8px;
    }
    footer .footer_box .footer_contents .footer_menu_box ul{
        margin:6px 0;
    }
    footer .footer_box .footer_contents .footer_menu_box li{
        margin:6px 0;
        color: #666666;
    }
    footer .footer_box .footer_contents .footer_menu_box a{
        color: #666666;
        text-decoration: none;
    }
    footer .footer_box .footer_contents .footer_menu_box a i{
        margin-right:8px;
    }

    footer .footer_box .footer_contents .footer_menu_box a:hover{
        color:#0547f4;
        border-bottom: 1px solid #0547f4;
    }

    footer .footer_box .footer_contents .footer_logo_box{
        margin: 40px auto 20px auto;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_logo_img{
        text-align: center;
        object-fit: contain;
        width:100%;
        height: 50px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_iso_box{
        display: flex;
        justify-content: space-around;
        margin:20px auto;
        width:200px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_iso_box .footer_iso_img{
        width:40%;
    }
    footer .footer_box .footer_contents .footer_logo_box .pda8{
        margin:0 auto;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_sbt_box{
        display: flex;
        justify-content: space-around;
        margin:20px auto;
        width:200px;
    }
    footer .footer_box .footer_contents .footer_logo_box .footer_sbt_box .footer_sbt_img{
        width:100%;
    }
    
    footer .footer_box .copyright{
        text-align: center;
        margin-top: 70px;
    }

    /* copyrights */
    .copyrights{
        color:#FFF;
        text-align: center;
        padding:10px 0px;
        background-color:#0547f4;
    }

    /* scroll */
    .jump_button_box {
        position:fixed;
        right:12px;
        bottom:42px;
        color:white;
        font-size:18px;
        line-height: 42px;
        text-align: center;
        height:42px;
        width:42px;
        background-color: rgba(0,0,0,0.8);
        border-radius: 4px;
        cursor: pointer;
        z-index: 100;
    }

    /* Page Main Visual */
    .page_title_image{
        position: relative;
        width: 100%;
        min-width:360px;
        height:240px;
        overflow: hidden;
    }
    .page_title_image .swiper-slide{
        text-align: center;
    }
    .page_title_image img{
        position: relative;
        width: auto;
        height: 240px;
    }

    .page_title{
        height:50px;
        padding-right: 40px;
        padding-left:40px;
        line-height: 50px;
        display: inline-block;
        margin-top: 160px;
        background-color:#0547f4;
        color: white;
        font-size: 28px; 
    }
    .page_title_image.subtitle{
        height:240px;
        background-image: url('../img/common/main_img.png');
        background-size:cover;
        background-position: center center;
        background-repeat: no-repeat;
    }
    .page_title_image .page_subtitle{
        position: absolute;
        bottom:60px;
        color: white;
        font-size: 28px; 
        line-height: 48px;
        height:48px;
        padding-right: 32px;
        padding-left:max(calc(50vw - 450px),32px);
        background-color:#0547f4;
    }

}