@charset "utf-8";
/* CSS Document */

@media screen and (max-width:736px) {
    html, body {
        font-size: 3.5vw;
        min-width: 0;
        width: 100%;
        height: 100%;
        -webkit-text-size-adjust : 100%;
    }

    img {
        max-width: 100% !important;
        height: auto;
    }

    .sp_only {display: inherit;}
    .sp_none {display: none;}

    .inner,
    .inner_min{
        width: 100%;
        margin: 0 auto;
        padding: 0 3%;
        box-sizing: border-box;
    }

    /*-----header-----*/

    header {
        display:none;
    }


    /*-----main_img-----*/
    .swiper-container {
    width: 100%;
    height: 100vw;
    transition:opacity .6s ease;
    background: url("../images/page/index/bg_blue.png") bottom center no-repeat;
    background-size: 100%;
    padding-bottom: 20px;
    }
    
    .swiper-slide .content{
    position:absolute;
    top:5%;
    left:0;
    width:90%;
    padding-left:5%;
    }
    
    .swiper-slide .title{
        font-size:6vw;
        margin-bottom:20px;
        line-height: 1.6em;
        letter-spacing: 0.2em;
    }

    
    h2.main_ttl {
        letter-spacing: 0.2em;
        font-size: 5vw;
        line-height:2.0em;
    }

    /*-----news_area-----*/

    .news_area { padding: 5% 0; }
    .news_area dl dt {
        font-size:2.5vw;
        font-weight:bold;
        float:none;
        width: 100%;
        display: block;
        margin: 0 0 2%;
    }

    .news_area dl dd {
        float:none;
        margin: 0px;
        font-size: 3.8vw;
    }

    span.new {
        font-size: 2.5vw;
        margin: 0 0 1%;
        display: inline-block;
    }

    /*-----news_area-----*/

    .main_area {
        background: url(../images/page/index/bg01.jpg) no-repeat 18%;
        background-size: cover;
        padding: 10% 0 20%;
    }

    .main_contents_left {
        width: 100%;
        text-align:center;
    }

    .main_contents_left h3 {
        font-size:5vw;
        margin: 0 0 10%;
    }

    .main_contents_left p {
        text-align: left;
        font-size: 4vw;
        line-height: 2.2em;
        padding: 0;
    }

    .main_contents_left p br {
        display:none;
    }
    
    /* index商品 */
    .index_product{
        background: url("../images/page/index/bg_blue002.png") center top no-repeat;
        background-size:500%;
        padding: 40px 0 0;
        margin-bottom: 50px;
    }

    .index_product .ttlunit{ color: #fff;}

    .ttlunit{
        text-align: center;
        margin-bottom: 20px;
    }

    .index_product .ttlunit p{margin: 20px 0 30px;}
    .index_productlist .ttlunit p{text-align: left !important;}

    .indexttl{
        text-align: center;
        font-size: 5.5vw;
        margin-bottom: 15px;
        font-weight: 500;
    }

    .procat li{
        width: 30%;
        text-align: center;
        margin: 0 1% 0;
        padding: 0 0 0 0;
        box-sizing: border-box;
    }
    .procat li a span.catimg{
        background: url("../images/page/index/bg_iconcat.png") center no-repeat;
        background-size: 100%;
        padding: 30% 0;
    }
    .procat li a:hover span{color:#1d7ace;}
    .procat li a:hover span.catimg{
        background: url("../images/page/index/bg_iconcat_hover.png") center no-repeat;
        background-size: 100%;
    }

    /* 商品リスト */
    .prolist article{
        width: 48%;
        margin: 0 1% 30px;
        box-sizing: border-box;
        padding: 0 0 0 0;
    }

    .prolist article p.prolistimg img{
        width: 100%;
        height: 150px;
    }

    .prolist article div.listtext{margin: 10px 0;}
    .prolist article ul.catlist{margin-bottom: 5px;}
    ul.catlist li{
        width: 48%;
        margin: 0 1% 0 0;
        font-size: 2vw;
        text-align: center;
    }
    
    .prolist article div.listtext h3 span{
        display: block;
        font-size: 2.5vw;
        font-weight: normal;
    }

    .prolist article div.listtext h3{
        font-size: 3.5vw;
        font-weight: 550;
    }

    p.business_bt {
        text-align:center;
        padding: 10% 10% 15%;
    }

    .bluebtn a{
        width: 85%;
        padding: 25px 0;
        font-size: 4vw;
    }


    /* ────────────────────── *
     * footer
     * ────────────────────── */

    #page-top a {
        background-size: 45px;
        width: 45px;
        height: 45px;
    }
    #page-top a:hover {background-size: 45px;}

    /* ────────────────────── *
     * footer
     * ────────────────────── */
    footer {margin: 0 0 75px;}

    h2.footer_logo{margin-bottom: 15px; text-align: center;}
    h2.footer_logo img {width: 50%;}
    h2.footer_logo span {
        display:block;
        font-size:13px;
        margin: 0 auto 10px;
        letter-spacing:0.05em;
    }

    dl.footer_access_txt {
        font-size:2.5vw;
        line-height: 2.0em;
        float: none;
        text-align: center;
        margin-bottom: 20px;
    }

    .footer_nav {float:none;}
    .footer_nav ul{
        width: 100%;
        border-left:none;
    }
    
    .footer_nav ul:last-of-type{border-bottom: 1px solid #ccc;}
    .footer_nav ul li a{
        font-size:3.5vw;
        padding: 10px 3%;
        display:block;
        color:#444444;
        border-top: 1px solid #ccc;
    }

    p.copyright {
        text-align:center;
        color: #fff;
        font-size:11px;
        background-color:#1d7ace;
        padding: 15px 0;
    }

    /*----------sp_navi------------*/

    .sp_logo img {
        width: 60%;
        vertical-align:top;
    }

    .sp_logo {
        width: 100%;
        /*height: 45px;*/
        float: left;
        text-align: center;
        margin: 0;
        padding: 4vw 0 0;
    }


    .sp_nav {
        z-index: 99999;
        height: 18vw;
        background-color: #fff;
        width: 100%;
        top:0;
    }

    .menu1{
      position: fixed;
      top: 2%;
      right: 2%;
      background: url('../images/common/menu.png') #1d7ace;
      border: 1px solid #fff;
      background-repeat: no-repeat;
      background-position: center center;
      background-size: 60%;
      width: 12vw;
      height: 12vw;
      z-index: 999;
      /*margin: 30px;*/
    }

    .sp_nav .panel{
      position: fixed;
      z-index: 999;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      display: none;
    }

    .sp_nav .panel-inner{
      position: relative;
      width: 100%;
      height: 100%;
      background: #fff;
      /*background: rgba(255, 255, 255, .9);*/
      transition: all 0.5s;
      overflow-y: scroll;
    }


    .sp_nav .l-nav{
      padding: 46px 0 0;
      bottom: 0;
      width: 100%;
      margin: auto;
      /*position: absolute;*/
    }

    i.fa-angle-right {
        text-align: left;
        position: absolute;
        left: 10%;
        top: 40%;
    }

    .nav-item {
      font-size:4vw;
      width: 96%;
      letter-spacing: 0.1em;
      margin: 0 auto;
      position: relative;
      text-indent: 20px;
    }


    .nav-item02 {
      font-size: 14px;
      font-weight: bold;
      width: 96%;
      letter-spacing: 0.1em;
      margin: 0 auto;
      text-indent: 20px;
    }

    .nav-item span {
        font-size: 2vw;
        display: inline-block;
        padding-left: 2%;
        font-weight: bold;
    }

    .nav-item a,
    .nav-item02 a{
        display: block;
        color: #333;
        text-decoration: none;
        transition: all 0.3s;
        border-bottom: 1px solid #ccc;
        padding: 25px 0;
    }

    .nav-item:hover > a{
      color: #603813;
      letter-spacing: 0.1em;
    }

    .close{
      position: fixed;
      top: 2%;
      right: 2%;
      background: url('../images/common/close.png') #1d7ace;
      border: 1px solid #fff;
      background-repeat: no-repeat;
      background-position: center center;
      background-size: 60%;
      width: 12vw;
      height: 12vw;
      /*margin: 30px;*/
    }
    
    /* ────────────────────── *
     * 下層ページ共通
     * ────────────────────── */
    #contents{margin-bottom: 100px;}

    .pagemain{
        background:linear-gradient(90deg, #136cda, #13b7ec);
    }
    .pagemain div.inner h1{
        padding: 40px 0;
        color: #fff;
        font-size: 4vw;
        letter-spacing: 0.1em
    }
    .page-template-page-policy .pagemain div.inner h1{font-size: 3vw;}
    
    
    .pagemain div.inner{
        background-position:140px center;
        background-repeat: no-repeat;
        background-size: auto 100%;
    }
    
    .page-template-page-commercial .pagemain div.inner{background-position:200px center;}
    .page-template-page-commercial .pagemain div.inner h1{font-size: 2vw; width: 60%;}

    .subttl{
        font-size: 4.8vw;
        margin-bottom: 20px;
        line-height: 1.8em;
        background: url("../images/common/bg_subttl.jpg") left center no-repeat;
        background-size: 20px;
        padding: 10px 30px;
        font-weight: 500;
        letter-spacing: 0;
    }

    .errorttl{text-align: center; font-size: 5vw; margin-bottom: 30px;}
    .contact-complete{text-align: center;}

    /* パンくず */
    #breadcrumbs{
        font-size:2vw;
        padding: 2% 0;
    }
    #breadcrumbs ul li a{
        padding:0 1%px 0 0;
        margin-right: 8px;
    }
    
    /* ────────────────────── *
     * 取扱い商品
     * ────────────────────── */
    .main_cantents.m_right .prolist article{
        width: 50%;
        margin: 0 0 30px;
        box-sizing: border-box;
        padding: 0 0 0 0;
    }

    .main_cantents.m_right .prolist article p.prolistimg img{
        width: 100%;
        height: 150px;
    }

    /* 商品詳細 */
    .single_product .subttl{
        font-size: 4.8vw;
        margin-bottom: 20px;
        line-height: 1.5em;
        background: url("../images/common/bg_subttl.jpg") left center no-repeat;
        background-size: 20px;
        padding: 10px 30px;
        font-weight: 500;
        letter-spacing: 0;
    }

    .single_product .subttl span{
        font-size:3vw;
        display: block;
        letter-spacing: 0.1em;
    }

    .single_product article{ margin: 0 0 50px}
    .single_product ul.catlist{margin-bottom: 10px;}
    .single_product ul.catlist li{
        width: 48%;
        margin: 0 1% 0 0;
    }

    .product_info{margin-bottom: 20px;}

    .single_product article p.prodetailimg,
    .single_product .product_info .woocommerce-product-gallery,
    .single_product .product_info .woocommerce-page div.product div.images{
        float:none;
        width: 100% !important;
        background: #333;
    }

    .cartinfo,
    .single_product .product_info .woocommerce div.product div.summary{
        float:none;
        width:100%;
        padding-top: 60px;
    }
    
    .single_product .product_info .price{
        text-align: right;
    }
    
    .cartinfo p.price,
    .single_product .product_info .price span.woocommerce-Price-amount{
        font-weight: 600;
        font-size: 10vw;
        color: #333;
    }

    .single_product .product_info .price{margin-bottom: 20px;}
    .cartinfo p.kazu{margin-bottom: 20px;}
    form.cart{width: 100%;}
    .cartinfo p.kazu input,
    .single_product .product_info .quantity{width: 20%;}
    .cartinfo input.productsubmit,
    .single_product .product_info button.single_add_to_cart_button{
        color: #fff;
        background-color:#bf4949 !important;
        border: 1px solid #bf4949;
        width: 78%;
        border-radius: 6px;
        text-align: center;
        margin: 0 auto;
        padding: 20px 0;
        font-size: 5vw;
        box-sizing: border-box;
        box-shadow:3px 3px 12px -2px #ccc;
    }

    .product_meta{display: none;}
    .related.products{
        overflow: hidden;
        clear: both;
        display: none;
    }

    .single_product article p.caption{margin-bottom: 20px;}
    .single_product article .caution{
        border: 3px solid #bf4949;
        padding: 20px 10px;
    }

    .single_product article .caution h3{
        text-align: center;
        font-weight: 550;
        color: #bf4949;
        margin-bottom: 20px;
    }

    .single_product article h3{
        font-size: 4vw;
        overflow: hidden;
        margin-bottom: 30px;
        font-weight: 500;
    }
    .single_product article h3 span {
        display: inline-block;
        padding: 0 0.5em 0 0;
        position: relative;

    }
    .single_product article h3 span:after {
        border-top: 2px solid #136bda;
        content: "";
        position: absolute;
        top: 50%;
        width: 99em;
    }
    .single_product article h3 span:after {left: 100%;}

    .single_product article .product_detail{
        margin-left: 50px;
    }

    .single_product article .product_detail dl{
        display: block;
        width: 100%;
    }

    .single_product article .product_detail dl dt,
    .single_product article .product_detail dl dd{
        display:  block;
        box-sizing: border-box;
        vertical-align: middle;
        padding: 10px 3%;
    }

    .single_product article .product_detail dl dt{
        border-top: 1px solid #1d7ace;
        font-weight: 500;
        width:100%;
    }

    .single_product article .product_detail dl dd{
        border-top: 1px solid #ccc;
        width: 100%;
    }

    .single_product article .product_detail dl:last-of-type dt{border-bottom: 1px solid #1d7ace;}
    .single_product article .product_detail dl:last-of-type dd{border-bottom: 1px solid #ccc;}

    .single_product article .product_detail div h4{font-weight: bold; margin-bottom: 10px;}
    .single_product article .product_detail div{margin-bottom: 25px;}
    
    /* ────────────────────── *
     * 事業内容
     * ────────────────────── */
    .buisiness section{
        margin-bottom: 30px;
        padding-bottom: 10%;
        background-position: center bottom;
        background-repeat: no-repeat;
        background-size: 150%;
    }

    .buisiness section div.bluebox{
        background: #1d7ace;
        color: #fff;
        padding: 20px 10px;
        box-sizing: border-box;
        width:90%;
        margin: 0 auto;
    }
    .buisiness section:nth-child(odd) div.bluebox{float: none;}
    .buisiness section:nth-child(even) div.bluebox{float: none;}

    .buisiness section div.bluebox .subttl{background: url("../images/common/bg_subttl02.jpg") left center no-repeat; background-size: 20px;}
    .buisiness section div.bluebox div.b_text{
        padding: 0 8%;
        line-height: 2em;
    }

    .buisiness section div.bluebox div.b_text p:nth-child(n+2){margin-top: 20px;}
    
    /* ────────────────────── *
     * 会社概要
     * ────────────────────── */
    .greeting{
        background: url("../images/page/aboutus/bg_greeting.jpg") center top no-repeat;
        background-size:130%;
        padding: 30px 0 20px;
        margin-bottom: 50px;
    }

    .greeting h2{
        float: none;
        padding: 3px;
        width: 80%;
        box-sizing: border-box;
        font-size: 5vw;
        letter-spacing: 3px;
        margin: 0 auto;
    }

    .greeting h2 span{
        display: block;
        border: solid 1px #54B9F7;
        padding: 10% 0;
    }

    .greeting_right{
        float: none;
        width: 100%;
    }

    .greeting_right h3{
        margin:30px 0;
        font-size:4.5vw;
        letter-spacing: 0.1em;
        font-weight: bold;
        text-align: center;
    }
    .greeting_right p{line-height: 1.8em;}
    .greeting_right p:nth-of-type(n+2){margin-top: 20px;}


    .tableunit table{width: 100%;}
    .tableunit table tr th,
    .tableunit table tr td,
    .tableunit.company dl dt,
    .tableunit.company dl dd{
        padding: 15px 10px 15px;
        box-sizing: border-box;
    }

    .tableunit table tr th{width: 25%;}
    .tableunit table tr td div{margin-top: 20px;}
    
    .tableunit.company div{margin-left:0; margin-bottom: 30px;}
    
    /* ────────────────────── *
     * お知らせ
     * ────────────────────── */

    .page_newslist{margin-bottom: 40px;}

    .page_newslist article p,
    .page_newslist article h3{float: left; box-sizing: border-box;}

    .page_newslist article p{
        width: 30%;
        border-top: solid 1px #1D7ACE;
        padding: 15px 0;
        text-align: center;
        font-size: 2.5vw;
    }

    .page_newslist article p span{
        color: #1D7ACE;
        font-weight: bold;
        margin-right: 8px;
        font-size:2.5vw;
    }

    .page_newslist article h3{width: 70%;}
    .page_newslist article h3 a{
        padding: 15px 20px;
    }


    /* main_cantents */
    .main_cantents{width: 100%; margin-bottom: 50px;}
    .main_cantents.m_left{float: none;}
    .main_cantents.m_right{float: none;}

    .main_cantents section:nth-of-type(n+2){margin-top: 40px;}

    .blog_single .days{margin:0 0 30px 30px; font-size: 2.5vw;}
    .blog_single .single_contents{
        margin: 0 5% 30px;
    }

    /* サイドバー */
    .sidebar{width: 100%;}
    .sidebar.s_left{float: none;}
    .sidebar.s_right{float: none;}

    .sidebar h2{
        font-size: 4vw;
        padding: 20px 10px;
    }
    
    /* ────────────────────── *
     * お問い合わせ
     * ────────────────────── */
    .contact_caption_list li{font-size: 2.8vw;}
    .contact_caption_list li br{display: none;}

    table.fotmtbl{width: 100%;}
    table.fotmtbl th,
    table.fotmtbl td{
        display: block;
    }

    div.tableunit table.fotmtbl tr th{width:100%; text-align: left; padding: 20px 0 0 10px;}
    div.tableunit table.fotmtbl tr td{width:100%; box-sizing: border-box; border-top:none;  padding: 10px 0 20px 10px;}
    table.fotmtbl td input.w30{width: 28%;}
    table.fotmtbl td input.w90,
    table.fotmtbl td textarea{width: 98%;}
    table.fotmtbl td input,
    table.fotmtbl td textarea{padding:10px 5px;}
    table.fotmtbl td input.nobg{background: none; border: none; padding: 0 0 0 0;}
    table.fotmtbl td p.fcap{padding-bottom: 20px;}
    #submit input{
        display: block;
        width: 85%;
        padding: 30px 0;
        font-size:4vw;
    }

    #submit input.backbtn{
        width: 85%;
         padding: 30px 0;
        font-size:4vw;
        border-radius: 5px;
        margin:20px 0;
    }

    #submit input.backbtn:hover{
        background: #bababa;
        color: #3A1419;
        cursor:pointer; 
    }

    span.error{color: #ff0000; font-weight: bold; margin-left: 5px;}


    /* 入力エラー */
    div.c_unit{margin: 30px 0;}
    div.contact-error{
        background: #ffdede;
        padding: 30px;
        margin-bottom: 30px;
        text-align: center;
    }

    div.contact-error h2.subttl002{color: #ff0000 !important;}

    div.contact-text p,
    div.contact-complete p{
        text-align: center;
        margin-bottom: 20px;
    }


    
    /* ────────────────────── *
     * プライバシーポリシー
     * ────────────────────── */
    .policy_contents div{margin-top: 40px;}

    .policy_contents div h3{
        font-weight: bold;
        font-size: 4vw;
        margin-bottom: 10px;
    }

    .policy_contents div ul li{
        list-style: disc;
        margin: 0 0 8px 20px;
    }
    .policy_contents{margin-bottom: 60px;}

}