@charset "UTF-8";
/*------------------------------------------------------------
ページヘッダー
------------------------------------------------------------*/
#page_header h1 { background-image: url("../images/header/bgimg_header-company.jpg"); }

/*------------------------------------------------------------
トップメッセージ
------------------------------------------------------------*/
#top_message { overflow: hidden; }

#top_message h2 { font-size: 2.6rem; line-height: 1.5; text-align: center; margin-bottom: 50px; }

#top_message figure { float: left; width: 220px; }

#top_message p { margin: 30px 0 0 220px; }

#top_message p.sign { text-align: right; margin-top: 66px; }

@media screen and (max-width: 767px) { #top_message h2 { font-size: 1.6rem; margin-bottom: 25px; }
  #top_message figure { float: none; width: auto; text-align: center; }
  #top_message p { margin: 15px 0 0 0; }
  #top_message p.sign { text-align: right; margin-top: 40px; } }

/*------------------------------------------------------------
企業理念
------------------------------------------------------------*/
#philisophy { padding-top: 150px; }

#philisophy h2 { text-align: center; }

#philisophy h2 img { max-width: 100%; height: auto; }

@media screen and (max-width: 767px) { #philisophy { padding-top: 25px; } }

/*------------------------------------------------------------
会社概要
------------------------------------------------------------*/
#about table { width: 100%; border: 1px solid #ddd; margin: 0 auto; }

#about table th { border: 1px solid #ddd; padding: 20px 25px; font-weight: normal; text-align: left; background: #F8F8F8; }

#about table td { border: 1px solid #ddd; padding: 20px 25px; }

#about table td a { color: #0285d0; }

#about table td a:hover { text-decoration: none; }

#about table td a.map { display: block; background: url("../images/common/ico_map.svg") no-repeat left 4px; background-size: auto 18px; padding-left: 20px; }

#about table td > dl > dt { font-weight: bold; }

#about table td > dl > dd dl { display: -webkit-box; display: -ms-flexbox; display: flex; }

#about table td > dl > dd dl dt { width: 140px; }

#about table td > dl > dd dl dd { width: calc(100% - 140px); }

#about table td > dl + dl { margin-top: 20px; }

#cm { margin-top: 100px; }

#cm h2 { font-size: 2.4rem; padding-bottom: 5px; border-bottom: 2px solid #ecf6fc; margin-top: 80px; position: relative; }

#cm h2:after { display: block; content: ""; width: 140px; height: 2px; background: #0285d0; position: absolute; bottom: -2px; left: 0; }

#cm h2:nth-of-type(1) { margin-top: 0; }

#cm ul { margin-top: 30px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }

#cm ul li { margin-top: 20px; width: calc(50% - 10px); position: relative; padding-bottom: calc(56.25% / 2); height: 0; overflow: hidden; }

#cm ul li:nth-child(-n + 2) { margin-top: 0; }

#cm ul li iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

@media screen and (max-width: 767px) { #about table { display: block; border: none; margin: 20px auto; }
  #about table thead, #about table tbody, #about table tfoot, #about table tr, #about table th, #about table td { display: block; }
  #about table th { border: none; padding: 10px 15px; }
  #about table td { border: none; padding: 10px 15px; }
  #about table td a.map { background-size: auto 14px; padding-left: 15px; }
  #about table td > dl > dd dl { display: block; margin-top: 5px; }
  #about table td > dl > dd dl dt { width: auto; }
  #about table td > dl > dd dl dd { width: auto; }
  #about table td > dl + dl { margin-top: 10px; }
  #cm { margin-top: 50px; }
  #cm h2 { font-size: 1.6rem; border-bottom: 1px solid #ecf6fc; margin-top: 40px; }
  #cm h2:after { width: 70px; height: 1px; bottom: -1px; }
  #cm ul { margin-top: 15px; display: block; }
  #cm ul li { margin-top: 15px; width: auto; padding-bottom: 56.25%; }
  #cm ul li:nth-child(2) { margin-top: 15px; } }

/*------------------------------------------------------------
沿革
------------------------------------------------------------*/
#history_flow ul { border-left: 1px solid #aaa; padding-bottom: 30px; }

#history_flow ul li { font-size: 4.0rem; line-height: 1; color: #909090; padding-left: 30px; margin-top: 80px; position: relative; }

#history_flow ul li:after { display: block; content: ""; width: 100%; height: 1px; background: #aaa; position: absolute; top: 50px; left: 0; }

#history_flow ul li:first-child { margin-top: 0; }

#history_flow ul li dl { font-size: 1.6rem; color: #222; line-height: 1.7; margin-top: 10px; overflow: hidden; }

#history_flow ul li dl:nth-of-type(1) { margin-top: 25px; }

#history_flow ul li dl dt { float: left; width: 35px; text-align: right; }

#history_flow ul li dl dd { margin-left: 60px; }

#history_flow ul li figure { margin-top: 15px; }

#history_flow ul li figure img { margin-right: 1px; }

@media screen and (max-width: 767px) { #history_flow ul li { font-size: 2.4rem; padding-left: 15px; margin-top: 40px; }
  #history_flow ul li:after { top: 32px; }
  #history_flow ul li dl { font-size: 1.3rem; line-height: 1.7; }
  #history_flow ul li dl:nth-of-type(1) { margin-top: 20px; }
  #history_flow ul li dl dt { width: 30px; }
  #history_flow ul li dl dd { margin-left: 40px; }
  #history_flow ul li figure { margin-top: 10px; }
  #history_flow ul li figure img { width: auto; height: 100px; }
  #history_flow ul li figure img.tall { height: 140px; } }

/*------------------------------------------------------------
設備、許可・認可・特許共通
------------------------------------------------------------*/
#facility h2, #approval h2 { font-size: 2.4rem; padding-bottom: 5px; border-bottom: 2px solid #ecf6fc; margin-top: 80px; position: relative; }

#facility h2:after, #approval h2:after { display: block; content: ""; width: 140px; height: 2px; background: #0285d0; position: absolute; bottom: -2px; left: 0; }

#facility h2:nth-of-type(1), #approval h2:nth-of-type(1) { margin-top: 0; }

#facility p, #approval p { margin-top: 40px; }

#facility table, #approval table { width: 100%; border: 1px solid #ddd; margin: 30px auto 0; }

#facility table caption, #approval table caption { text-align: left; margin-bottom: 5px; padding-left: 12px; position: relative; }

#facility table caption:before, #approval table caption:before { display: block; content: ''; width: 6px; height: 6px; background: #0285d0; border-radius: 100%; position: absolute; top: 10px; left: 0; }

#facility table caption small, #approval table caption small { font-size: 1.4rem; }

#facility table th, #approval table th { font-size: 1.4rem; border: 1px solid #ddd; padding: 10px 0; font-weight: normal; text-align: center; background: #F8F8F8; }

#facility table td, #approval table td { font-size: 1.4rem; border: 1px solid #ddd; width: 40%; padding: 10px 15px; }

#facility table td a, #approval table td a { color: #0285d0; }

#facility table td a:hover, #approval table td a:hover { text-decoration: none; }

#facility table td:nth-last-of-type(1), #approval table td:nth-last-of-type(1) { width: 20%; text-align: right; }

#facility table.half td, #approval table.half td { width: 50%; }

#facility table.half td:nth-last-of-type(1), #approval table.half td:nth-last-of-type(1) { text-align: left; }

#approval table td:nth-last-of-type(1) { text-align: left; }

@media screen and (max-width: 767px) { #facility h2, #approval h2 { font-size: 1.6rem; border-bottom: 1px solid #ecf6fc; margin-top: 40px; }
  #facility h2:after, #approval h2:after { width: 70px; height: 1px; bottom: -1px; }
  #facility p, #approval p { margin-top: 20px; }
  #facility table, #approval table { margin: 20px auto 0; }
  #facility table caption, #approval table caption { margin-bottom: 3px; padding-left: 12px; }
  #facility table caption:before, #approval table caption:before { top: 7px; }
  #facility table caption small, #approval table caption small { font-size: 1.1rem; }
  #facility table th, #approval table th { font-size: 1.1rem; padding: 5px 0; }
  #facility table td, #approval table td { font-size: 1.2rem; padding: 5px 10px; }
  #facility table td:nth-last-of-type(1), #approval table td:nth-last-of-type(1) { white-space: nowrap; }
  #facility table.half td, #approval table.half td { width: auto; } }

/*# sourceMappingURL=company.css.map */