@charset "utf-8";

/*---------------------------------------------
---------------------------------------------
 トップページCSS
---------------------------------------------
---------------------------------------------*/

#container {
  overflow: hidden;
}


/*---------------------------------------------
 HEADER
---------------------------------------------*/

@media screen and (min-width: 768px) {

  #header {
    width: 100%;
    height: 807px;
  }

  #headertop {
    position: relative;
    width: 960px;
    height: 103px;
    padding-left: 20px;
    padding-right: 20px;
    margin: 0 auto;
  }

  #header h1 {
    position: absolute;
    top: 22px;
    left: 20px;
    width: 330px;
    height: 60px;
  }

  #header h1>a {
    display: block;
    width: auto;
    height: 100%;
    color: #fff;
    background-image: url(/img/common/logo/logo-top-en.png);
    background-size: 293px;
    background-repeat: no-repeat;
  }

  #header h1 span {
    background: #63c7f2;
  }

  #header h1>a>img {
    display: none;
  }

  #tnav {
    position: absolute;
    top: 20px;
    right: 23px;
  }

  #tnav li {}

  #tnav li a {
    color: #fff;
  }

  #tnav li a:before {
    height: 18px;
  }

  #tnav li#tnav_english a:before {
    background: url(/img/top/btn_tnav_english.png) no-repeat 0 0, url(/img/top/btn_tnav_english_o.png) no-repeat 100px 100px;
  }

  #tnav li#tnav_english a:hover:before {
    background-image: url(/img/top/btn_tnav_english_o.png);
  }

  #tnav li#tnav_news a:before {
    background: url(/img/top/btn_tnav_news.png) no-repeat 0 0, url(/img/top/btn_tnav_news_o.png) no-repeat 100px 100px;
  }

  #tnav li#tnav_news a:hover:before {
    background-image: url(/img/top/btn_tnav_news_o.png);
  }

  #tnav li#tnav_sitemap a:before {
    background: url(/img/top/btn_tnav_sitemap.png) no-repeat 0 1px, url(/img/top/btn_tnav_sitemap_o.png) no-repeat 100px 100px;
  }

  #tnav li#tnav_sitemap a:hover:before {
    background-image: url(/img/top/btn_tnav_sitemap_o.png);
  }

  #tnav li#tnav_contact a:before {
    background: url(/img/top/btn_tnav_contact.png) no-repeat 0 2px, url(/img/top/btn_tnav_contact_o.png) no-repeat 100px 100px;
  }

  #tnav li#tnav_contact a:hover:before {
    background-image: url(/img/top/btn_tnav_contact_o.png);
  }

}


/* BUSINESS MAP
---------------------------------------------*/

.businessMap {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 0;
  width: 960px;
  height: 790px;
  margin-right: auto;
  margin-left: auto;
}

.businessMapInner {
  position: absolute;
  top: 0;
  left: -400px;
  width: 1800px;
  margin: 0 auto;
}

.businessMap a,
.businessMap-main area {
  outline: none;
}

.businessMap a,
.businessMap img {
  display: block;
}

.businessMap .businessMap-cover,
.businessMap .businessMap-cover-button,
.businessMap .businessMap-main {
  position: absolute;
  top: 0;
  left: 0;
}

.businessMap .businessMap-cover-button {
  z-index: 1;
}

.businessMap .businessMap-cover-button .button {
  position: absolute;
  top: 205px;
  left: 844px;
}

.businessMap .businessMap-main {
  display: none;
}

.businessMap .businessMap-main .protectCover {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.businessMap .businessMap-main .button {
  position: absolute;
  top: 700px;
  left: 769px;
}

.businessMap .businessMap-main .balloons>div {
  position: absolute;
  z-index: 1;
}

.businessMap .businessMap-main .balloons>div a,
.businessMap .businessMap-main .balloons>div a img {
  position: absolute;
}

.businessMap .businessMap-main .balloons .balloon1 {
  top: 273px;
  left: 1053px;
}

.businessMap .businessMap-main .balloons .balloon2 {
  top: 386px;
  left: 681px;
}

.businessMap .businessMap-main .balloons .balloon3 {
  top: 358px;
  left: 455px;
}

.businessMap .businessMap-main .balloons .balloon4 {
  top: 402px;
  left: 270px;
}

.businessMap .businessMap-main .balloons .balloon5 {
  top: 223px;
  left: 379px;
}

.businessMap .businessMap-main .balloons .balloon6 {
  top: 181px;
  left: 698px;
}

.businessMap .businessMap-main .balloons .balloon7 {
  top: 217px;
  left: 1199px;
}

.businessMap .businessMap-main .balloons .balloon8 {
  top: 160px;
  left: 925px;
}

.businessMap .businessMap-main .balloons .balloon9 {
  top: 250px;
  left: 570px;
}

.businessMap .businessMap-main .balloons .balloon10 {
  top: 218px;
  left: 1326px;
}

.businessMap .businessMap-main .balloons .balloon11 {
  top: 439px;
  left: 1256px;
}

.businessMap .businessMap-main .balloons .balloon12 {
  top: 494px;
  left: 1080px;
}

.businessMap .businessMap-main .balloons .balloon13 {
  top: 340px;
  left: 1143px;
}

.businessMap .businessMap-clouds>div {
  position: absolute;
}

.businessMap .businessMap-clouds .cloud1 {
  top: 208px;
  left: 146px;
}

.businessMap .businessMap-clouds .cloud2 {
  top: 240px;
  left: 479px;
}

.businessMap .businessMap-clouds .cloud3 {
  top: 226px;
  left: 1150px;
}

.businessMap .businessMap-clouds .cloud4 {
  top: 183px;
  left: 1427px;
}

.businessMap .businessMap-clouds .cloud5 {
  top: 229px;
  left: 1620px;
}

.businessNav {
  display: none;
}


/* GLOBAL NAVI
---------------------------------------------*/

@media screen and (min-width: 768px) {

  #gnav_wrap {
    padding-top: 5px;
    border-top-width: 0;
    border-bottom-width: 0;
  }

  #gnavi>li>p>a:after {
    color: #fff;
  }


  #gnavi {
    width: 958px;
    padding: 0 21px;
    margin: 0 auto;
  }

  #gnavi li {}

  #gnavi li a,
  #gnavi>li>a:after {
    color: #fff !important;
  }

  #gnavi>li>a,
  #gnavi>li>p>a {
    padding-top: 0;
  }

  #gnavi>li>p>a #gnavi>li>p>a #gnavi>li>a:hover {
    color: #333 !important;
  }

  #gnavi>li>p>a:hover:after {
    color: #ff7f00 !important;
  }

  #gnavi>li>p>a {
    height: 38px;
    padding-top: 7px;
  }

  #gnavi>li>p>a:hover {
    color: #666 !important;
  }

  #gnavi>li>p>a:hover:after {
    color: #ff7f00 !important;
  }

  #gnavi>li:before {
    top: 0;
    bottom: 14px;
    border-color: #fff;
  }

  #gnavi>li:after {
    top: -7px;
    bottom: 8px;
    background: rgba(255, 255, 255, .5);
  }

  #gnavi li#gnav_recruit a {
    background-image: url(/img/common/btn_gnav_blank_white.png) !important;
    background-position: 153px 10px !important;
  }

  #gnavi li#gnav_recruit a:hover {
    background-image: url(/img/top/btn_gnav_recruit_o.png);
  }

  #gnavi li ul li a,
  #gnavi li ul li ul li a {
    color: #333 !important;
  }

  #gnavi li ul li a:hover,
  #gnavi li ul li ul li a:hover {
    color: #fff !important;
  }

  #gnavi li ul li ul {
    margin-left: -1px;
  }
}

/*---------------------------------------------
 CONTENTS
---------------------------------------------*/


/* コンテンツ
---------------------------------------------*/

#contents {
  padding-top: 46px;
  padding-bottom: 80px;
}



/* 施工動画
---------------------------------------------*/

#movie_box {
  width: 700px;
}

#movie_box ul {
  overflow: hidden;
  width: 700px;
  padding-top: 30px;
}

#movie_box ul {
  position: relative;
  width: 720px;
}

#movie_box ul li {
  float: left;
  width: 220px;
  margin-right: 20px;
}

#movie_box ul li dl dt {
  width: 220px;
  margin-right: 20px;
}

#movie_box ul li dl dd {
  width: 220px;
  font-weight: bold;
  text-align: center;
  margin-top: 7px;
}



/* ニュースリリース
---------------------------------------------*/

#news_listbox {
  position: relative;
  width: 700px;
}

#news_listbox dl {
  overflow: hidden;
  width: 700px;
  font-size: 1.083em;
  padding-top: 20px;
}

#news_listbox dl dt {
  width: 113px;
  float: left;
  clear: both;
  padding: 18px 0 15px 5px;
}

#news_listbox dl dd {
  padding: 18px 0 15px 118px;
  border-bottom: 1px dotted #ccc;
}

#news_listbox dl dd:last-child {
  border-bottom: none;
}

/* 一覧ボタン */
.list_btn {
  z-index: 1;
  position: absolute;
  top: 10px;
  right: 9px;
  width: 65px;
  height: 20px;
  padding: 0;
}



/* 文字サイズ変更（サイド）トップのみ
---------------------------------------------*/

#text_size_side {
  position: relative;
  width: 214px;
  height: 36px;
  margin-bottom: 18px;
  border: 3px solid #ddd;
  background-color: #F8F8F8;
}

#text_size_side h2 {
  position: absolute;
  top: 12px;
  left: 9px;
  width: 100px;
  height: 30px;
  color: #3E3E3E;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.2em;
  letter-spacing: 0;
  text-shadow: 1px 1px 1px #fff;
  padding: 0;
  background: none;
}




/* トップバナーエリア
---------------------------------------------*/

.topbnr_area {
  margin-top: -20px;
  padding-bottom: 50px;
}




@media screen and (max-width: 768px) {

  /* =============================================================

      Mobile - Base Setting

  ============================================================= */

  /* コンテンツ
  ---------------------------------------------*/

  #contents {
    padding-top: 46px;
    padding-bottom: 10px;
  }

  #text_size_side {
    display: none;
  }

  /*  Header Setting
  --------------------------------------------- */

  #header {
    background: #63c7f2;
  }

  /* -------- Site Logo -------- */

  #header h1 a {
    background-image: url(/img/common/logo/logo-top-en.png);
    color: #fff;
  }

  #header h1 span {
    background: #63c7f2;
  }

  #sitemenu #menu_btn span {
    background-color: #fff;
  }


  /* BUSINESS MAP
  ---------------------------------------------*/

  .businessMap {
    display: none;
  }

  .businessMap * {
    display: none;
  }

  .topbnr_area {
    margin: 0 0 30vw;
    padding: 0;
  }

  .topbnr_area img {
    width: 100%;
  }

  .businessNav {
    position: relative;
    display: block;
    margin: 0 0 10vw;
    font-size: .9em;
  }

  .businessNav:before {
    position: absolute;
    top: -95vw;
    right: -20px;
    left: -20px;
    bottom: 25px;
    z-index: -1;
    background: url(/img/top/business_map_sp.png) no-repeat top center;
    background-size: 100%;
    content: "";
  }

  .businessNav dl {
    display: block;
    border-top: 4px solid #ff7f00;
    font-size: 1.7em;
    font-weight: bold;
    background: #f8f7f2;
  }

  .businessNav a {
    text-decoration: none;
  }

  .businessNav dt {
    display: block;
    position: relative;
    padding: 20px 60px 20px 15px;
    font-size: .95em;
    font-weight: bold;
  }

  .businessNav dt:before {
    transition: border .2s ease-in-out;
    transform: rotate(135deg);
    position: absolute;
    top: 18px;
    right: 30px;
    width: 12px;
    height: 12px;
    border-width: 2px 2px 0 0;
    border-color: #000 #000 transparent transparent;
    border-style: solid;
    content: "";
  }

  .businessNav.active dt:before {
    transform: rotate(-45deg);
    top: 26px;
  }

  .businessNav dd {
    display: none;
  }

  .businessNav ul {
    padding: 0 15px 15px;
  }

  .businessNav li {
    padding-top: 8px;
    font-size: .9em;
  }

  .businessNav li a {
    display: table-cell;
    position: relative;
    width : -webkit-calc(100vw - 70px);
    width : calc(100vw - 70px);
    height: 54px;
    padding: 8px 40px 8px 65px;
    background: #fff;
    font-size: .9em;
    vertical-align: middle;
  }

  .businessNav li a span {
    position: absolute;
    top: 50%;
    left: 8px;
    display: inline-block;
    width: 38px;
    margin-top: -19px;
    margin-right: 10px;
    vertical-align: middle;
  }

  .businessNav li a:before {
    transition: border .2s ease-in-out;
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    right: 20px;
    width: 12px;
    height: 12px;
    margin-top: -6px;
    border-width: 2px 2px 0 0;
    border-color: #ff7f00 #ff7f00 transparent transparent;
    border-style: solid;
    content: "";
  }

  .businessNav .btnList {
    padding: 15px 15px 25px;
    border-bottom: 4px solid #ff7f00;
  }

  .businessNav .btnList a {
    display: block;
    width: 240px;
    max-width: 100%;
    margin: 0 auto;
    padding: 12px 30px;
    border: none;
    text-align: center;
    text-shadow: none;
    font-size: 13px;
  }

  .businessNav .btn_defalut:before {
    display: none;
  }

  .businessNav .btn_defalut:after {
    left: 20px;
    border-width: 5px 7px;
    margin-top: -6px;
  }


  /* ニュースリリース
  ---------------------------------------------*/

  #news_listbox {
    width: 100%;
    margin-bottom: 0;
  }

  .list_btn {
    top: 15px;
  }

  #news_listbox dl {
    width: 100%;
    padding-top: 5px;
  }

  #news_listbox dl dt {
    width: 100px;
    letter-spacing: 0;
  }

  #news_listbox dl dd {
    padding-left: 100px;
  }


}
