@charset "UTF-8";

/* 印刷用 */
@media only print{
  /*
    A4 847 * 595 px
    A3 1191 * 842 px
    B5 729 * 516 px
  */
  body{
    width: 1140px;
    overflow: hidden;
    /*zoom: 0.9;*/
  }
  .container{
    width: 100%;
  }
  .tb{
    display: none;
  }
  .sp{
    display: none;
  }

  /* 固定ヘッダーを使用している場合など */
  header .hdr1{
    position: static !important;
  }
  /* animate のフェードインを可視化 */
  [data-animate]{
    opacity:1 !important;
  }
}

@media only screen and (max-width:1220px){
  /* **********************************
   *  TOP
   * ********************************* */

  /* **********************************
   *  フッター
   * ********************************* */
  footer{
    margin-top: 60px;
  }
  footer .fttr_bx .box3 .box4 .site_map:after{
    top: 34%;
  }
  .action_contact_wrap .items .item .info_contact.left{
    justify-content: center;
  }
  .action_contact_wrap .info_contact.left .text{
    margin-left: 60px;
  }
  .action_contact_wrap .info_contact.left .number{
    font-size: 32px;
  }
  /* **********************************
   *  top
   * ********************************* */
  .tt2{
    font-size: 28px;
  }
  .tt3 em{
    font-size: 16px;
  }
  .mv{
    height:400px; 
  }
  .mv .mv_box .txt{
    font-size: 36px;
  }

  .tt3.news:before {
    height: 45%;
    width: 38px;
    top: -40px;
    right: 45%;
  }



  .home_concept_img:after{
    height: 79%;
    width: 69px;
    top: 8px;
    right: 190px;
  }

  .action_contact_wrap.bottom .box1:before{
    height: 83px;
    width: 71px;
    top: -16px;
    left: 3px;
  }

  .action_contact_wrap .box2.right .bottom .box1:before{
    height: 92px;
    width: 74px;
    top: -16px;
    left: 4px;
  }
  .action_contact_wrap .bottom .box1 .text span .fa-envelope:before{
    font-size: 29px;
    bottom: -3px;
    left: -41px;
  }
  .home_info_wrap{

  }
  .tt3.product:before{
    height: 65%;
    width: 78px;
    top: -50px;
    right: 46%;
  }
  .home_works_items:before{
    width: 200px;
    height: 83px;
    left: 20px;
    top: -100px;
    
  }
  .action_contact_wrap .bottom .box1:before{
    height: 104px;
    width: 72px;
    top: -32px;
    left: 3px;
  }
  .action_contact_wrap .box2.right .bottom .info_contact .t1{
    font-size: 29px;
  }


  /* **********************************
   *  お知らせ一覧
   * ********************************* */
  .pg_archive_news .section#sec1{
    margin-top: 100px;
    margin-bottom: 60px;
  }
  .post_items .item .date{
    font-size: 16px;
  }
  .post_items .item .title{
    font-size: 16px;
  }
  /* **********************************
   *  お知らせ詳細
   * ********************************* */
  .pg_single_news .section#sec1{
    margin-bottom: 50px;
  }
  .pagination .nav-posts .page-archive,
  .pagination .nav-posts .page-next,
  .pagination .nav-posts .page-prev{
    min-width: 200px;
  }
  .pagination .nav-posts .page-archive a{
    font-size: 14px;
    width: 200px;
    padding: 10px;
  }
  .pagination .nav-posts .page-next a,
  .pagination .nav-posts .page-prev a{
    font-size: 14px;
    width: 200px;
    padding: 10px;
  }
   .pagination .nav-posts .page-archive.news,
  .pagination .nav-posts .page-next.news,
  .pagination .nav-posts .page-prev.news{
    font-size: 16px;
    min-width: 200px;
  }
  .pagination .nav-posts .page-next.news a,
  .pagination .nav-posts .page-prev.news a,
  .pagination .nav-posts .page-archive.news a{
    width: 200px;
    font-size: 16px;
  }
  /* **********************************
  *  施工・工事
  * ********************************* */
  .construction_image_wrap .items{
    justify-content: center;
  }
  .construction_image_wrap .items .box1 .img1 img,
  .construction_image_wrap .items .box1 .img2 img{
    height: 470px;
  }
  .construction_image_wrap .items .box2 .img1 .inner img,
  .construction_image_wrap .items .box2 .img2 .inner img{
    height: 232px
  }
  /* **********************************
  *  暖楽舎について
  * ********************************* */
  .company_mge_wrap .company_items .box1 .greeting_img span{
    left: 25%;
  }
  .company_mge_wrap .company_items .box1 .txt{
    right: 16px;
  }
  /* **********************************
  *  メンテナンス
  * ********************************* */
  .maintenance_qa_wrap .items .item .flex .box1 .title,
  .maintenance_qa_wrap .items .item .flex .box1 .txt1,
  .maintenance_qa_wrap .items .item .flex .box1 .text,
  .maintenance_qa_wrap .items .item .flex .box1 .title2,
  .maintenance_qa_wrap .item.right .title,
  .maintenance_qa_wrap .item.right .txt1{
    font-size: 14px;
  }
  .maintenance_mge_wrap:before{
    left: 46%;
  }
  /* **********************************
  *  初めての方へ
  * ********************************* */
  .beginners_faq_wrap .items .item .meta_title:after{
    height: 14px;
  }
  /* **********************************
  *  お見積もり
  * ********************************* */
  .pg_quote .contact_form.sec2 td.file .block{
    font-size: 13px;
  }
}

@media only screen and (max-width:1023px){


  /* **********************************
   *  フッター
   * ********************************* */
  footer .ftr_links li{
    padding: 0 5px;
  }
  footer .ftr_addr{
    font-size: 13px;
  }
  footer .fttr_bx .box3 .fttr_info{
    font-size: 13px;
    margin-top: 34px;
  }
  footer .fttr_bx .box3 .box4 .fttr_contact a.btn3{
    width: 200px;
    font-size: 13px;
    padding: 7px 5px;
  }
  footer .fttr_bx .box3 .box4 .site_map span{
    font-size: 14px;
  }
  footer .fttr_bx .box3 .box4 .site_map:after{
    top: 34%;
  }
  .action_contact_wrap .items .item .info_contact.right{
    justify-content: center;
    margin-left: 40px;
  }
  .action_contact_wrap .items .item .info_contact.right .fa-envelope:before{
   bottom: -8px;
  }
  /* **********************************
   *  top
   * ********************************* */
  .tt2{
    font-size: 28px;
  }
  .tt3 em{
    font-size: 16px;
  }
  .mv{
    height:400px; 
  }
  .mv .mv_box .txt{
    font-size: 36px;
  }
  .home_concept_items .item .inner .title{
    font-size: 13px;
  }
  .tt3.news:before {
    height: 45%;
    width: 38px;
    top: -40px;
    right: 44%;
  }


  .home_concept_img img{
    width: 50%;
    height: 50%;
  }
  .home_concept_img:after{
    height: 81%;
    width: 68px;
    top: 8px;
    right: 115px;
  }
  .action_contact_wrap .bottom .info_contact{
    width: auto;
  }

  .home_banner_items .item.show .inner span{
    font-size: 20px;
  }
  .action_contact_wrap .bottom .box1 .text{
    font-size: 20px;
    margin-right: 20px;
  }
  .action_contact_wrap .bottom .box1 .number{
    font-size: 25px;
    margin-right: 0;
  }
  .action_contact_wrap .bottom .box1:before{
    height: 83px;
    width: 57px;
    top: -32px;
    left: 3px;
  }
  .action_contact_wrap .box2.right .bottom .box1{
    padding: 33px 0;
  }
  .action_contact_wrap .box2.right .bottom .info_contact{
    margin-right: 16px;;
  }
  .action_contact_wrap .box2.right .bottom .box1 .info_contact .text{
    margin-right: 0;
  }
  .action_contact_wrap .box2.right .bottom .box1:before{
    height: 76px;
    width: 56px;
    top: -23px;
    left: 4px;
  }
  .action_contact_wrap .box2.right .bottom .info_contact .t1{
    font-size: 20px;
  }
  .action_contact_wrap .bottom .box1 .text span .fa-envelope:before{
    font-size: 29px;
    bottom: -3px;
    left: -41px;
  }
  .home_info_wrap{

  }
  .tt3.product:before{
    height: 65%;
    width: 78px;
    top: -50px;
    right: 45%;
  }
  .home_works_wrap .home_works_items:before{
    left: 31px;
    top: -87px;
    /* width: 19%; */
    height: 84px;
  }
  .action_contact_wrap .item .text span{
    font-size: 20px;
  }
  .action_contact_wrap .item .box1 .number{
    font-size: 30px;
    margin-right: 10px;
  }
  .action_contact_wrap .items .item .info_contact{
    width: 100%;
  }
  .action_contact_wrap .item .box1 .text{
    font-size: 18px;
    font-weight: normal;
    color: #ffffff;
    line-height: 1.2em;
    margin-right: 10px;
  }
  .action_contact_wrap .box1:before{
    height: 83px;
    width: 58px;
    top: -32px;
    left: 3px;
  }
  .action_contact_wrap .item.right .box1:before{
    height: 75px;
    width: 58px;
    top: -21px;
    left: 11px;
  }
  .action_contact_wrap .item.right .box1{
    padding: 39px 0;
  }
  .action_contact_wrap .item .text span .fa-envelope:before{
    bottom: -6px;
  }
  .action_contact_wrap .item.right .info_contact .t1{
    margin-right: 10px;
  }
  /* **********************************
   *  施工・工事
   * ********************************* */
  .pg_construction{
    margin-bottom: 100px;
  }
  .tt4.self:before{
    left:11%;
  }
  .tt4.or:before{
    left: 46%;
  }
  .construction_self_wrap:before{
    left: 19%;
  }
  .construction_self_wrap .items .box1 .text{
    font-size: 15px;
  }
  .construction_self_wrap .items .box2 .img{
    padding-top: 0;
  }
  .construction_image_wrap .items .box1 .img1 .inner{
    

  }
  
  .construction_image_wrap .items .box1{
    padding: 0;
  }
  .construction_image_wrap .items .box1 .img2 .inner{
    padding-left: 5px;
    padding-right: 5px;
  }

  /* **********************************
   *  メンテナンス
   * ********************************* */
  .pg_maintenance{
    margin-bottom: 50px;
  }
  .maintenance_desc_wrap .tt4.ora2{
    font-size: 22px;
  }
  .maintenance_mge_wrap:before{
    height: 50px;
    width: 75px;
    left: 46%;
  }
  .maintenance_change_wrap .items .item.left{
    margin-right: auto;
  }
  .maintenance_change_wrap .items .item.right{
    margin-left: auto;
  }
  .maintenance_change_wrap .items .item.left:after{
    right: -92px
  }
  .maintenance_qa_wrap .items{
    display: block;
  }
  .maintenance_qa_wrap .items .item{
    width: 100%;
  }
  .maintenance_qa_wrap .items .item .flex{
    justify-content: space-between;
  }
  .maintenance_qa_wrap .items .item .flex .box1{
    width: 77.47%;
    padding-bottom: 10px;
  }
  .maintenance_qa_wrap .items .item.left{
    padding-right: 0;
  }
  .maintenance_qa_wrap .items .item.right{
    margin-top: 20px;
  }
  .maintenance_qa_wrap .items .item .flex .box2 .inner{
    padding: 8px 5px 8px 0;
  }
  .maintenance_qa_wrap .item.right .img{
    text-align: center;
  }
  .maintenance_change_wrap .items .item {
    margin: 0 20px;
  }
  
  .pg_maintenance .section#sec2 .center{
    text-align: left;
  }
  
  /* **********************************
  * 暖楽舎について
  * ********************************* */
  .pg_company .section#sec2{
    height: 150px;
  }
  .show_info_tbl{
    margin-left: 60px;
  }

  /* **********************************
   *  初めての方へ
   * ********************************* */
  .beginners_flow_items .item .title{
    font-size: 15px;
  }
  .beginners_flow_items .item .txt{
    font-size: 14px;
  }
  .read_more.s a{
    font-size: 13px;
  }
  .beginners_faq_wrap .items .item .meta_title .title_q{
    font-size: 14px;
  }
  .beginners_faq_wrap .items .item .item_a span{
    font-size: 13px;
    padding-left: 0;
  }
  .beginners_faq_wrap .items .item .meta_title:after{
    height: 10px;
  }
  .beginners_howto_wrap .box1 .txt, .beginners_howto_wrap .box2 .txt{
    font-size: 14px;
  }
  /* **********************************
  * 取扱商品
  * ********************************* */

  .pg_handling{
    margin-bottom: 0;
  }
  .pg_handling .section#sec1{

  }
  .pg_handling .section#sec2{
    margin-top: 40px;
  }
  .pg_handling .section#sec3{
    margin-top: 40px;
  }
  .handling_cat_items .item:nth-child(n+2) .inner{
    padding: 0 10px 40px;
  }
  .handling_cat_items .item .name,
  .handling_cat_items .item:nth-child(n+2) .name{
    width: 220px;
    border: 1px solid #cdcccc;
    box-shadow: 1px 1px 2px #cdcccc;
    padding: 10px 10px;
    position: absolute;
    top: 22%;
    left: -2px;
  }
  .handling_cat_items .item .name span{
    font-size: 17px;
  }
  .handling_product_items .box2 .txt{
    font-size: 14px;
  }
  .product_info_items{
    display: block;
  }
  .product_info_items .left{
    width: 60%;
    margin: 0 auto;
  }
  .product_info_items .right{
    width: 100%;
    padding-left: 0;
    margin-top: 20px;
  }
  .handling_product_items.type-b .item {
    width: 50%;
    padding: 0 15px
  }
  .handling_product_items.type-b .item:nth-child(n+3) {
    margin-top: 58px;
  }
  .detail_ttl,
  .works_link{
    font-size: 16px;
  }
  
  
  /* **********************************
  *  施工事例　詳細
  * ********************************* */
  .pg_single_case{
    margin-bottom: 60px;
  }
  .case_items .item .title{
    font-size: 18px;
  }

  /* **********************************
     *  サイトマップ
     * ********************************* */

  .sitemap_items .item a{
    font-size: 14px;
  } /* **********************************
     *  お見積もり
     * ********************************* */
  .quote_desc_wrap .description .text1,
  .quote_desc_wrap .description .text2{
    font-size: 15px;
  }
  .quote_title,
  .quote_notes,
  .quote_txt{
    font-size: 14px;
  }
  
  /* **********************************
   *  お問い合わせ
   * ********************************* */
  .contact_form th {
    width: 250px;
  }
  .contact_form td .wpcf7-text{
    width: 100%;
  }
  .contact_form td [name="zipcode"]{
    width: 90px;
  }
  .contact_form.sec2 td.file input{
  width: 85%;
}
.contact_form td.induction span:nth-child(3):after{
  font-size: 13px;
}
.contact_form td.induction .file_block{
  display: block;
  margin-top: 20px;
}
.contact_form td.induction .file_block input[name="file1"]{
  width: 100%;
}
  /* **********************************
   *  お問い合わせ
   * ********************************* */
  .contact_info .box2 .tel a{
    font-size: 30px;
  }
  .contact_info .box2 .tel .slash{
    font-size: 30px;
    margin: 0 10px;
  }
}

@media only screen and (max-width:767px){

  body{
    font-size: 14px;
    padding-bottom: 50px;
  }

  header{
    padding: 10px 0;
  }
  header .hdr1{
    width: 100%;
    margin-bottom: 0;
    flex-wrap: nowrap;
  }
  header .hdr1 .hdr_logo{
   
    margin: 5px 0;
  }
  header .hdr1 .hdr_logo img{
    width: 240px;
  }
  header .hdr1 .hdr_contact{
    display: none;
  }
  .hdr_info{
    display: block;
  }
  .hdr_info .box1{
    text-align: center;
    
  }
  .hdr_info .btn1 {
    font-family: 'Roboto', sans-serif;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.030em;
    margin-right: 0;
    position: relative;
  }
.hdr_info .btn1:before {
    display: block;
    content: "";
    width: 113px;
    height: 84px;
    background-image: url(/img/top/home_img.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    position: absolute;
    top: -2px;
    left: 2%;
}
.hdr_info .btn1 span {
    display: block;
    font-size: 12px;
    font-weight: 700;
    width: 110px;
    color: #0F2C6C;
   margin-top: 50px;
    position: relative;
    margin-right: -1px;
    margin-left: 2px;
}
.hdr_info .btn1 span:after {
    display: block;
    content: "";
    width: 24px;
    height: 31px;
    background-image: url(/img/top/beginner.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    position: absolute;
    top: -31px;
   left: 40%;
}
.hdr_info .box2{
  display: none;
}
  .section#fttr_contact {
    margin-top: 60px;
  }
  footer .ftr2 .container{
    flex-wrap: wrap;
  }
  footer .ftr2 .box1,
  footer .ftr2 .box2{
    width: 100%;
    text-align: center;
  }
  footer .ftr2 .box2{
    margin-top: 10px;
  }
  footer .fttr_bx .box3 .box4 .fttr_contact a.btn3{
    font-size: 12px;
    padding-left: 20px;
  }
  .footer_fix{
    display: block;
  }
 .footer_fix .fa-envelope:before{
    margin-right: 0px;
  }
  .gnav{
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: #FFF;
    padding: 0;
    z-index: 99999;
    overflow-y: scroll;

    /*transition: all 0.2s;*/
    transform: translateX(100%);
    padding: 15px;
  }
  .gnav.active{
    transform: translateX(0%);
  }
  .gnav > ul{
    display: block;
  }
  .gnav > ul > li{
    width: 100%;
    padding: 10px 0;
    border: 0;
    border-bottom: 1px dashed #CCC;
  }
  .gnav > ul > li + li,
  .gnav > ul > li:first-child,
  .gnav > ul > li:last-child{
    border-left: 0;
    border-right: 0;
  }
  .gnav > ul > li a{
    padding: 10px 0;
    margin: 20px 0;
  }
  .gnav .children, .gnav .sub-menu{
    display: block;
    position: static;
    background: #EEE;
  }

  .pg_header .container{
    height: 150px;
  }
  
  .breadcrumb{
    font-size: 12px;
  }
  .breadcrumb li{
    white-space: nowrap;
  }

  .tt1{
    font-size: 24px;
  }
  .tt1 span{
    font-size: 14px;
  }

  .tt2{
    font-size: 17px;
  }
  .tt2.concept{
     font-size: 17px;
  }
  .tt3{
    font-size: 16px;
  }
  .tt3 span{

  }
  .tt4{
    font-size: 18px;
  }
  .tt4 span{

  }
  .tt5{
    font-size: 13px;
  }
  .tt5 span{

  }

  .post_items{

  }
  .post_items .item{
    flex-wrap: nowrap;
  }
  .post_items .item .title{
    width: 100%;
  }
  .post_items .item.single_item .title{
    font-size: 16px;
  }
  .pagination .nav-posts .page-next,
  .pagination .nav-posts .page-prev{
    min-width: 100px;
  }
  .pagination .nav-posts .page-next a, 
  .pagination .nav-posts .page-prev a,
  .pagination .nav-posts .page-archive a{
    padding: 10px 10px;
    font-size: 11px;
  }


  .read_more.bk a, .read_more.md a {
    font-size: 13px;
  }

  /* **********************************
   *  お問い合わせ
   * ********************************* */
  .contact_info{
    padding: 10px;
  }
  .contact_info .box1{
    font-size: 13px;
  }
  .contact_info .box2{
    margin-top: 10px;
  }
  .contact_info .box2 .icon{
    font-size: 15px;
  }
  .contact_info .box2 .tel{
    font-size: 24px;
  }
  .contact_info .box2 .txt{
    width: 100%;
    margin: 10px 0 0 0;
  }

  .contact_form th,
  .contact_form td{
    display: block;
    width: 100%;
    padding: 10px 10px;
  }
  .contact_form th{
  }
  .contact_form td{
  }
  .contact_form td [name="zipcode"]{
    width: 100px;
  }
  .contact_form dl.date dt{
    width: 100%;
  }
  .contact_form dl.date dt.wide{
    width: 100%;
  }

  .contact_form dl.date dt.m,
  .contact_form dl.date dt.d{
    width: 90px;
  }
  .contact_form dl.date dt.m select,
  .contact_form dl.date dt.d select{
    width: calc(100% - 2em);
  }
  .contact_form dl.date dt.t{
    width: calc(100% - 180px - 10px);
  }
  .contact_form dl.date dt.t select{
    width: calc(100% - 3.5em);
  }

  .contact_form_btns input[type="submit"], 
  .contact_form_btns input[type="button"],
  .contact_form_btns button  {
    width: 48%;
    margin: 0 1%;
    font-size: 12px;
  }
  .contact_form_btns input[type="submit"]{

  }
  .contact_form_btns button {
    width: 30%;
  }




  /* **********************************
   *  top
   * ********************************* */

  .pg_home .section#sec3{
    padding-top: 20px;
  }
  header .hdr1 .hdr_logo img{
    width: 100%;
  }
  .mv .mv_box .txt{
    font-size: 20px;
  }
  .home_concept_img img{
    width: 72%;
    height: 50%;
  }
  .home_concept_img:after{
    width: 70%;
    top: -3px;
    right: -7px;
    height: 100px;
    width: 68px;
  }
  .home_concept_items{
    display: block;
  }
  .home_concept_items .item{
    width: 75%;
    margin: 0 auto;
  }
  .home_concept_items .item:not(:first-child){
    border-left: none;
    border-right: none;
    border-top:1px solid #7d7d7d; 
    border-bottom: 1px solid #7d7d7d;
  }
  .home_concept_items .item:first-child{
    border-left: none;
    border-top: 1px solid #7d7d7d;
  }
  .home_concept_items .item:last-child{
    border-right: none;
    border-top: none;
    border-bottom: 1px solid #7d7d7d;
  }
  .home_concept_items .item:nth-child(n+2){
    margin-top: 20px;
  }
  .tt3.product:before{
    height: 66%;
    width: 53px;
    top: -41px;
    right: 44%;
  }
  .tt3.works:before{
    height: 72%;
    width: 48px;
    top: -41px;
    right: 46%;
  }
  .tt3.news:before{
    height: 57%;
    width: 38px;
    top: -40px;
    right: 44%;
  }
  .home_concept_wrap{
    padding: 60px 10px 0;
  }
  .home_works_wrap{
    padding: 50px 0;

  }
  .home_product_wrap{
    padding: 20px 0 38px;
  }
  .home_info_items{
    display: block;
  }
  .home_info_items .box1, .home_info_items .box2{
    width: 100%;
  }
  .home_info_items .box1 .top{
    margin-right: 0;
  }
  .home_works_wrap .home_works_items{
    display: block;
  }
  .home_works_wrap .home_works_items .item{
    width: 75%;
    margin: 0 auto;
  }
  .home_works_wrap .home_works_items .item:nth-child(n+2){
    margin-top: 20px;
  }
  .home_works_wrap .home_works_items:before{
    left: 37px;
    top: -55px;
    width: 108px;
    height: 45px;

   }
  .home_info_items .box1 .inner{
    padding: 30px 10px;
  }
  .home_info_items .box1 .top, .home_info_items .box2 .top{
    height: auto;
  }
  .action_contact_wrap .item .box1 .number{
    font-size: 23px;
    margin-right: 80px;
  }
  .action_contact_wrap .item .text span{
    font-size: 20px;
  }
  .action_contact_wrap .item .box1 .text{
    font-size: 16px;
  }
  .action_contact_wrap .item .box1 .text{
    font-size: 20px;
    margin-right: 0;
  }
  .action_contact_wrap .item .box1{
    padding: 12px;
  }
  .home_banner_items .item.insta{
    height: auto;
  }
  .action_contact_wrap .item.right .bottom .box1{
    padding: 20px 0;
  }
  .action_contact_wrap .item.right .info_contact .t1{
    font-size: 18px;
  }
  .action_contact_wrap .item.right .info_contact{
    margin-right: 68px;
  }
  .home_info_wrap{
    padding: 30px 0 0;
  }
  
  /* 商品スライダー */
  .product_slider{
    padding: 0 30px;
  }
  .product_slider .btn_prev,
  .product_slider .btn_next{
    width: 20px;
    font-size: 14px;
  }
  
  /* 商品スライダー要素 */
  .slider_product_item{

  }
  .slider_product_item .img{
    border: 5px solid #dcdcdc;
  }
  
  .home_banner_items .item{
    height: auto;
  }
  .home_info_items .box2 .inner{
    padding: 0;
  }

  /* **********************************
   *  お知らせ一覧
   * ********************************* */
  .pg_archive_news .section#sec1{
    margin-top: 100px;
    margin-bottom: 0;
  }
  .post_items:before{
    left: 45%;
  }
  .post_items .item .title,
  .post_items .item .date{
    font-size: 14px;
  }
  .pg_archive_news .post_items:before{
    height: 29px;
    width: 36px;
    top: -74px;
    left: 46%;
  }

  /* **********************************
 *  お知らせ詳細
 * ********************************* */
  .pg_single_news .section#sec1{
    margin-bottom: 0;
  }
  .post_items .item.single_item{
    padding: 18px;
  }
  .post_items .item.single_item .post_content{
    font-size: 14px;
  }
  .pagination .nav-posts .page-archive,
  .pagination .nav-posts .page-next,
  .pagination .nav-posts .page-prev{
    min-width: 110px;
  }
  .pagination .nav-posts .page-next a,
  .pagination .nav-posts .page-prev a,
  .pagination .nav-posts .page-archive a{
    width: 110px;
  }
   .pagination .nav-posts .page-archive.news,
  .pagination .nav-posts .page-next.news,
  .pagination .nav-posts .page-prev.news{
    font-size: 14px;
    min-width: 110px;
  }
  .pagination .nav-posts .page-next.news a,
  .pagination .nav-posts .page-prev.news a,
  .pagination .nav-posts .page-archive.news a{
    width: 110px;
    font-size: 14px;
  }
  .pagination .nav-posts .page-next.news a:before,
  .pagination .nav-posts .page-prev.news a:after{
    display: none;
  }

  /* **********************************
*  施工・工事
* ********************************* */
  .pg_construction{
    margin-bottom: 0;
  }
  .pg_construction .section#sec1{
    margin-top: 120px;
  }
  .pg_construction .section#sec3{
    margin-top: 90px;
  }
  .tt4.yw,
  .tt4.or{
    font-size: 16px;
  }
  .tt4.or:before{
    height: 53px;
    width: 52px;
    top: -94px;
    left: 44%;
  }
  .construction_message_wrap .text{
    text-align: left;
    margin-top: 38px;
  }
  .construction_image_wrap .items{
    display: block;
  }
  .construction_image_wrap .items .box1{
    padding: 0;
  }
  .construction_image_wrap .items .box1,
  .construction_image_wrap .items .box2{
    width: 100%;
    margin: 0 auto;
  }
  .construction_image_wrap .items .box1 .img1 img,
  .construction_image_wrap .items .box1 .img2 img{
    height: 250px;
  }
  .construction_image_wrap .items .box1 .img2 .inner{
    padding: 0 0 5px 5px;
  }
  .construction_image_wrap .items .box2 .img1 .inner img,
  .construction_image_wrap .items .box2 .img2 .inner img{
    height: 236px;
    width: 100%;
  }
  .tt4.self:before{
    left: 16%;
    height: 23px;
    width: 270px;
  }
  .construction_self_wrap:before{
    height: 57px;
    width: 31px;
  }
  .construction_self_wrap .items{
    display: block;
  }
  .construction_self_wrap .items .box1{
    width: 100%;
    margin: 0 auto;
  }
  .construction_self_wrap .items .box2{
    width: 75%;
    margin: 20px auto 0;
  }
  .construction_self_wrap .items .box1 .text{
    font-size: 14px;
    text-align: left;
    padding-right: 0;
  }

  /* **********************************
   *  暖学舎について
   * ********************************* */
  .pg_company {
    margin-bottom: 0;
  }
  .pg_company .section#sec2 {
    height: 100px;
  }
  .company_mge_wrap{
    margin-top: 135px;
  }
  .company_mge_wrap:before{
    height: 53px;
    width: 52px;
    top: -94px;
    left: 45%;
  }
  .company_mge_wrap .company_items{
    display: block;
  }
  .company_mge_wrap .company_items .box1{
    width: 75%;
    margin: 0 auto;
  }
  .company_mge_wrap .company_items .box2{
    width: 100%;
    margin-top: 100px;
  }
  .company_mge_wrap .company_items .box2 .inner{
    padding-left: 0;
  }
  .company_about_wrap .company_tbl th{
    text-align: left;
  }
  .company_about_wrap .company_tbl th,
  .company_about_wrap .company_tbl td{
    display: block;
    width: 100%;
    padding: 10px;
  }
  .about_label_wrap {

  }
  .about_info_wrap .title{
    font-size: 15px;
    text-align: left;
  }
  .about_room_items{
    display: block;
  }
  .about_room_items .box2,
  .about_room_items .box1{
    width: 75%;
    margin: 0 auto;
  }
  .about_room_items .box2 .item .inner {
    padding: 5px 0 0;
  }
  .about_room_items .box2 .item.bt .inner{
    padding: 5px 0 0;
  }
  .about_info_wrap .g_map iframe{
    height: 200px;
  }
  .show_info_tbl{
    margin-left: 10px;
  }
  .show_info_tbl th,
  .show_info_tbl td{
    display: block;
    width: 100%;
    text-align: left;
  }
  .show_info_tbl th{
    font-size: 14px;
    text-align: left;
  text-align-last: start;
  }
  .show_info_tbl td{
    font-size: 13px;
    padding-left: 0;
  }
  .show_info_tbl td:before{
    display: none;
  }
  
  /* **********************************
   *  メンテナンス
   * ********************************* */
  .pg_maintenance{
    margin-bottom: 0;
  }
  .pg_maintenance .section#sec1{
    margin-top: 125px;
  }
  .pg_maintenance .section#sec2{
    margin-top: 60px;
    padding-bottom: 16px;
  }
  .maintenance_desc_wrap .tt4.ora2{
    font-size: 18px;
  }
  .maintenance_change_wrap{
    padding-top: 20px;
  }
  .maintenance_mge_wrap:before{
    height: 37px;
    width: 56px;
    left: 45%;
  }
  .maintenance_desc_wrap{
    margin-top: 60px;
  }
  .maintenance_mge_wrap span.desc1{
    text-align: left;
  }
  .maintenance_mge_wrap span.desc2{
    text-align: left;
  }
  .maintenance_label_img{
    margin-bottom: 30px;
  }
  .maintenance_change_wrap {
    background-image: none;
  }
  .maintenance_change_wrap .items{
    display: block;
  }
  .maintenance_change_wrap .items .item.left{
    width: 100%;
    /*margin-right: 0;*/
    margin-right: auto;
  }
  .maintenance_change_wrap .items .item.left:after{
    content: "";    
    background: url(/img/maintenance/arrow_sp.png)no-repeat center / contain;
    height: 78px;
    width: 65px;
    margin: 20px auto;
    display: block;
  }
  .maintenance_change_wrap .items .item.right{
    width: 100%;
    /*margin-left: 0;*/
    margin-top: 0;
  }
  .maintenance_change_wrap .items .item.right .img,
  .maintenance_change_wrap .items .item.left .img{
    text-align: center;
  }
  .maintenance_change_wrap .items .item.left span{
    text-align: center;
    margin-top: 12px;
    /*margin-right: 0;*/
  }
  .maintenance_change_wrap .items .item.right span{
    text-align: center;
    margin-top: 12px;
    margin-left: 0;
  }
  .maintenance_image_wrap .items{
    display: block;
  }
  .maintenance_image_wrap .items .item{
    width: 75%;
    margin: 0 auto;
  }
  .maintenance_image_wrap .item:nth-child(odd) .inner{
    padding-right: 0;
  }
  .maintenance_image_wrap .item:nth-child(even) .inner{
    padding-left: 0;
  }
  .maintenance_image_wrap .item:nth-child(n+2) .inner{
    padding-top: 10px;
  }
  .maintenance_qa_wrap .items .item .flex .box1 .title,
  .maintenance_qa_wrap .items .item .flex .box1 .txt1,
  .maintenance_qa_wrap .items .item .flex .box1 .text,
  .maintenance_qa_wrap .items .item .flex .box1 .title2,
  .maintenance_qa_wrap .item.right .title,
  .maintenance_qa_wrap .item.right .txt1{
    font-size: 13px;
    padding: 16px 8px;
  }
  .maintenance_qa_wrap .items .item .flex .box1 .title:after{
    height: 60px;
    width: 39px;
    right: 27px;
    top: -3px;
  }
  .maintenance_qa_wrap .item.right .title:after{
     height: 60px;
    width: 39px;
    right: 27px;
    top: -3px;
  }
  .maintenance_qa_wrap .items .item .flex{
    display: block;
  }
  .maintenance_qa_wrap .items .item .flex .box1{
    width: 100%;
    padding-top: 5px;
  }
  .maintenance_qa_wrap .items .item .flex .box2{
    text-align: center;
  }
  .maintenance_qa_wrap .items .item .flex .box2 .img img{
    height: 250px;
  }
  .maintenance_change_wrap .items .item {
    margin: 0 auto;
  }

  /* **********************************
   *  初めての方へ
   * ********************************* */
  .pg_beginners .description{
    text-align: left;
    font-size: 14px;
  }
  .beginners_howto_wrap{
    margin-top: 70px;
  }
  .beginners_howto_wrap .tt5.title{
    padding-bottom: 16px;
    margin-left: 47px;
    padding-left: 2px;
  }
  .beginners_howto_wrap .tt5.title:before{
    height: 64px;
    width: 44px;
    left: -47px;
  }
  .beginners_howto_wrap .items .item{
    display: block;
  }
  .beginners_howto_wrap .box1{
    width: 100%;
  }
  .beginners_howto_wrap .box1 .title{
    font-size: 16px;
  }
  .beginners_howto_wrap .box1 .txt,
  .beginners_howto_wrap .box2 .txt{
    font-size: 13px;
  }
  .beginners_howto_wrap .box2 .inner{
    padding-left: 0;
  }
  .beginners_howto_wrap .box2 .inner .img{
    text-align: center;
  }
  .beginners_bg_title{
    font-size: 16px;
    padding: 24px 30px;
  }
  .beginners_flow_wrap .beginners_flow_items{
    display: block;
  }
  .beginners_flow_items .item{
    width: 100%;
  }
  .beginners_flow_items .item .inner{
    padding: 20px;
  }
  .beginners_flow_items .item .step_number{
    font-size: 16px;
  }

  .beginners_flow_items .item .img{
    width: 75%;
    margin: 20px auto;
  }
  .beginners_flow_items .item .title{
    margin-top: 16px;
  }
  .beginners_flow_items .item:nth-child(n+2){
    margin-top: 20px;
  }
  .beginners_faq_wrap .items .item .meta_title .item_q{
    width: 60px;
    font-size: 16px;
  }
  .beginners_faq_wrap .items .item .meta_title .title_q{
    width: calc(100% - 60px - 20px);
  }
  .beginners_faq_wrap .items .item .meta_title:after{
    height: 5px;
  }
  .beginners_faq_wrap .items .item .meta_title .title_q:after{
    right: 9px;
  }
  .beginners_flow_items .item .txt{
    font-size: 13px;
  }
  .beginners_faq_wrap .items .item .meta_title .title_q{
    font-size: 13px;
  }
  .beginners_faq_wrap .items .item .meta_title .title_q:after{
    right: 2px;
    font-size: 18px;
  }
 
  .beginners_faq_wrap .items .item .item_q:before{
    left: 5px;
  }
  .beginners_faq_wrap .items .item.on .item_a span{
    padding: 30px 10px;
  }
  /* **********************************
  *  施工事例
  * ********************************* */
  .pg_archive_case {
    margin-bottom: 0;
  }
  .archive_case_wrap .case_items .item {
    width: 50%;
  }
  .archive_case_wrap .case_items .item:nth-child(n+3){
    margin-top: 30px;
  }
  /* **********************************
  *  施工事例　詳細
  * ********************************* */
  pg_single_case{
    margin-bottom: 0;
  }
  .case_items .item .text_content{
    font-size: 14px;
  }
  .pagination .nav-posts .page-prev a:after{
    right: 6px;
  }
  .pagination .nav-posts .page-next a:after{
    left: 6px;
  }
  .pagination .nav-posts .page-next a:before,
  .pagination .nav-posts .page-prev a:after{
    display: none;
  }
  /* **********************************
  *  取扱商品
  * ********************************* */
  .pg_handling{
    margin-bottom: 0;
  }
  .pg_handling .section#sec1{

  }
  .pg_handling .section#sec2{
    margin-top: 40px;
  }
  .pg_handling .section#sec3{
    margin-top: 40px;
  }
  .handling_cat_items .item:nth-child(n+2) .inner{
    padding: 0 10px 40px;
  }
  .handling_cat_items .item .name,
  .handling_cat_items .item:nth-child(n+2) .name{
    width: 185px;
    padding: 10px 10px;
    top: 20%;
    left: -30px;
  }
  .handling_cat_items{
    display: block;
  }
  .handling_cat_items .item{
    width: 85%;
    margin: 0 auto;
  }
  .handling_cat_items .item .inner{
    border: none;
  }
  .handling_cat_items .item .name span{
    font-size: 14px;
  }
  
  .product_brand_items li{
    width: 50%;
  }
  
  .product_info_items {
    display: block;
  }
  .product_info_items .left {
    width: 75%;
    margin: 0 auto;
  }
  .product_info_items .right{
    width: 100%;
  }
  .handling_product_items .item{
    padding: 20px;
  }
  .handling_product_items .contact_button .read_more a {
    font-size: 13px;
    right: -8px;
    bottom: -17px;
  }

  .product_info_items .right th{
    width: 120px;
  }
  .product_info_items .right th,
  .product_info_items .right td{
    font-size: 14px;
  }
  .handling_product_items.type-b .item {
    width: 100%;
  }
  .handling_product_items.type-b .item + .item{
    margin-top: 50px;
  }

  /* **********************************
  *  お見積もり
  * ********************************* */
.quote_desc_wrap .description .text1,
.quote_desc_wrap .description .text2{
  text-align: left;
}
.quote_title,
.quote_notes{
  margin-top: 30px;
}
.quote_desc_wrap .tt4{
  font-size: 16px;
}

  /* **********************************
  *  お問い合わせ
  * ********************************* */
  .pg_contact{
    margin-bottom: 0;
  }
  .contact_info .box2 .tel{
    display: block;
  }
  .contact_info .box2 .tel .slash{
    font-size: 20px;
  }
  .contact_tab_wrap .tab_items .box1 a,
  .contact_tab_wrap .tab_items .box2 a{
    font-size: 16px;
    text-align: center;
    padding-right: 0;
  }
  .contact_form.sec2 td.file{
    display: block;
  }
  .contact_form.sec2 td.file .block{
    display: block;
    font-size: 14px;
  }
  .contact_notes{
    margin-left: 0;
  }
  .contact_title{
    margin-top: 36px;
  }
  .txt_c{
  margin: 100px auto;
  font-size: 18px;
}
.txt_c a{
  font-size: 16px;
}
  /* **********************************
*  フッター
* ********************************* */
  .pagetop{
    bottom: 100px;
  }
  .action_contact_wrap .item .box1 .text{
    font-size: 20px;
    margin-left: 0;
  }
  .action_contact_wrap .item .text span{
    font-size: 18px;
  }
  .action_contact_wrap .items{
    display: block;
  }
  .action_contact_wrap .items .item{
    width: 100%;
  }
  .action_contact_wrap .items .item:nth-child(n+2){
    margin-top: 30px;
  }
  .action_contact_wrap .item.right .box1{
    text-align: right;
    padding: 25px 40px 25px 20px;
  }
  .action_contact_wrap .box1:before{
    height: 83px;
    width: 58px;
    top: -32px;
    left: 11px;
  }
  .action_contact_wrap .items .item .info_contact.left{
    justify-content: center;
    margin-left: 20px;
      }
      .action_contact_wrap .items .item .info_contact.right .fa-envelope:before{
        font-size: 32px;
        bottom: -5px;
        left: 22%;
      }
  .action_contact_wrap .item .box1 .number{
    margin-right: 0;
    margin-left: 20px;
  }
  .action_contact_wrap .items .item.right .info_contact{
    display: block;
    width: 300px;
    margin: 0 auto;
  }
  footer{
    margin-top: 50px;
  }
  footer .ftr_links{
    display: none;
  }
  footer .fttr_bx{
    display: block;
    padding: 20px 0;
  }
  footer .box2{
    width: 100%;
    margin-top: 0;
  }
  footer .ftr_addr{
    text-align: center;
  }
  footer .fttr_bx .box3{
    margin-top: 16px;
  }
  footer .fttr_bx .box3 .fttr_info{
    margin-top: 16px;
  }
  footer .fttr_bx .box3 .box4 .fttr_contact{
    justify-content: center;
  }
  footer .fttr_bx .box3 .box4 .site_map{
    justify-content: center;
  }
  footer .fttr_bx .box3 .box4 .site_map:after{
    right: 0;
  }
　.footer_fix .fa-envelope:before{
    margin-right: 0;
  }

  /* **********************************
 *  サイトマップ
 * ********************************* */
  .pg_sitemap{
    margin-bottom: 0
  }
  .sitemap_items .item{
    width: 50%;
  }
  .sitemap_items .item:nth-child(n+3){
    margin-top: 20px;
  }
  /* **********************************
   *  プライバシーポリシー
   * ********************************* */
  .privacy_tt{
    font-size: 18px;
  }
  .privacy_tt br{
    display: inline;
  }
  .privacy_items .item h4{
    font-size: 15px;
  }
  

}
@media only screen and (max-width:380px){
  
   /* **********************************
 *  TOP
 * ********************************* */
  
  .home_product_wrap .tt3.product:before{
    right: 43%;
  }
  /* **********************************
 *  施工・工事
 * ********************************* */
  .tt4.self:before{
    left: 10%;
  }
  
  /* **********************************
*  暖学舎について
* ********************************* */
  .about_info_wrap .title{
    font-size: 13px;
  }
  .about_addres_wrap .box{
    font-size: 13px;
  }
  /* **********************************
  *  取扱商品
  * ********************************* */
  .handling_bland_items .item{
    width: 50%;
  }
  .handling_bland_items .item:nth-child(n+3){
    margin-top: 10px;
  }
  
  
  /* **********************************
  *  初めての方へ
  * ********************************* */
  .beginners_faq_wrap .items .item .item_q:before{
    left: 0;
  }
  
  
  
  /* **********************************
  *  メンテナンス
  * ********************************* */
  .maintenance_mge_wrap:before{
    left: 43%;
  }
  .maintenance_change_wrap .items .item.left:after{
    left: 43%;
  }
  .maintenance_qa_wrap .items .item .flex .box1 .text:after{
    left: 40%;
  }
  .maintenance_qa_wrap .items .item .flex .box1 .title:after,
  .maintenance_qa_wrap .item.right .title:after{
    height: 60px;
    width: 39px;
    right: 27px;
    top: -3px;
  }
  
  
  /* **********************************
  *  フッター
  * ********************************* */
  .fa-envelope:before{
    margin-right: 0;
  }
  footer .fttr_bx .box3 .box4 .fttr_contact{
    width: 100%;
    margin-top: 20px;
  }
  footer .fttr_bx .box3 .box4 .fttr_contact a.btn3{
    width: 200px;
  }
  .action_contact_wrap .items .item .info_contact.left{
    justify-content: flex-end;
    margin-left: 0;
  }
  .action_contact_wrap .item.right .box1 {
    text-align: right;
    padding: 15px 12px 20px 20px;
}
.action_contact_wrap .items .item.right .info_contact{
  margin-left: 0;
}
.action_contact_wrap .item .text .ttt1 .fa-envelope:before{
  font-size: 24px;
  bottom: -5%;
  left: 26%;
}
footer .fttr_bx .box3 .box4{
  display: block;
}
footer .fttr_bx .box3 .box4 .site_map{
  width: 100%;
  }
  footer .fttr_bx .box3 .box4 .site_map span{
    padding-right: 0;
  }
footer .fttr_bx .box3 .box4 .site_map:after{
  display: none;
}
.footer_fix .fa-envelope:before{
    margin-right: 0px;
  }
 }
@media only screen and (max-width:359px){
  .footer_fix ul{
    font-size: 12px;
  }
  .footer_fix .fa-envelope:before{
    margin-right: 0px;
  }
  .beginners_faq_wrap .items .item .meta_title .item_q{
    width: 50px;
  }
  .beginners_faq_wrap .items .item .meta_title .title_q{
    width: calc(100% - 50px);
  }
  .beginners_faq_wrap .items .item .meta_title:after{
    height: 4px;
  }
  .action_contact_wrap .item .text span{
    font-size: 14px
  }
  .action_contact_wrap .item .box1 .number{
    margin-left: 10px
  }
  .action_contact_wrap .items .item.right .info_contact{
    width: auto;
  }
  .action_contact_wrap .item .text .ttt1 .fa-envelope:before{
    left: 85px;
  }
}