@charset "utf-8";
@media screen and (max-width: 990px) {
body{
width: 100%;
min-width: 100%;
webkit-text-size-adjust : none;
}

img{
max-width: 100%;
}

p,
td,
th,
li,
dt,
dd,
input,
textarea,
.entryBody,
.entryMore {
font-size: 16px;
}

/* ========== ヘッダー ========== */
#siteTitle h1 {
font-size:10px;
text-align: center;
width: 100%;
}

.toppage #header{
position:relative;
}

#headerTitle {
width: 100%;
}

#headerAreaLogo {
float: left;
}


#headerAreaLogo img{
max-width:240px;
margin:0 auto;
}


#headerAreaSub {
float: none;
text-align: center;
}

#menuBtn {
display: block;
float:right;
}

#menuBtn a{
display: block;
}

p#headerAddress img{
width:250px;
}
.breadcrumbs .breadcrumbs_inner {
	display:none;
}
/* ========== キャッチ画像 ========== */
#catchArea {
width: 100%;
}

#catchArea_inner {
width: 100%;
}

.nivoSlider{
height:auto;
}

#slider{
height: auto;
}

#slider{
background:none;
}

#main {
width: 100%;
margin: 0 auto;
}

/* ========== 下層キャッチ画像 ========== */
.customs-header-area,
.customs-header-area img {
	display:none;
}
.home .customs-header-area2 {
display:none;
}
.customs-header-area2 {
    width: auto;
    margin: 76px auto 0px;
    text-align: center;
    background: #000;
    position: relative;
    overflow: hidden;
    height: auto;
}
.customs-header-area2 img {
position: relative;
    width: 100%;
    height: auto;
    max-width: none;
}
/* ========== メインメニュー ========== */
#mainMenu {
display: none;
}

#mainMenu ul{
}

/* ==================== コンテンツ ==================== */
#contents {
width: 100%;
float: none;
}

#categoryTop .date .dateTime{
display: block;
}


/* ==================== セカンドエリア ==================== */
#secondArea {
width: 100%;
float: none;
}

#secondArea #subMenu{
display:block;
}

#sideBanners img,
#sideBanners2 img{
width: 90%;
margin:0 auto;
}

#spclose{
display: block;
}

/* ========== フッター ========== */

DIV#footerInner {
width: 100%;
margin: 0 auto 15px;
}

DIV#footer P#copyright{
font-size:12px;
text-align: center;
}


/* ========== サイドメニュー ========== */

div#secondArea div#subMenu div#subMenu_menu div.title{
display: none;
}

#subMenu ul,
#subMenu li,
.sideTitle li,
#secondAreaBlogParts .sideContents li,
#secondAreaCustomParts .sideContents li{
background: none;
}

/* ========== 会社案内 ========== */

#contents #categoryCompany th{
width:1em;
}

#contents #categoryCompany table.accessTable th{
width:1em;
}

/* ========== 施工事例 ========== */

#contents .categoryWorksList ul{
margin: 2% 10px;
}

#contents .categoryWorksList ul li {
float:none;
width: 98%;
margin-bottom: 20px;
}


#contents .categoryWorksList ul li a {
width: 98%;
}

#contents .categoryWorksList ul li img{
width: 98%;
}

#showType1 #categoryWorksData{
float:none;
width:98%;
}

#showType1 #categoryWorksPhoto{
float:none;
width:98%;
}


/* ========== お問い合わせ ========== */

#contents #categoryInquiry table{
width: 98%!important;
margin:0 auto;
}

#contents #categoryInquiry table,
#contents #categoryInquiry tbody,
#contents #categoryInquiry thead,
#contents #categoryInquiry tfoot,
#contents #categoryInquiry tr,
#contents #categoryInquiry th,
#contents #categoryInquiry td {
display: block;
}

#contents #categoryInquiry th,
#contents #categoryInquiry td {
border:none;
background: none;
}

#contents #categoryInquiry th,
#contents #categoryInquiry td,
#contents #categoryInquiry textarea{
width:100%;
}

#contents #categoryInquiry th,
#contents #categoryInquiry td{
padding:5px 0;
}

form#mailformpro input, form#mailformpro textarea{
max-width:250px!important;
}

/* For Smart Phone CSS */

  *, *:before, *:after {
      -webkit-box-sizing: border-box;
         -moz-box-sizing: border-box;
           -o-box-sizing: border-box;
          -ms-box-sizing: border-box;
              box-sizing: border-box;
  }

  body {
    font-family: sans-serif;
    /*padding-bottom: 60px;*/
    -webkit-text-size-adjust: 100%;
  }

  p, li, dt, dd {
    font-size: 14px;
  }

  .pcNone {
    display: block;
  }
  br.pcNone {
    display: inline;
  }
  table.pcNone {
    display: table;
  }
  tr.pcNone {
    display: table-row;
  }
  th.pcNone,
  td.pcNone {
    display: table-cell;
  }
  .spNone {
    display: none;
  }

  body,
  body#index {
    min-width: 0;
  }

  .fixed {
    display: none!important;
  }

  #sp_gnavi {
width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow-y: auto;
    z-index: -9;
    background-color: rgba(0, 0, 0, 0.9);
  }
  #sp_gnavi a {
    color: #fff;
    text-decoration: none;
    display: block;
    text-align: left;
  }
  #sp_gnavi dl {
    border-top: 1px dotted #fff;
    margin-top: -1px;
  }
  #sp_gnavi dl:first-child {
    margin-top: 80px;
    border-top: none;
  }
  #sp_gnavi dt {
    font-weight: bold;
    text-align: center;
    color: #fff;
    font-size: 15px;
    line-height: 1;
    padding: 15px;
    border-bottom: 1px solid #fff;
  }

  #sp_gnavi ul {
    overflow: hidden;
    margin:0;
    padding:0;
    list-style: none;
  }
  #sp_gnavi ul li {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-bottom: 1px solid #fff;
    font-size:12px;
  }

  #sp_gnavi ul a {
    position: relative;
padding:0 10px;
    height: 50px;
    line-height: 1.4;
    font-size: 11px;
  }
  #sp_gnavi ul a span {
    display: block;
    position: relative;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }

  #sp_gnavi ul a:after {
content:"▶";
float:right;
}

  #sp_gnavi ul li.on a:after {
content:"▼";
}


  #sp_gnavi ul li ul li {
border-top:1px dotted #fff;
border-bottom:none;
margin-left:0px;
}

  #sp_gnavi ul li ul li a:after{
content:""!important;
}

  #sp_gnavi .close {
    border-top: 1px dotted #fff;
    text-align: center;
    padding: 15px 0;
    margin: -1px 0 0 0;
  }
  #sp_gnavi .close a {
    display: inline-block;
    font-weight: bold;
  }

  .ac_Menu {
    display: inline-block;
width:15%;
    padding:  0;
float:right;
  }



.spNavi{
position:relative;
}

/* ==================== 各サイト専用 ==================== */

.pagetop{
right:0;
bottom:0;
}

#categoryTop .date li span.dateTime{
background:none;
padding:0;
color:#fe9e1a;
}


#header_sp {
    display: block;
}


#header_sp {
    position: fixed;
    z-index: 10;
    background: #fff;
    top: 0;
    width: 100%;
    display: block !important;
}

#header_sp.fixed {
    position: fixed;
    }

#header_sp #nav_sp01 {
    background: #fff;
margin:0;
padding:0;
display: flex;
}
#header_sp li.logo {
    margin: 0px;
}
#header_sp img {
    vertical-align: bottom;
}
#nav_sp01 li {
    margin: 0px;
    display: inline;
    list-style:none;
}

#catchArea{
margin-top:80px;
}

#topLatestBlog_inner{
width:100%;
}

#locoblog,
#letter{
width:100%;
float:none;
}

#contents #topcontent01 div,
#contents #topcontent02 div,
#contents #topcontent03 div,
#contents #topcontent04 div,
#topcontent04,
DIV#footer DIV#footerMenu{
width:100%;
float:none;
}

#topLatestBlog h2{
font-size:21px;
}

#topLatestBlog h3{
font-size:18px;
text-align:center;
}

#locoblog p,
#letter p {
position:relative;
text-align:center;
top:0;
}

#topLatestBlog ul{
margin:15px 20px;
}

#contents #categoryTop p.fl,
#contents #categoryTop p.fr{
float:none;
margin:0 0 15px 0;
}

#topcontent01, #topcontent02, #topcontent03{
margin:0;
}

#contents #categoryTop h3 span{
font-size:16px;
}

#contents #categoryTop h3{
font-size:21px;
text-align:center;
}

#contents #categoryTop div div p{
width:94%;
margin: 0 auto 20px;
font-size:15px;
}

#contents #categoryTop ul{
margin-bottom:30px;
}

#contents #categoryTop ul#topbnr li{
width:70%;
}

#footerAreaLogo{
float:none;
margin:0 auto;
}

DIV#footer DIV#footerMenu{
margin-top:30px;
text-align:center;
}

DIV#footer DIV#footerMenu ul li{
display:block;
}

DIV#footer DIV#footerMenu ul li:after{
display:none;
}

p.fr{
float:none;
margin:0 auto;
text-align:center;
}

p.fl{
float:none;
margin:0 auto;
text-align:center;
}

p.fl.mr30{
float:none;
margin:0 auto;
text-align:center;
}

#categoryFreePage{
	width:96%;
	margin:48px auto 0;
}

.blog #contents {
    width: 100%;
    float: none;
}

.blog #secondArea {
    float: none;
    width: 100%;
    margin: 15px 0;
}

#main.blog{
	width:96%;
	margin:0 auto;
}
#contents .mainTitle h2 {
    color: #2e1203 !important;
    font-size: 24px !important;
    font-weight: 400 !important;
    font-family: 'Noto Sans JP', sans-serif !important;
    line-height: 1.5 !important;
    padding: 0 !important;
    margin: 0px auto 24px !important;
    text-align: center !important;
    position: relative !important;
}
#contents h3 {
    color: #2e1203 !important;
    font-size: 21px !important;
    font-weight: 400 !important;
    font-family: 'Noto Sans JP', sans-serif !important;
    line-height: 1.5 !important;
    padding: 0 !important;
    margin: 0px 0 24px !important;
    text-align: left !important;
    position: relative !important;
}
.blog img {
    width:100%;
}
.aligncenter,
.aligncenter img {
    width:100% !important;
    height:auto;
}
}
