@charset "utf-8";

/* 株式会社 東北産業サービスWEBサイト スタイル
last edit: 2022.10.3
*/

/*----------------------------------------------------------
/* リセット・基本定義
-----------------------------------------------------------*/
/***フォント ***/
html {
  font-size: 10px;
  /* initial 10px */
}

body {
  font-family: "Yu Gothic Medium", "游ゴシック Medium", "Yu Gothic", YuGothic, "游ゴシック体", "ヒラギノ角ゴシック Pro",
    "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.6rem;
  /* default font-size 16px */
}
/* body */
body {
  margin: 0;
  font-weight: 400;
  line-height: 1.5;
  color: #4c4c4c;
  background-color: #ededed;
}

/*** 太字処置／サービスメニュー、DPF ***/
.page-service,
.page-dpf{
  font-weight: bold;
}



/* 要素 */
div,ul,li,p,span,a{
  box-sizing: border-box;
}

/* 段落 */
p {
  margin: 0.2em 0 1em 0;
}

p:empty {
  display: none !important;
}

/* アンカー */
a,
a:link,
a:visited {
  text-decoration: none;
  color: #333;
}

a:active,
a:hover {
  text-decoration: none;
}

.hov-dk {
  opacity: 0.7;
  transition: all .2s ease-out;
}

.hov-dk:hover {
  opacity: 1;
}

.hov-thin {
  opacity: 1;
  transition: all .2s ease-out;
}

.hov-thin:hover {
  opacity: 0.7;
}

/* ページのみリストスタイルリセット */
ul,
ul li,
ol,
ol li {
  list-style: none;
  margin: 0;
  padding: 0;
}

img{
  vertical-align: top;
  max-width: 100%;
  height:auto;
}

.img-block{
  display: block;
}

.img-inline-block{
  display: inline-block;
}


/*** 汎用クラス ***/
.mb10 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.indent1 {
  padding-left: 1em;
  text-indent: -1em;
}

@media screen and (max-width: 767px) {}

@media print,
(min-width: 768px) {}



/*--------------------------------------------------
/* 包含
----------------------------------------------------*/
.common-content{
  margin: 0 auto 30px;
  width:100%;
}



sample-source{
  box-shadow: 0px 8px 16px -2px rgba(38, 76, 160, 0.1), 0px 10px 7px -14px rgba(38, 76, 160, 0.2);

  background: rgba(38, 76, 160, 0.6);

  transition: all .3s ease;

  transform: rotate(45deg);
  background: linear-gradient(to bottom, #0068b7 0%, #00479d 100%);
}





/*--------------------------------------------------
/* ヘッダー
----------------------------------------------------*/
header{
  box-sizing: border-box;
  position: relative;
  margin: 0 auto 0;
  padding:15px 15px;
  width:100%;
  background-color: #fff;
}
header .hd-inner{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 10px;
  max-width: 1200px;
}
.hd-inner h1{
  margin: 0;
  text-align: center;
  font-size:2rem;
  font-weight: bold;
  color:#122c5f;
}
.hd-inner h1 span{
  display: block;
  margin: 0 0 10px 0;
}
.hd-inner h1 a{
  display: block;
}

/* GL */
.site-navi-wrap{
  margin: 0 auto 0;
  width:100%;
  max-width: 1200px;
}
.site-navi-wrap ul{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin: 0 auto 0;
  padding:8px 0 8px 0;
  width:100%;
  max-width: 1200px;
  background-color: #ededed;
}
.site-navi-wrap ul > li{
  padding:0 10px;
}
.site-navi-wrap ul > li:nth-of-type(n+2){
  border-left: solid 1px #fff;
}
.site-navi-wrap ul > li > a{
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  padding:10px 10px 8px 10px;
  transition: all .2s ease-out;
  font-weight: bold;
  border-radius: 4px;
  border-bottom: solid 2px #ededed !important;
}
.site-navi-wrap ul > li > a:hover{
  color:#fff;
  background-color: #122c5f;
  border-bottom: solid 2px #122c5f !important;
}

/* ナビカレント表示 */
.page-info .site-navi-wrap ul > li:nth-of-type(1) a,
.page-service .site-navi-wrap ul > li:nth-of-type(2) a,
.page-dpf .site-navi-wrap ul > li:nth-of-type(3) a,
.page-price .site-navi-wrap ul > li:nth-of-type(4) a,
.page-eco21 .site-navi-wrap ul > li:nth-of-type(5) a,
.page-access .site-navi-wrap ul > li:nth-of-type(6) a{
  border-bottom: solid 2px #aaa;
}

@media screen and (max-width: 767px) {}

@media print,
(min-width: 768px) {}


/*--------------------------------------------------
/* ページ見出し
----------------------------------------------------*/
h2{
  margin: 0 auto 0;
  padding:20px 60px;
  text-align: center;
  font-size:2.6rem;
  color:#fff;
  background-color: #122c5f;
}
h2 > span{
  display: inline-block;
  margin-left: 20px;
  font-size:1.8rem;
  color:#f79410;
}

h3{
  margin: 0 auto 20px;
  padding:0 0 6px 0;
  font-size:2.2rem;
  font-weight: bold;
  color:#122c5f;
  border-bottom: solid 2px #122c5f;
}




/*--------------------------------------------------
/* ページ基本
----------------------------------------------------*/
/* 包含 */
.common-content > table{
  margin: 0 auto 0;
  padding:40px 0;
  background-color: #fff;
}

/* テーブル枠制御 */
.common-content table{
  width:100%;
  max-width:1200px;
}


/*** サービスメニュー ***/
.font30{
  margin: 0 0 8px 0;
  color:#9F0000;
}

/*** 料金表・エコアクション21 ***/
/* 表 */
.eco21-hyou{
  width: 100% !important;
}

.price-hyou tr td,
.eco21-hyou tr td{
  padding:8px 10px !important;
  vertical-align: middle !important;
}
.price-hyou tr td p,
.eco21-hyou tr td p{
  margin: 0 !important;
}

/*** クーポン ***/
.ticket-box{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 20px;
  padding:0 15px;
  width: 80%;
  max-width: 800px;
}
.ticket-box > div{
  width:45%;
  text-align: center;
}

@media screen and (max-width: 767px) {}

@media print,
(min-width: 768px) {}


/*--------------------------------------------------
/* DPFページ 2022.8改編
/* 2022.10.3更新
----------------------------------------------------*/
/* 包含 */
.page-dpf .dpf-content{
  margin: 0 auto 0;
  padding-bottom: 40px;
  width:100%;
  max-width:1200px;
  background-color: #fff;
}

.dpf-content > div{
  margin: 0 auto 0;
  width:100%;
  max-width:1050px;
}
.dpf-content > div:nth-of-type(n+2){
  margin-top: 60px;
}

/* 見出し */
.dpf-content h3{
  margin: 0 auto 30px;
  padding:12px 0;
  text-align: center;
  font-size:2.8rem;
  font-weight: bold;
  color:#fff;
  border:none
}
.dpf-content .blue-bg{
  background-color: #007194;
}
.dpf-content .purple-bg{
  background-color: #32003f;
}
.dpf-content .navy-bg{
  background-color: #002b55;
}
.dpf-content .black-bg{
  background-color: #000;
}

/* 強調アンダーライン */
.under-line{
  position: relative;
  display: inline-block;
  font-weight: bold;
  color:#000;
  z-index:1;
}
.under-line::after{
  position: absolute;
  content:'';
  bottom:0;
  left:0;
  width:100%;
  height:10px;
  z-index:-1;
}
.under-line.green::after{
  background-color: #26da1b;
}
.under-line.blue::after{
  background-color: #2df0ff;
}
.under-line.red::after{
  background-color: #ec2c1b;
}
.under-line.orange::after{
  background-color: #ff941a;
}

/*** 導入 ***/
/* メインビジュアル */
.dpf-mainvisual{
  margin: 0 auto 0;
  width:100%;
  max-width:1200px;
}
.dpf-content .main-intro{
  margin: 0 auto 40px;
  padding:20px 0 15px 0;
  width:100%;
  max-width:1050px;
  line-height: 1.3;
  font-size:2.2rem;
  font-weight: bold;
  color:#0c52f7;
  border-bottom: solid 2px #0c52f7;
}


.intro-catch{
  margin: 0;
  padding: 20px 15px;
  text-align: center;
  font-size:2.2rem;
  font-weight: bold;
  color:#000;
}

/*** 安心サービス ***/
.service-3{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; 
  margin: 0 auto 0;
}
.service-3 > div{
  display: flex;
  flex-wrap: wrap;
  flex-direction:column;
  justify-content: flex-start; 
  margin: 0 auto 0;
  width:30%;
}
.service-3 .upper-box .md{
  margin: 0 0 16px 0;
  line-height: 1.3;
  text-align: center;
  letter-spacing: -0.05em;
  font-size:1.8rem;
  font-weight: bold;
  color:#000;
}
.upper-box ul > li{
  text-indent:-1em;
  padding-left:1em;
}
.upper-box ul > li:nth-of-type(n+2){
  margin-top: 8px;
}

.service-3 > div img{
  display: block;
  margin: 15px auto 0;
}

/* 一番下の情報 */
.service-3 .service-box .btm-info{
  margin-top: 15px;
  font-size:1.8rem;
}



/*** トラブル ***/
/* ケース紹介 */
.trouble-case{
  margin: 0 auto 30px;
  padding:20px;
  width:80%;
  border:solid 2px #32003f;
}
.trouble-case > li{
  text-indent: -1em;
  padding-left: 1em;
  line-height: 1.2;
  font-size:2rem;
  font-weight: bold;
  color: #32003f;
}
.trouble-case > li:nth-of-type(n+2){
  margin-top: 8px;
}

/*** 洗浄ワークフロー ***/
/* 見出し */
.cleaning-flow-brock h4{
  margin: 0 auto 20px;
  padding:4px;
  text-align: center;
  width:25%;
  font-size:2.3rem;
  color:#fff;
  background-color: #002b55;
  border-radius: 10px;
}

/* フロー */
.cleaning-flow{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto 30px;
  width:100%;
}
.cleaning-flow > li{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width:32%;
  border:solid 1px #000;
}
.cleaning-flow > li:nth-of-type(n+4){
  margin-top: 20px;
}
.cleaning-flow > li .explanation{
  position: relative;
  display: flex;
  width:55%;
}
.cleaning-flow > li .explanation span{
  position: absolute;
  top:0;
  left:0;
  display: block;
  padding: 0 10px;
  text-align: center;
  font-size:2.2rem;
  font-weight: bold;
  color:#fff;
  background-color: #000;
}
.cleaning-flow > li .explanation p{
  margin: 40px 0 0 0;
  padding:6px;
  line-height: 1.3;
}
.cleaning-flow > li .photo{
  width:45%;
}

.working{
  margin-right: auto;
  margin-left: auto;
  padding-left:1em;
  text-indent: -1em;
  width:90%;
  line-height: 1.3;
  font-size: 2rem;
  font-weight: bold;
  color:#002b55;
}

/*** お問い合わせ ***/
.contact-box{
  margin: 0 auto 0;
  padding:50px;
  text-align: center;
  color:#fff;
  background: linear-gradient(45deg,  #ffffff 0%,#007194 25%,#32003f 70%,#002b55 100%);
}
.contact-box .md{
  display: inline-block;
  margin: 0 auto 30px;
  padding-bottom: 2px;
  text-align: center;
  font-size:2.8rem;
  font-weight: bold;
  border-bottom: solid 2px #fff;
}
.contact-box .tel-info{
  font-size:1.8rem;
  font-weight: bold;
}
.contact-box .tel-info > span{
  display: inline-block;
  margin-left: 30px;
  font-size:2.6rem;
}

@media screen and (max-width: 767px) {}

@media print,
(min-width: 768px) {}


/*--------------------------------------------------
/* ■
----------------------------------------------------*/

@media screen and (max-width: 767px) {}

@media print,
(min-width: 768px) {}


/*--------------------------------------------------
/* フッター
----------------------------------------------------*/
footer{
  box-sizing: border-box;
  margin: 0 auto 0;
  padding:40px 15px 20px 15px;
  font-weight: normal !important;
  color:#fff;
  background-color: #122c5f;
}
footer .inner p{
  margin: 0;
  line-height: 1.3;
  text-align: center;
  font-size:1.4rem;
}
footer .inner .ft-corporate-name{
  margin-bottom: 15px;
  font-size:2rem;
}
footer .inner .ft-info-tel{
  margin-top: 6px;
}
footer .inner .ft-copy{
  margin-top: 20px;
  font-size:1.2rem;
}

@media screen and (max-width: 767px) {}

@media print,
(min-width: 768px) {}
