
.object-fit-img img,
img.object-fit-img{
    height:100%; width:100%; object-fit:cover; object-position:center; 
    font-family:'object-fit:cover; object-position:center;'
}

@media screen and (min-width: 768px){
	
html {
  scroll-padding-top: 210px;
}

body{ min-height:100vh; }
.wrapper.underPage{ min-height:calc(100vh - 220px); }
.spOnly{ display:none !important; }
.pict img{ width:100%; }
section.pageBlock{ margin-bottom:100px; padding:100px 0; }
.sectionHeader{ text-align:center; margin-bottom:40px; }
.sectionHeader .header{
    display:inline-block; padding:.3rem 1rem; margin:0 auto; background-color:#162; color:#fff;
    font-size:2.8rem; line-height:2.8rem; font-weight:bold;
}
.sectionHeader .subHeader{ font-size:.8rem; font-weight:normal; color:#666; margin-top:3px; }
section.pageBlock .contBox{ width:1100px; margin:0 auto; }
.flexBox{ display:flex; }
.flexBox.btw{ justify-content:space-between; }
.flexBox.ard{ justify-content:space-around}

/*ボタン*/
.moreBtn{ margin-top:50px; }
.moreBtn a{
    display:block; width:240px; margin:0 auto; padding:.75rem;
    border:1px solid #162; transition:.3s;
}
.moreBtn a span{ 
    position:relative; display:inline-block; width:100%; margin-left:-1rem;
    color:#162; font-weight:bold; text-align:center; white-space:nowrap; width:100%;
}
.moreBtn a span::after{
    position:absolute; bottom:0; margin-bottom:.35rem;
    content:''; display:inline-block; width:30px; height:.5rem; transform:skewX(40deg); transition:.3s;
    border:1px solid transparent; border-bottom-color:#162; border-right-color:#162;
}
.moreBtn a:hover{ background-color:#162; }
.moreBtn a:hover span{ color:#fff; }
.moreBtn a:hover span::after{
    border-bottom-color:#fff; border-right-color:#fff; width:36px;
}
/*【negative】*/
.moreBtn.nega{ margin-top:50px; }
.moreBtn.nega a{ border-color:#fff; }
.moreBtn.nega a span{ color:#fff; }
.moreBtn.nega a span::after{ 
    border:1px solid transparent; border-bottom-color:#fff; border-right-color:#fff;
}
.moreBtn.nega a:hover{ background-color:#fff; }
.moreBtn.nega a:hover span{ color:#333; }
.moreBtn.nega a:hover span::after{ border-bottom-color:#333; border-right-color:#333; }
/*ボタン*/

/**** HOME ****/

/* FirstView */
#homeFirstView{ 
    height:840px; background-image:url(../../images/homeFirstViewBg.png); background-repeat:repeat-x; 
    position:relative;
}
#homeFirstView.pageBlock{ padding:0; margin-bottom:100px; }
#homeFirstView #firstViewInner{ 
    display:flex; width:100%; padding:0 6%; justify-content:space-between; align-items:flex-s;
    position:absolute; left:0; top:200px; z-index:20;
}
#homeFirstView #firstViewInner #firstLeftBlock{ background-color:rgba(255,255,255,.7); padding:15px; }
#firstLeftBlock .mainCopyAddTxt{
    font-size:1.3rem; font-weight:bold; line-height:1.3; border-top:1px solid #999; padding-top:15px; 
}
#firstViewInner #firstLeftBlock .mainCopyAddTxt .strong{
    font-size:1.8rem; color:#fff; font-feature-settings:"palt"; font-weight:bold;
    background-color:#162; text-shadow:none; text-align:center; border-radius:4px; margin-top:5px;;
 }
#homeFirstView #firstRightBlock{
    width:24vw; background-color:rgba(255,255,255,.7); padding:15px;
    position:absolute; top:200px; right:6%;
}
#homeFirstView #firstRightBlock p{
    font-size:.95rem; line-height:2rem; margin-bottom:15px; 
}
#homeFirstView #firstRightBlock .objBox{ margin-top:45px; display:flex;}
#homeFirstView #firstRightBlock #NETIS{ width:105px; height:92px; margin-right:10px; }
#homeFirstView #firstViewInner p{
    color:#444;
    text-shadow:1px 1px 1px rgba(255,255,255,.75),-1px 1px 1px rgba(255,255,255,.75),1px -1px 1px rgba(255,255,255,.75),-1px -1px 1px rgba(255,255,255,.75); 
    /*animation:mojiiro 15.5s ease infinite;*/
}
/*@keyframes mojiiro{
    0%{ color:#666; }
    16%{ color:#666; background-color:rgba(255,255,255,0); }
    20%{ color:#333; background-color:rgba(255,255,255,.8); }
    92%{ color:#333; background-color:rgba(255,255,255,.8);}
    100%{ color:#666; background-color:transparent}
}*/
#homeFirstView h1 .forTitleTxt{ font-size:6.6rem; line-height:7.5rem; font-weight:bold; }
#homeFirstView h1 p:first-of-type{ font-size:1.3rem; font-weight:bold; }
#homeFirstView .sliderCase{ 
    
    position:absolute; top:0; left:0; width:100vw; height:840px; overflow:hidden;
}
#carPictSlider{ height:840px; }
#carPictSlider .slick-list,
#carPictSlider .slick-track{ height:100%; }
#carPictSlider #slide-carBodyPic{ /*padding-top:160px; */}
#carPictSlider .slick-slide p{ width:100%; height:100%; }
#carPictSlider .slick-slide p img{ margin:0 auto; }
.sliderCase .slick-dots{ bottom:15px; }
.sliderCase .slick-dots li button::before{ color:#3d5d4d !important; }
/* FirstView */

/*後から追加-お知らせ的な*/
#extraBlock{ padding:0; margin-bottom:0; }
#extraBlock .contBox{
    width:850px; margin:0 auto; border:3px solid #aba; border-radius:30px; padding:30px 60px;
    /*ボーダーを太らせる場合
    box-shadow:1px 1px 0px rgba(200,220,200,1), 1px -1px 0 rgba(200,220,200,1),
        -1px 1px 0px rgba(200,220,200,1), -1px -1px 0 rgba(200,220,200,1);
    */
    box-shadow:0px 8px 5px rgba(000,000,000,.1);
    background-color:#fdfffd;
}
#extraBlock .contBox .pict{ width:540px; margin:0 auto 30px; border-radius:10px; overflow:hidden; }
/*後から追加-お知らせ的な*/

/* トイレカーとは？ */
h3.strong{ color:#162; font-size:1.4rem; line-height:2.2rem; font-weight:bold; margin-bottom:15px; }
#homeAbout .extraText{
    background-color:#999; border:1px solid #939393; margin:50px 0 0; padding:30px; padding-left:285px; 
    position:relative;
}
#homeAbout .extraText p{
    display:inline-block; color:#fff; font-size:1.6rem; line-height:2.8rem; font-weight:bold; 
    text-shadow:0 0 5px rgba(0,0,0,.4);
}
#homeAbout .extraText .strong{ font-size:2rem; font-weight:bold; color:#fcf2af; }
#homeAbout .extraText .strong .sub{ font-size:.8rem; }
#homeAbout .note{
    padding:3px; font-size:.8rem; text-align:right; color:#333;
}
a.spotLink{ color:#3595df; text-decoration:underline; }
#homeAbout .extraText #toiletCarCut{width:250px; position:absolute; top:-5px; left:-20px; }
#homeAbout div.flexBox{ width:720px; margin:0 auto; }
/* トイレカーとは？ */

/* 導入事例 */
#homeIntroEx{
    background-color:#f0f0f0; background-image:url(../../images/home_introBG_town.png); 
    background-repeat:repeat-x; background-position:bottom;
    padding-bottom:250px; position:relative;
}
#homeIntroEx .contBox .flexList{ display:flex; justify-content:space-between; }
#homeIntroEx .contBox .flexList li{ width:330px; }
#homeIntroEx .contBox .flexList li .pict{ width:100%; height:220px; }
.flexList .explain{ margin-top:12px; }
.flexList .explain .header{ color:#162; font-weight:bold; font-size:1.2rem; }
.flexList .explain .text{ text-align:justify;}
#homeIntroEx #charactorCar{ position:absolute; bottom:0; left:10%; height:120px; }
/* 導入事例 */

/* おしらせ */
#topicList{ width:760px; margin:0 auto; background-color:rgba(255,255,255,.85); }
#topicList li a{ display:flex; padding:15px; border-bottom:1px dotted #333; }
#topicList li a:hover{ background-color:#efefef; }
#topicList li a .date{ margin-right:20px; }
#topicList .title .new{
    display:inline-block; margin-left:10px; font-size:.8rem; line-height:1.2rem;
    /*background-color:#fe5806;*/ color:#fe5806; border-radius:2px;
}
/*#homeInfo{
    background-image:url(../../images/halfToneImage.jpg); margin-bottom:0; padding-bottom:200px; 
    background-position:bottom; background-size:100%; background-repeat:no-repeat;
}*/
/* おしらせ */

/*お客様の声*/
#homeVoice{ background-color:#efefef; margin-bottom:0; }
#homeVoice #voiceList{ display:flex; justify-content:center; width:100%; }
#homeVoice #voiceList li{ width:253px; margin:0 8px; position:relative;}
#homeVoice #voiceList a{ display:block; width:100%; height:100%; }
#homeVoice #voiceList a:hover .pict img{ opacity:.5; }
#homeVoice #voiceList a:hover {background-color:#fff;}
#homeVoice #voiceList .pict{
    width:100%; height:200px; overflow:hidden; background-color:#162; position:relative;
}
#homeVoice #voiceList .pict::after{
    content:''; display:block; border:25px solid transparent; border-left-color:rgba(255,255,255,.8);
    border-top-width:18px; border-bottom-width:18px;
    position:absolute; top:calc(50% - 18px); left:43%; opacity:0; transition:.3s;
}
#homeVoice #voiceList a:hover .pict::after{ opacity:1; left:calc(50% - 13px); }
#homeVoice #voiceList .pict img{ transition:.3s; }
#homeVoice #voiceList .title{ font-size:.9rem; padding:10px 5px 0; font-weight:bold; }
#homeVoice #voiceList .new{
    position:absolute; top:0; left:0; display:block; background-color:red; color:#fff;
    font-size:.7rem; padding:0 5px;
}
#homeVoice #voiceList .header{ font-size:.9rem; padding:0 5px 10px; }
/*お客様の声*/

/* フッタ上リンク */
.halfFlex{ display:flex; }
.halfFlex li{ width:50vw; }
#homeCompany{ margin-bottom:0; padding:0; }
#homeCompany .halfFlex li{ height:360px; background-color:#251; position:relative;}
#homeCompany .halfFlex li a{ display:block; width:100%; height:100%; overflow:hidden;}
#homeCompany .halfFlex li a .title{
    display:flex; align-items:center; justify-content:center; width:100%; height:100%;
    position:relative; z-index:10;
}
#homeCompany .halfFlex li a .title p{ color:#fff; text-align:center; font-weight:bold; }
#homeCompany .halfFlex li a .title .header{ font-size:1.8rem; }
#homeCompany .halfFlex li .bgPanel{
    position:absolute; width:100%; height:100%; top:0; left:0; opacity:.5; transition:.3s;
}
#homeCompany .halfFlex li a:hover .bgPanel{ opacity:1; }
#homeCompany .halfFlex li a:hover .title p{ text-shadow:0 0 3px rgba(0,0,0,.75); }

/* フッタ上リンク */  

/**** HOME ****/



/**** 下層 ****/
#firstSection{ margin-bottom:100px; }
.underPage .pageBlock{width: 90%; max-width:1100px; margin:0 auto; }
.underPage section.pageContHead{ margin-bottom:0px; padding:150px 0 0; }
.underPage .pageContHead .pageTopImg{ width:1100px; height:350px; margin:0 auto; }
.underPage #pageLead{ margin-bottom:120px; }
.underPage .pageCopy{ font-size:2.4rem; font-weight:bold; color:#162; margin-bottom:40px; line-height: 1.4;}
.underPage .leadText{ margin-top: 100px; }
.underPage .object{ display:flex; margin:15px 0; }
.noteSpot{ color:#fe5806; font-size:.85rem; }
.orangeTxt{ color:#fe5806; }
.note{ font-size:.85rem; margin-top:10px; }
.midashi{ font-size:1.8rem; font-weight:bold; color:#787; position:relative; text-align:center; }
.midashi::after{
    content:''; display:block; width:150px; height:2px; background-color:#162; 
    position:absolute; bottom:-.5rem; left:calc(50% - 75px); 
}
.pointHeader{ text-align:center; margin-bottom:40px; position:relative;}
.pointHeader p{
    display:inline-block; font-size:1.5rem; font-weight:bold; color:#fff; background-color:#787; 
    padding:0 16px; margin:0 auto; border-radius:2px;
}
.pointHeader .subHeader{ display:block; text-align:center; font-size:.8rem; color:#666; }
.contentBox{ margin-bottom:100px; }
.contentInnerBox{width:1100px; margin:0 auto; }
.anchor{ position:absolute; top:-80px; }

/*UL*/
.cardList{ display:flex; flex-wrap:wrap; }
.cardList li a .pict{ overflow:hidden; }
.cardList li a .pict img{ transition:.3s; width:100%; }
.cardList li a:hover .pict img{ opacity:.6; }
.cardRow3 .cardList li{ width:350px; margin-bottom:60px; margin-right:25px; }
.cardRow3 .cardList li:nth-of-type(3n){ margin-right:0; }
.cardRow3 .cardList li .pict{ height:250px; }
/*UL*/

/*TABLE*/
.basicTable{ width:100%; }
.basicTable tr{ border-bottom:1px solid #ccc; }
.basicTable th,
.basicTable td{ padding:12px 0; }
.basicTable th{ text-align:left; color:#162; padding-left:20px; }
.basicTable td{}
/*TABLE*/

/** 下層ページのターミナル **/
.underPageCross{ display:flex; flex-wrap:wrap; justify-content:space-between; }
.underPageCross li{ width:45%; margin-bottom:120px; position:relative; }
.underPageCross li .pict{ height:360px; }
.underPageCross li .pageIntro{
    text-align:center; width:75%; margin:0 auto; padding:30px 0; position:absolute;
    left:10%; bottom:-30px; background-color:#fff;
}
.underPageCross li .pageIntro .pageTitle{ font-weight:bold; font-size:1.2rem; }
.underPageCross li .pageIntro .pageTitleSup{ color:#162; }
.underPageCross li .pageIntro .moreBtn{ margin-top:20px; }
/** 下層ページのターミナル **/


/** about 概要・用途 **/
/* 4つのメリット */
#maritList .merit{ margin-bottom:120px; }
#maritList .maritTitle{
    position:relative; margin-bottom:20px; padding-bottom:15px;
    height:auto; display:flex; align-items:flex-start;
    border-bottom:1px solid #162;
}

#maritList .maritTitle .sub{
    font-size:.85rem; color:#333; position:relative; text-align: center; margin-right:40px;
}
#maritList .maritTitle .sub .num{
    display:block; font-size:1.5rem; font-weight:; line-height:1.8rem; background-color:#162; color:#fff;
}
#maritList .maritTitle .header{ font-size:2.7rem; line-height:3.5rem; color:#162; }

#maritList .merit .cont{ display:flex; flex-wrap:wrap; justify-content: flex-end; }
#maritList .merit .cont .problem,
#maritList .merit .cont .answer{ width:820px; }
#maritList .merit .cont .problem{ margin-bottom:50px; }
#maritList .merit .cont .text{ text-align:justify;  }
#maritList .merit .cont .problem .pict{ width:350px; }
#maritList .merit .cont .answer{ background-color:rgba(12,144,48,.1); padding:25px; position:relative; }
#maritList .merit .cont .answer::before{
    content:'answer'; position:absolute; top:-2rem; left:22px; font-size:2.4rem; color:#6caf79;
    font-family:'Century Gothic','Avenir Next',sans-serif;
}
#maritList .merit:first-of-type .answer .object{ background-color:#fff; border-radius:5px; padding-bottom:10px; }
#maritList .merit:first-of-type .answer .object .pict{ margin:0 auto; }
#maritList .merit:nth-of-type(4) .answer{ display:flex; justify-content:space-between; }
#maritList .merit:nth-of-type(4) .answer .text{ width:calc(100% - 300px); }
#maritList .merit:nth-of-type(4) .answer .object{ width:250px; margin:0; }
#meritStopCopy .header{
    font-size:3rem; line-height:4.2rem; font-weight:bold; color:#fe5806; margin-bottom:10px;
}
#maritStopPict{ width:100%; margin:12px auto; position:relative; }
#maritStopPict .BC{
    content:'Best Choice'; position:absolute; left:44%; top:38%; transform:rotate(-12deg);
    font-size:6rem; font-weight:bold; font-family:serif; line-height:6.3rem;
    color:#6caf79;  
}
#maritStopPict .pict{ width:450px; margin-left:50px; }
/* 4つのメリット */
/* 運用事例 */
#aboutOperationCont .about-opeBlock{ margin-bottom:140px; position:relative;}
#aboutOperationCont .pageLead{ margin-bottom:50px; }
.lb-data .lb-details .lb-caption{ color:#fff !important; }
#aboutOperationCont .title{ margin-top:8px; font-weight:bold; color:#162; }
#aboutOperationCont h2{
    margin-bottom:10px; font-weight:bold; color:#333; font-size:1.2rem; position:relative; color:#555;
}
#aboutOperationCont h2::before{
    content:''; display:inline-block; width:1rem; height:1rem; background-color:#162; border-radius:50%;
    margin-right:5px;
}
#aboutOperationCont .semiBlock{ margin-bottom:60px; }
#aboutOperationCont #gohu .cardList{ margin-top:30px; }


/*0825追加*/
#aboutOperationCont .blockHeader{ margin-bottom:15px;  }
#aboutOperationCont .blockHeader .blockTitle{ 
    position:relative; font-size:1.4rem; font-weight:bold; color:#666; margin-bottom:8px;
    padding-left:1.2rem;
}
#aboutOperationCont .blockHeader .blockTitle::before{
    content:''; position:absolute; top:.55rem; left:0;
    display:block; width:1rem; height:1rem; background-color:#162; border-radius:50%; 
}
#aboutOperationCont .blockLead{
    padding:15px; background-color:#f3f3f3; border-radius:5px; font-size:.9rem;
}
.eventBlock .cardList{ margin-bottom:60px; padding-bottom:30px; border-bottom:1px dotted #ccc; }
.eventBlock .cardList li{ width:350px; margin-bottom:25px; margin-right:25px; }


/* 運用事例 */

/*機能・種類*/
#aboutType.pageBlock{ width:100%; max-width: unset;}
/*#aboutType.pageBlock .contentBox{ width:1100px; margin:0 auto 100px; }*/
#aboutType .contentInnerBox{width: 90%; max-width: 1100px; margin: 0 auto;}
#aboutType #pageLead{ /*width:1100px;*/ margin:0 auto 100px; }
#aboutType .pdfDwn{ margin:50px 0; }
#aboutType .pdfDwn .pdfDwnCase .dwBtn{
    display: inline-block; background-color:#162; color:#fff; margin-right:5px; margin-bottom: 5px; padding:10px 20px; border-radius:6px; 
    transition:.3s; font-size:1.2rem; font-weight:bold; white-space:nowrap; 
}
#aboutType .pdfDwn .pdfDwnCase .dwBtn:hover{ background-color:#e80; }


/*youtube*/
#aboutType #youtubeBox{
    width:100%; height:186px; margin:20px auto 0; display:flex; justify-content:space-between;
    position:relative; 
}
#aboutType #youtubeBox .ifrCase{ width:330px; }
#aboutType #youtubeBox iframe{ width:100%; height:100%; }
/*#aboutType #youtubeBox::after{
    content:'仮'; position:absolute; left:0; top:0; width:100%; height:100%; background-color:rgba(0,0,0,.5);
    display:block; font-size:200px; color:#eee; font-weight:bold; text-align:center; line-height:360px;
}*/

/*レイアウト*/
#aboutType #layoutBox{scroll-margin-top: -50px;}
#aboutType #layoutBox.contentBox{ width:100%; background-color:rgba(12,144,48,.1);; padding:100px 0; }
#aboutType #layoutBox.contentInnerBox{width: 90%; max-width:1100px; margin: 0 auto;}
#aboutType #pageLead .header{ font-weight:bold; font-size:1.1rem; }
#aboutType #pageLead .header span{ font-size:1.4rem; margin-left:10px; }
#aboutType #pageLead .object .pict{ width:120px; margin-right:10px; }
#aboutType #pageLead .object .pict#shakensho{ width:150px; border:1px solid #ccc; }
#aboutType #kaitekiToillet{ align-items:center; justify-content:center; margin:30px 30px 100px;}
#aboutType #toilrtCarPict{ width:300px;  }
#aboutType #kaitekiText{ width:480px; margin: 0 20px; }
#aboutType .type-imageCut{ width:180px; }
#aboutType #kaitekiText .noteSpot{ margin-top:12px; }
#aboutType #toilrtCarPict img{ width:100%; }
#aboutType #layoutBlock{ margin-top:30px; }
#aboutType #layoutBlock li{ display:flex; justify-content:center; flex-wrap:wrap;}
#aboutType #layoutBlock li .equipment{ width: 100%; display: flex; justify-content: center; margin-top: 20px; }
#aboutType #layoutBlock li .equipment .equipName{
    padding:0 8px; border:1px solid #ccc; margin-bottom:10px; background-color:#fff; color:#555; margin-right: 20px;
}
#aboutType #layoutBlock li .equipment .equipName:last-child{margin-right: 0;}	
#aboutType #layoutBlock li .object{ width: 85%; max-width:800px; margin:30px auto 0; justify-content:center; }
#aboutType #layoutBlock li .object .equipPict{ width: 33.33%; max-width:240px; margin:0 12px; }
#aboutType #layoutBlock li .object .pict img{ width:100%; }
#aboutType #layoutBlock .layoutGraph{ width:100%; }
#aboutType #layoutBlock .layoutGraph img{ width:95%; max-width: 500px; margin: 0 auto; }
#aboutType #layoutBlock #twoRoom .layoutGraph{ width:541px; }
#aboutType .slideThumb{ width: 90%; max-width:760px; margin:0 auto; }
#aboutType .slideThumb .slick-slide{ width: 30% !important; max-width:240px; /*margin-right:10px;*/ cursor:pointer;}
#aboutType .slideThumb .slick-slide:nth-of-type(3){ margin-right:0; }
#aboutType .slideThumb .slick-slide .header{
    width: 100%; max-width:240px; background-color:#fff; padding:0 8px; border:1px solid #ccc; border-radius:2px;
    text-align:center; font-size:1.1rem; color:#999;
}
#aboutType .slideThumb .slick-slide.slick-current .header{ background-color:#162; color:#fff; font-weight:bold;}

/*設備*/
#aboutType #exteriaBox .pageCopy{ /*width:1100px;*/ margin:0 auto 40px; }
#aboutType #exteriaBox.contentBox{ width:100%; background-color:rgba(12,144,48,.1);; padding-top:100px }
#aboutType #exteriaBox.contentBox .cardList{  padding-bottom:50px; }
#aboutType #equipBox .cardList, #aboutType #exteriaBox .cardList{max-width: 1090px; margin: 0 auto;}
#aboutType .cardList li{ width:250px; margin-right:30px; margin-bottom:36px; }
#aboutType .cardList li:nth-of-type(4n){ margin-right:0; }
#aboutType .cardList li .header{ font-weight:bold; font-size:1.1rem; margin-top:8px; color:#162; }
#aboutType .cardList li .text{
    padding:10px; background-color:rgba(12,144,48,.1); border-radius:3px; font-size:.9rem; line-height:1.5rem; 
}
#aboutType #exteriaBox .cardList li .text{background-color:#fff; }

/*寸法*/
#aboutType #specs.contentBox{  } 
#aboutType #specs .cardList{ position:relative; justify-content: center;}
#aboutType #specs .cardList::before{
    content:''; position:absolute; left:/*60px*/calc(50% - 90px); top:0; width:60px; height:360px; line-height:360px;
    border:1px solid #999; border-left-color:transparent; border-right-color:transparent;
}
#aboutType #specs .cardList::after{
    content:''; position:absolute; left:/*90px*/calc(50% - 60px); top:0;
    width:1px; height:360px; background-color:#999;  
}
#aboutType #specs .cardList li{ width:500px; height:360px; margin-right: 0; }
#aboutType #specs .cardList li:first-of-type{ margin-bottom:80px; }
#aboutType #specs .cardList li .pict{ height:360px; text-align:center; }
#aboutType #specs .cardList li .pict img{ height:100%; width:auto; margin: 0 auto;}
#aboutType #specs .cardList li#frontPict,
#aboutType #specs .cardList li#rightPict{ position:relative; }
#aboutType #specs .cardList li#frontPict::before{
    content:''; display:block; width:230px; height:1px; background-color:#999;
    position:absolute; left:calc(50% - 115px); bottom:-40px;  
}
#aboutType #specs .cardList li#frontPict::after{
    content:'167cm'; width:230px; height:40px; text-align:center;
    border:1px solid #999; border-top-color:transparent; border-bottom-color:transparent;
    position:absolute; left:calc(50% - 115px); bottom:-60px;
}
#aboutType #specs .cardList li#rightPict::before{
    content:''; display:block; width:478px; height:1px; background-color:#999;
    position:absolute; left:calc(50% - 239px); bottom:-40px;  
}
#aboutType #specs .cardList li#rightPict::after{
    content:'365cm'; width:478px; height:40px; text-align:center;
    border:1px solid #999; border-top-color:transparent; border-bottom-color:transparent;
    position:absolute; left:calc(50% - 239px); bottom:-60px;
}
#aboutType #specs .cardList li#carHeight{ position:absolute; width: fit-content; left:/*30px*/calc(50% - 50px); top:0; line-height:360px; z-index: 2; margin-bottom: 0;}

#aboutType #specs #carData{ display:flex; justify-content:space-between; }
#aboutType #specs #carData .carDataTable{ width:46%; }
#aboutType #specs #carData .carDataTable li{ margin-bottom:15px; border:1px solid #ccc; }
#aboutType #specs #carData .carDataTable .header{ background-color:#162; color:#fff; padding:2px 10px; }
#aboutType #specs #carData .carDataTable .text{ padding:10px; }
#aboutType #specs #carData .carDataTable .hyojun span{ display:inline-block; margin-right:15px; vertical-align:text-top}
#aboutType #specs #number8{ background-color:#fe5806; color:#fff; padding:2px 6px; }
#aboutType #specs #carData .carDataTable table{ width:100%; margin:5px 0; }
#aboutType #specs #carData .carDataTable td{ width:50%; padding:3px 10px; }
#aboutType #specs #carData .carDataTable td span{ font-weight:bold; color:#666; }
/*機能・種類*/
/** about 概要・用途 **/

/** 会社概要 **/
#companyFirstSec{ padding-bottom:0; }
#companyHeaderImg{ height:250px; }
#companyHeaderImg .pict{ width:100%; text-align:center; }
#companyHeaderImg img{ width:150px; height:250px; }
.cornerHeader .header{
    text-align:center; font-size:2.4rem; color:#999; margin-bottom:30px; letter-spacing:.3rem;
    position:relative;
}
#companyData .basicTable{ width:750px; margin:0 auto 100px;  }
#companyData .basicTable th,
#companyData .basicTable td{ font-size:1rem;  }
#companyData .basicTable th{ width:175px; }
#companyData .basicTable td .td-link{color: var(--text-color); text-decoration: underline; transition: all .1s;}
#companyData .basicTable td .td-link:hover{color: #162; transition: all .1s;}
#companyData #kanren .basicTable td,
#companyData #torihiki .basicTable td{ padding:10px 8px; }
#companyData #torihiki .basicTable{ margin-bottom:50px; }
#companyData #torihiki .basicTable caption{ color:#162; font-size:1.2rem; text-align:left;  }

/** 会社概要 **/

/** お知らせ **/
.NewsPage .pagePrevBox{ display:flex; justify-content:center; margin-top:20px; }
.NewsPage .pagePrevBox .pagePrev a,
.NewsPage .pagePrevBox .pageNext a{
    margin:0 10px; padding:6px 12px; border:1px solid #162; transition:.3s; 
}
.NewsPage .pagePrevBox .pagePrev a:hover,
.NewsPage .pagePrevBox .pageNext a:hover{ background-color:#162; color:#fff; }
.NewsHomeBtn{ margin:40px auto; }
.NewsHomeBtn a{
    display:block; width:250px; margin: 0 auto; padding:6px; border:1px solid #162; transition:.3s; 
    text-align:center; 
}
.NewsHomeBtn a:hover{ background-color:#162; color:#fff; }

.NewsDetailBox .infoTitle{ margin-bottom:30px; 
    font-size:2rem; font-weight:bold; color:#162; 
}

.NewsDetailBox .entryBody a img { max-width:100%; width:auto; }

/** お知らせ **/


/** お客様の声 **/
.VoicePage #topicList{ display:flex; flex-wrap:wrap; justify-content:flex-start; width:100%; }
.VoicePage #topicList li{
    width:calc((100% / 4) - 20PX); margin-bottom:40px; margin-right:25px;
    box-shadow:0 2px 3px rgba(60,128,92,.2);
}
.VoicePage #topicList li:nth-of-type(4n){ margin-right:0; }
.VoicePage #topicList li a{ display:block; border:none; padding:0; position:relative;}
.VoicePage #topicList li .thumb{
    position:relative; top:0; left:0; width:100%; height:160px;
    background-image:url(/common/images/daitai.png); background-size:cover; background-position:center;
}
.VoicePage #topicList li .thumbnail_target{
    position: absolute; top:0; left:0; z-index:2; width:100%; height:160px; overflow:hidden;
    transition:.3s; background-image:url(/common/images/daitai.png); 
    background-size:cover; background-position:center;
}
.VoicePage #topicList li .thumbnail_target img{ width:100%; height:100%; }
.VoicePage #topicList li .title{ padding:8px 5px 0; font-weight:bold; }
.VoicePage #topicList .title .new{
    position:absolute; top:0; left:0;color:#fff; background-color:red;
    margin-left:0; line-height:1.5rem; z-index:10; padding:0 4px;
}
.VoicePage #topicList li .header{ padding:0 5px 5px; }
.voiceDetailPage .NewsDetailBox{ width:960px; margin:0 auto; }
.voiceDetailPage .entryBody a img{ max-width:100%; margin:20px 0; }

.NewsDetailBox .infoTitle .mainT{
    font-size:2rem; font-weight:bold; color:#162; 
}
.NewsDetailBox .infoTitle .subTxt{
    display:inline-block; padding:5px 10px; background-color:#efefef; border-radius:2px; font-size:16px; font-weight:normal; color:#333
}
/** お客様の声 **/
.pagePrevBox{ display:flex; justify-content:center; }
.pagePrevBox p{ padding:15px; }
.pagePrevBox p a{color:#162; font-weight:bold;}


/** 個人情報保護方針 **/
#privacyBlock{ padding-top:0; }
#privacyBlock .privacyList{ width:800px; margin:0 auto; }
#privacyBlock .privacyList li{ margin-bottom:80px; }
#privacyBlock .privacyList li .listNum{ font-weight:bold; font-size:1.4rem; color:#162; margin-bottom:10px; }
#privacyBlock .privacyList li dl{ width:90%; margin:20px 0 0 10%; }
#privacyBlock .privacyList li dt{ font-size:1.1rem; font-weight:bold; color:#666; margin-bottom:6px; }
#privacyBlock .privacyList li dd{ margin-bottom:30px; }
/** 個人情報保護方針 **/

/** サイトマップ **/
#sitemapUrlList .cardList{ justify-content:space-between; }
#sitemapUrlList .cardList li{ width:30%; border-right:1px solid #ccc; }
#sitemapUrlList .cardList li:last-of-type{ border-right:none; }
#sitemapUrlList dl{ margin-bottom:30px; }
#sitemapUrlList dt{ font-size:1.4rem; font-weight:bold; margin-bottom:10px; }
#sitemapUrlList dt .text{ font-size:.9rem; color:#666; }
#sitemapUrlList dd{ padding-left:20px; margin-bottom:6px; }
#sitemapUrlList dd.sub{ padding-left:40px; }
#sitemapUrlList a{ transition:.3s; font-weight:bold; }
#sitemapUrlList a:hover{ color:#162; }
/** サイトマップ **/

/**** contact ****/
#contactSec{  }
#contactSec .leadText{ text-align:center; margin-bottom:40px; }
.contactBlock{ width: 90%; max-width:920px; margin:0 auto; border:2px solid #162; background-color:#f9f9f9; }
.tableCase.formTable{ padding:0 60px; }
.tableCase .inputTable{ width:100%; }
.inputTable tr{ border-bottom:1px solid #ccc; }
.inputTable th,
.inputTable td{ vertical-align:middle; text-align:left; padding:15px 0; font-size:1rem; font-weight: normal; }
.inputTable th{ width:300px;}
.inputTable .formKoumokuAdd{
    display:inline-block; margin-top:8px; font-size:.85rem; padding:0; line-height:1.75rem;
}
.inputTable .formKoumokuAdd .strong{
    display: inline-block; font-size:1rem; font-weight:bold; background-color:#162; padding:5px 8px; margin-right:5px; 
    border-radius:3px; color:#fff;margin-bottom: 5px;
}

.inputTable .hissu{ background-color: #e33; border-radius: 3px; color: white !important; padding-right: 5px; margin-left: 5px; font-size: 13px; padding-left: 4px; padding-bottom: 1px;}
.inputTable .nini {background-color: #797676; padding-left: 4px; padding-bottom: 1px; border-radius: 3px; color: white; padding-right: 5px; margin-left: 5px; font-size: 13px;
}

	.inputTable td input[type=text]{
    width:100%; padding:.5rem; background-color:#fff; border:1px solid #ccc;
    font-size:1rem; border-radius:2px;
}

.inputTable td input[type=checkbox]{ display:none; }
.inputTable td input[type=radio] {display: inline !important; margin: -3px 7px 0 7px !important; accent-color: #162 !important; height: 16px; width: 16px; vertical-align: middle;}
.inputTable td .typeRadio{ position:relative; padding-left:2rem;}
.inputTable td .typeRadio::before{
    content:''; display:inline-block; width:18px; height:18px; position:absolute; top:0; left:0;
    border-radius:50%; border:1px solid #ccc; background-color:#fff; box-sizing:border-box;
}
.inputTable td input[type=radio] + .typeRadio::after{
    content:''; display:block; position:absolute; top:3px; left:3px; 
    width:12px; height:12px; background-color:#162; border-radius:50%; opacity:0; transition:.2s;
}
.inputTable td input[type=radio]:checked + .typeRadio::after{ opacity:1; }
.inputTable td .typeChBox{ position:relative; padding-left:2rem; }
.inputTable td .typeChBox::before{
    content:''; display:inline-block; width:18px; height:18px; position:absolute; top:0; left:0;
    border:1px solid #ccc; background-color:#fff; box-sizing:border-box;
}
.inputTable td input[type=checkbox] + .typeChBox::after{
    content:''; display:block; position:absolute; top:0; left:3px; width:12px; height:6px; 
    border:2px solid transparent; border-left-color:#162; border-bottom-color:#162;
    transform:rotate(-45deg) skewX(-5deg); opacity:0; transition:.2s;
}
.inputTable td input[type=checkbox]:checked + .typeChBox::after{ opacity:1; }
.inputTable td select{
    -webkit-appearance:none; appearance:none; position:relative;
    width:100%; padding:.5rem; background-color: #fff; border:1px solid #ccc; border-radius:2px; background-color;
    padding:.5rem; font-size:1rem;
}
.inputTable #addressRow td{ display:flex; flex-wrap:wrap; }
.inputTable #addressRow td .postal{ display:flex; align-items:center; margin:0 10px 10px 0; }
.inputTable #addressRow td .longInput{ width:100%; }
.selectBox{ position:relative; width:200px; }
.selectBox::after{
    content:''; display:block; width:10px; height:10px; 
    position:absolute; top:15px; right:14px; border-bottom:2px solid #333; border-right:2px solid #333; 
    transform:rotate(45deg); pointer-events:none;
}
.inputTable td textarea{ width:100%; height:10rem;         background-color: #fff; border:1px solid #ccc; padding:.5rem; }
.submitArea{background-color:#fff; padding:20px; margin-top:20px; border-radius:5px; }
.submitArea .g-recaptcha > div{ margin:0 auto; }
.submitArea #contact_submit{
    display:block; width:280px; margin:20px auto 0; padding:5px; color:#fff; font-weight:bold; 
    border-radius:2px; background-color:#162; text-align:center; transition:.3s;
}
.submitArea #contact_submit:hover{ background-color:#fe5806; }
#required_confirm{ text-align:center; }
.hissRecapcha {background-color: #e33; padding-left: 6.5px; border-radius: 3px; color: white !important; font-size: 13px; width: 40px; margin-left: 47%;
}
	
.anketo {border-left: thick solid #162 !important; font-size: 20px; font-weight: bold; color: #163; margin-top: 20px; padding-left: 10px;}
	
.komoku {color: #e33; font-weight: bold;}

.errorMessage{color: #e33; font-size: 16px;}
#txt_others_er{width: calc(100% - 165px); margin: 0 0 0 auto;}

/* 確認 */
.submitArea form{ display:flex; justify-content:center; }
.submitArea input[type=button].typeBack{
    width:200px; padding:5px; border:1px solid #162; background-color:#eee; color:#333; margin-right:10px; transition:.3s; cursor:pointer; text-align: center; flex-shrink: 0;
}
.submitArea input[type=button].typeBack:hover{ background-color:#666; color:#eee; }
.submitArea input[type=submit]{
    width:200px; padding:5px; background-color:#162; color:#fff; border:none; transition:.3s; cursor:pointer; text-align: center; flex-shrink: 0;
}
.submitArea input[type=submit]:hover{ background-color:#fe5806; }

/* 送信完了 */
#contactSendEndPage{width: 90%; max-width: 1100px; margin: 100px auto;}
#contactSendEndPage .pageCopy{ text-align:center; }
#contactSendEndPage .pict img{max-width: 150px;}
.contactSendMessage{ text-align:center; }
.contactSendMessage .header{ font-size:1.4rem; margin-bottom:12px; }

.contactPageImg{ width:150px; margin:0 auto 20px; }

/* エラー */
#contactErrorPage .submitArea p{ color:#c66; text-align:center; }
#contactErrorPage .submitArea input.typeBack{ margin-top:50px; }

/**** contact ****/

}

@media screen and (max-width: 1576px) and (min-width: 768px){

html {
  scroll-padding-top: 130px;
}

}

@media screen and (max-width: 1225px) and (min-width: 768px){

.cardRow3 .cardList li{width: calc(50% - 12.5px);}
.cardRow3 .cardList li:nth-of-type(2n){ margin-right:0; }
.cardRow3 .cardList li:nth-of-type(3n){ margin-right:25px; }

}

@media screen and (max-width: 1210px) and (min-width: 899px){

#aboutType #equipBox .cardList, #aboutType #exteriaBox .cardList{ max-width: 810px;}
#aboutType #equipBox .cardList li:nth-of-type(3n), #aboutType #exteriaBox .cardList li:nth-of-type(3n){ margin-right:0; }
#aboutType #equipBox .cardList li:nth-of-type(4n), #aboutType #exteriaBox .cardList li:nth-of-type(4n){ margin-right:30px; }

}

@media screen and (max-width: 899px) and (min-width: 768px){

#aboutType #equipBox .cardList, #aboutType #exteriaBox .cardList{ max-width: 530px;}
#aboutType #equipBox .cardList li:nth-of-type(3n), #aboutType #exteriaBox .cardList li:nth-of-type(3n){ margin-right:30px; }	
#aboutType #equipBox .cardList li:nth-of-type(2n), #aboutType #exteriaBox .cardList li:nth-of-type(2n){ margin-right:0; }

#aboutType #specs .cardList::before{
    content:''; position:absolute; left: unset; right: calc(50% + 280px); top:0; width:60px;
    border:1px solid #999; border-left-color:transparent; border-right-color:transparent;
}
#aboutType #specs .cardList::after{
    content:''; position:absolute; left: unset; right: calc(50% + 310px); top:0;
    width:1px; background-color:#999;  
}
#aboutType #specs .cardList li#carHeight{ position:absolute; left: unset; right: calc(50% + 320px) !important; top:0;}
	
}

@media screen and (max-width: 1200px) and (min-width: 768px){

#aboutType #youtubeBox{
    width:100%; max-width: 500px; height:unset; margin:20px auto 0; display:block;}
#aboutType #youtubeBox .ifrCase{ width:100%; margin-bottom: 30px; }
#aboutType #youtubeBox iframe{ width:100%; height:auto; min-height: 300px; }
	
#aboutType #kaitekiToillet{ align-items:center; justify-content:center; margin:50px auto 100px;}
#aboutType #toilrtCarPict{ width: 50%; max-width:300px;  }
#aboutType #kaitekiText{ width: calc(50% - 20px); max-width:480px; margin-right: 0; margin-left: 30px;}
#aboutType .type-imageCut{ width:100%; max-width: 800px; margin-top: 30px; display: flex; justify-content: center; }

#aboutType #specs .cardList {justify-content: center;}
#aboutType #specs .cardList::before{
    height:270px; line-height:270px;}
#aboutType #specs .cardList::after{
    height:270px;}
#aboutType #specs .cardList li{ width:375px; height:270px;}
#aboutType #specs .cardList li .pict{ height:270px;}
#aboutType #specs .cardList li#frontPict::before{
    content:''; display:block; width:186px; height:1px; background-color:#999;
    position:absolute; left:calc(50% - 93px); bottom:-40px;  
}
#aboutType #specs .cardList li#frontPict::after{
    content:'167cm'; width:186px; height:40px; text-align:center;
    border:1px solid #999; border-top-color:transparent; border-bottom-color:transparent;
    position:absolute; left:calc(50% - 93px); bottom:-60px;
}
#aboutType #specs .cardList li#rightPict::before{
    content:''; display:block; width:360px; height:1px; background-color:#999;
    position:absolute; left:calc(50% - 180px); bottom:-40px;  
}
#aboutType #specs .cardList li#rightPict::after{
    content:'365cm'; width:360px; height:40px; text-align:center;
    border:1px solid #999; border-top-color:transparent; border-bottom-color:transparent;
    position:absolute; left:calc(50% - 180px); bottom:-60px;
}
#aboutType #specs .cardList li#carHeight{ line-height: 270px !important;}		
#aboutType #specs #carData{ flex-wrap: wrap; }
#aboutType #specs #carData .carDataTable{ width:100%; }
	
}

@media screen and (max-width: 987px) and (min-width: 768px){

#txt_others_er{width: 100%;}
	
}

@media screen and (max-width: 900px) and (min-width: 768px){

#aboutType #specs .cardList li:nth-child(2n-1){ width:250px; height:270px;}
#aboutType #specs .cardList li#carHeight{right: calc(50% + 125px);}
	
}

@media screen and (max-width: 768px){
	
html {
  scroll-padding-top: 115px;
}
	
.pcOnly{ display:none !important; }

.pict img{ width:100%; }
section.pageBlock{ margin-bottom:100px; padding:100px 5vw; width:100%; }
.sectionHeader{ text-align:center; margin-bottom:40px; }
.sectionHeader .header{
    display:inline-block; padding:.3rem 1rem; margin:0 auto; background-color:#162; color:#fff;
    font-size:2.4rem; line-height:2.5rem; font-weight:bold;
}
.sectionHeader .subHeader{ font-size:.8rem; font-weight:normal; color:#666; margin-top:3px; }
section.pageBlock .contBox{ width:100%; margin:0 auto; }

/*ボタン*/
.moreBtn{ margin-top:50px; }
.moreBtn a{
    display:block; width:240px; margin:0 auto; padding:.75rem;
    border:1px solid #162; transition:.3s;
}
.moreBtn a span{ 
    position:relative; display:inline-block; width:100%; margin-left:-1rem;
    color:#162; font-weight:bold; text-align:center; white-space:nowrap; width:100%;
}
.moreBtn a span::after{
    position:absolute; bottom:0; margin-bottom:.35rem;
    content:''; display:inline-block; width:30px; height:.5rem; transform:skewX(40deg); transition:.3s;
    border:1px solid transparent; border-bottom-color:#162; border-right-color:#162;
}
/*【negative】*/
.moreBtn.nega{ margin-top:50px; }
.moreBtn.nega a{ border-color:#fff; }
.moreBtn.nega a span{ color:#fff; }
.moreBtn.nega a span::after{ 
    border:1px solid transparent; border-bottom-color:#fff; border-right-color:#fff;
}
.moreBtn.nega a:hover{ background-color:#fff; }
.moreBtn.nega a:hover span{ color:#333; }
.moreBtn.nega a:hover span::after{ border-bottom-color:#333; border-right-color:#333; }
/*ボタン*/

/**** HOME ****/

/* FirstView */
#homeFirstView{ 
    /*height:840px;*/ background-image:url(../../images/homeFirstViewBg.png); background-repeat:repeat-x; 
    position:relative; margin-bottom:0;
}
#homeFirstView.pageBlock{ padding:0; }
#homeFirstView #firstViewInner{ 
    display:flex; flex-wrap:wrap; width:100%; padding:0 6%; justify-content:space-between; align-items:flex-end;
     background-color:#dae2e5;
}
#homeFirstView #firstViewInner #firstLeftBlock{ width:; margin-top:10px; margin-bottom:90vw; }
#homeFirstView #firstViewInner #firstRightBlock{ width:100%; padding-bottom:20px; }
#homeFirstView #firstViewInner #firstRightBlock p{
    font-size:3.8vw; line-height:7.2vw; margin-bottom:15px; 
}
#homeFirstView #firstViewInner #firstRightBlock .objBox{ margin-top:20px; display:flex;}
#homeFirstView #firstViewInner #firstRightBlock #NETIS{ width:105px; height:92px; margin-right:10px; }
#homeFirstView #firstViewInner p{ color:#666; }
#homeFirstView h1 .forTitleTxt{ font-size:20vw; line-height:20vw; font-weight:bold; margin-bottom:1.8vw }
#homeFirstView h1 p:first-of-type{ font-size:4.8vw; font-weight:bold; }
#homeFirstView .mainCopyAddTxt{
    font-size:4.8vw; font-weight:bold; line-height:7.5vw; text-align:center; 
    width:85vw; margin:0 auto;
}
#homeFirstView #firstLeftBlock .mainCopyAddTxt .strong{
    background-color:#162; text-align:center; font-weight:bold;
    color:#fff; font-size:6vw; border-radius:5px;
}
#homeFirstView .sliderCase{ position:absolute; top:350px; height:85vw; width:100%; overflow:hidden; }
#carPictSlider{ height:100%; }
#carPictSlider .slick-list{ width:100vw; }
#carPictSlider .slick-list,
#carPictSlider .slick-track{ height:100%; }
#carPictSlider .slick-slide p{ width:100%; height:100%; text-align:center; }
#carPictSlider .slick-slide p img{ margin:0 auto; height:100%; width:100%; }
#carPictSlider #slide-carBodyPic.slick-slide p img{ height:auto; }
#carPictSlider #slide-carBodyPic p{ padding:0 7vw }
/* FirstView */

/*後から追加-お知らせ的な*/
#extraBlock{ padding:0; margin:5vw auto; }
#extraBlock .contBox{
    width:88vw; margin:0 auto; border:3px solid #aba; border-radius:2vw; padding:5vw;
    box-shadow:0px 8px 5px rgba(000,000,000,.1);
    background-color:#fdfffd;
}
#extraBlock .contBox .pict{ width:100%; margin:0 auto 30px; border-radius:10px; overflow:hidden; }
/*後から追加-お知らせ的な*/

/* トイレカーとは？ */
h3.strong{ color:#162; font-size:1.4rem; line-height:2.2rem; font-weight:bold; margin-bottom:15px; }
#homeAbout{ margin-bottom:0; }
#homeAbout .contBox p{ text-align:justify; }
#homeAbout .extraText{
    background-color:#999; border:1px solid #939393; margin:60px 0 0; padding:5vw; padding-top:42vw;
    position:relative;
}
#homeAbout .extraText p{
    display:inline-block; color:#fff; font-size:6vw; line-height:9vw; font-weight:bold; 
    text-shadow:0 0 5px rgba(0,0,0,.4);
}
#homeAbout .extraText .strong{ font-size:9vw; line-height:14vw; font-weight:bold; color:#fcf2af; }
#homeAbout .extraText .strong .sub{ font-size:.8rem; }
#homeAbout .note{
    padding:3px; font-size:.7rem; text-align:right; color:#333;
}
#homeAbout .note a{ color:#3595df; text-decoration:underline; }
#homeAbout .extraText #toiletCarCut{width:50vw; position:absolute; top:-30px; left:calc(50% - 25vw); }
a.spotLink{ color:#3595df; text-decoration:underline; }
/* トイレカーとは？ */

/* 導入事例 */
#homeIntroEx{
    background-color:#f0f0f0; background-image:url(../../images/home_introBG_town.png); 
    background-repeat:repeat-x; background-position:bottom;
    padding-bottom:250px; position:relative; margin-bottom:0;
}
#homeIntroEx .contBox .flexList{ display:flex; flex-wrap:wrap;  }
#homeIntroEx .contBox .flexList li{ width:100%; margin-bottom:80px; }
#homeIntroEx .contBox .flexList li .moreBtn{ margin-top:30px; }
#homeIntroEx .contBox .flexList li .pict{ width:100%; height:220px; }
.flexList .explain{ margin-top:12px; }
.flexList .explain .header{ color:#162; font-weight:bold; font-size:1.2rem; }
.flexList .explain .text{ text-align:justify;}
#homeIntroEx #charactorCar{ position:absolute; bottom:0; left:10%; height:120px; }
/* 導入事例 */

/* おしらせ */
#homeInfo{ margin-bottom:0; }
#topicList{ width:100%; margin:0 auto; }
#topicList li a{ display:flex; flex-wrap:wrap; padding:15px; border-bottom:1px dotted #333; }
#topicList li a .date{ width:100%; }
#topicList .title .new{
    display:inline-block; margin-left:5px; font-size:.8rem; color:#fe5806;
}
/* おしらせ */

/*お客様の声*/
#homeVoice{ background-color:#efefef; margin-bottom:0; }
#homeVoice #voiceList{ display:flex; flex-wrap:wrap; justify-content:space-between;}
#homeVoice #voiceList li{ width:43vw; margin-bottom:5vw; border:1px solid #ccc; position:relative;}
#homeVoice #voiceList a{ display:block; width:100%; height:100%; background-color:#f6f6f6; }
#homeVoice #voiceList .pict{
    width:100%; height:30vw; overflow:hidden; background-color:#162; position:relative;
}
#homeVoice #voiceList .title{ font-size:3.6vw; line-height:5.2vw; padding:10px 2vw 5px; }
#homeVoice #voiceList .new{ 
    font-size:3vw; color:#fff; position:absolute; top:0; left:0; padding:2px;
    display:block; background-color:red;
}
#homeVoice #voiceList .header{ font-size:3.6vw; line-height:5.2vw; padding:0 2vw 3vw; }
/*お客様の声*/

/* フッタ上リンク */
.halfFlex{ display:flex; flex-wrap:wrap; }
.halfFlex li{ width:100%; border-top:1px solid #ccc; }
#homeCompany{ margin-bottom:0; padding:0; }
#homeCompany .halfFlex li{ height:45vw; background-color:#251; position:relative;}
#homeCompany .halfFlex li a{ display:block; width:100%; height:100%; }
#homeCompany .halfFlex li a .title{
    display:flex; align-items:center; justify-content:center; width:100%; height:100%;
    position:relative; z-index:10;
}
#homeVoice #voiceList .new{
    position:absolute; top:0; left:0; display:block; background-color:red; color:#fff;
    font-size:.7rem; padding:0 5px;
}
#homeCompany .halfFlex li a .title p{ color:#fff; text-align:center; font-weight:bold; }
#homeCompany .halfFlex li a .title .header{ font-size:1.8rem; }
.bgPanel{background-position:center; background-size:cover; background-repeat:no-repeat;}
#homeCompany .halfFlex li .bgPanel{
    position:absolute; width:100%; height:100%; top:0; left:0; opacity:.5; transition:.3s;
}
#homeCompany .halfFlex li a:hover .bgPanel{ opacity:1; overflow:hidden; }
#homeCompany .halfFlex li a:hover .title p{ text-shadow:0 0 3px rgba(0,0,0,.75); }

/* フッタ上リンク */  

/**** HOME ****/



/**** 下層 ****/
.underPage .pageBlock{ width:100%; }
.underPage .pageBlock:last-of-type{ padding-bottom:0; }
.underPage section.pageContHead{ margin-bottom:0px; padding:100px 0 0; }
.underPage .pageContHead .pageTopImg{ width:100%; height:; margin:0 auto; }
.underPage #pageLead{ margin-bottom:120px; }
.underPage .pageCopy{ font-size:1.8rem; text-align:justify; font-weight:bold; color:#162; margin-bottom:40px; line-height: 1.4;}
.underPage .leadText{ text-align:justify; }
.underPage .object{ display:flex; margin:15px 0; }
.noteSpot{ color:#fe5806; font-size:.85rem; }
.orangeTxt{ color:#fe5806; }
.note{ font-size:.85rem; margin-top:10px; }
.midashi{ font-size:1.5rem; font-weight:bold; color:#787; position:relative; text-align:center; margin-bottom: 20px;}
.midashi::after{
    content:''; display:block; width:150px; height:2px; background-color:#162; 
    position:absolute; bottom:-.5rem; left:calc(50% - 75px); 
}
.pointHeader{ text-align:center; margin-bottom:40px; position:relative; }
.pointHeader p{
    display:inline-block; font-size:1.5rem; font-weight:bold; color:#fff; background-color:#787; 
    padding:0 16px; margin:0 auto; border-radius:2px;
}
.pointHeader .subHeader{ display:block; text-align:center; font-size:.8rem; color:#666; }
.contentBox{ margin-bottom:100px; }
.contentInnerBox{ width:1100px; margin:0 auto; }
.anchor{ position:absolute; top:-120px; }


/*UL*/
.cardList{ display:flex; flex-wrap:wrap; justify-content:space-between; }
.cardList li{ width:46%; margin-bottom:25px; }
.cardList li:last-of-type{ margin-right:0; }
.cardList li .pict{ height:30vw; }
/*UL*/

/*TABLE*/
.basicTable{ width:100%; border:1px solid #ccc; border-bottom-color:transparent; }
.basicTable tbody{ width:100%; }
.basicTable tr{ border-bottom:1px solid #ccc; display:block; width:100%; }
.basicTable th,
.basicTable td{ padding:3vw; display:block;  width:100%; }
.basicTable th{ color:#162; }
/*TABLE*/

/** 下層ページのターミナル **/
.underPage .pageBlock.terminal{ width:90%; margin:0 auto; padding:50px 0; }
.underPageCross{  }
.underPageCross li{ width:100%; margin-bottom:60px; position:relative; }
.underPageCross li .pict{ height:66vw; }
.underPageCross li .pageIntro{
    text-align:center; width:75%; margin:0 auto; padding:5vw 0; position:absolute;
    left:10%; bottom:-5vw; background-color:rgba(255,255,255,.92);
}
.underPageCross li .pageIntro .pageTitle{ font-weight:bold; font-size:1.2rem; }
.underPageCross li .pageIntro .pageTitleSup{ color:#162; }
.underPageCross li .pageIntro .moreBtn{ margin-top:15px; }
.underPageCross li .pageIntro .moreBtn a{ width:50vw; padding:2vw }
/** 下層ページのターミナル **/

/** about 概要・用途 **/
/* 4つのメリット */
#maritList .merit{ margin-bottom:120px; }
#maritList .maritTitle{
    position:relative; margin-bottom:20px; padding-bottom:10px;
    height:auto; display:flex; flex-wrap:wrap; align-items:center;
    border-bottom:1px solid #162;
}
#maritList .maritTitle .sub{
    font-size:1rem; line-height:1.2rem; color:#333; position:relative; text-align: center; margin-right:40px; 
}
#maritList .maritTitle .sub .num{
    display:inline-block; font-size:1.4rem; font-weight:bold; color:#162; margin-left:10px;
}
#maritList .maritTitle .header{ font-size:2rem; line-height:3rem; color:#162; }

#maritList .merit .cont{ display:flex; flex-wrap:wrap; justify-content: flex-end; }
#maritList .merit .cont .problem,
#maritList .merit .cont .answer{ width:100%; }
#maritList .merit .cont .problem{ margin-bottom:50px; }
#maritList .merit .cont .text{ text-align:justify;  }
#maritList .merit .cont .problem .pict{ width:85%; margin:0 auto; }
#maritList .merit .cont .answer{ background-color:rgba(12,144,48,.1); padding:25px; position:relative; }
#maritList .merit .cont .answer::before{
    content:'answer'; position:absolute; top:-2rem; left:22px; font-size:2.4rem; color:#6caf79;
    font-family:'Century Gothic','Avenir Next',sans-serif;
}
#maritList .merit:first-of-type .answer .object{ background-color:#fff; border-radius:5px; padding-bottom:10px; }
#maritList .merit:first-of-type .answer .object .pict{ margin:0 auto; }
#maritList .merit:nth-of-type(4) .answer .object{ width:100%; }
#maritList .merit:nth-of-type(4) .answer .object .pict{ width:80%; margin:0 auto; }
#maritList .merit:nth-of-type(4) .text img{ width:100%; margin-top:12px; }
#meritStopCopy .header{
    font-size:1.8rem; line-height:2.8rem; font-weight:bold; color:#fe5806; text-align:justify; margin-bottom:15px;
}
#maritStopPict{ width:100%; margin:12px auto; position:relative; }
#maritStopPict .pict{ width:90%; margin:0 auto; padding-top:32%; }
#maritStopPict .BC{
    content:'Best Choice'; position:absolute; left:0; top:-4%; transform:rotate(-8deg);
    font-size:5rem;line-height:5.3rem; font-weight:bold; font-family:serif; 
    color:#6caf79;  
}
/* 4つのメリット */

/* 運用事例 */
#aboutOperationCont .about-opeBlock{ margin-bottom:100px; position:relative;}
#aboutOperationCont .pageLead{ margin-bottom:30px; }
.lb-data .lb-details .lb-caption{ color:#fff !important; }
#aboutOperationCont .title{ margin-top:8px; font-weight:bold; color:#162; line-height:1.4rem; }
#aboutOperationCont h2{
    margin-bottom:10px; font-weight:bold; color:#333; font-size:1.2rem; position:relative; color:#555;
}
#aboutOperationCont h2::before{
    content:''; display:inline-block; width:1rem; height:1rem; background-color:#162; border-radius:50%;
    margin-right:5px;
}
#aboutOperationCont .semiBlock{ margin-bottom:60px; }
#aboutOperationCont #gohu .cardList{ margin-top:30px; }
#aboutOperationCont #aboutOpeDisaster{ margin-bottom:0; }

/*0825追加*/
#aboutOperationCont .blockHeader{ margin-bottom:15px;  }
#aboutOperationCont .blockHeader .blockTitle{ 
    position:relative; font-size:1.3rem; font-weight:bold; color:#666; margin-bottom:8px;
    padding-left:1.2rem;
}
#aboutOperationCont .blockHeader .blockTitle::before{
    content:''; position:absolute; top:.45rem; left:0;
    display:block; width:1rem; height:1rem; background-color:#162;
    border-radius:50%; 
}
#aboutOperationCont .blockLead{
    padding:15px; background-color:#f3f3f3; border-radius:5px; font-size:.85rem;
}
.eventBlock .cardList{ margin-bottom:60px; padding-bottom:30px; border-bottom:1px dotted #ccc; }


/* 運用事例 */

/*機能・種類*/
#aboutType.pageBlock{ width:100%; padding:100px 0 0; margin-bottom:0; }
#aboutType.pageBlock .contentBox{ width:100%; }
#aboutType.pageBlock .contentInnerBox{ width:92%; margin:0 auto; }
#aboutType #pageLead{ width:100%; margin:0 auto 100px; }
#aboutType .pdfDwn{ margin:75px 0 30px; }
#aboutType .pdfDwn .pdfDwnCase .dwBtn{
    display:inline-block; line-height: 1.4;
    background-color:#162; color:#fff; padding:10px; border-radius:6px; margin-bottom:3vw;
    transition:.3s; font-size:1.2rem; font-weight:bold;
}

/*youtube*/
#aboutType #youtubeHeader{ margin-top:80px; }
#aboutType #youtubeBox .ifrCase{
    width:100%; height:0; margin:20px auto 40px; padding-top:56.5%; position:relative;
}
#aboutType #youtubeBox iframe{ position: absolute; top: 0; left: 0; width: 100% !important; height: 100% !important; min-height: unset;}


/*レイアウト*/
#aboutType #layoutBox{scroll-margin-top: -50px;}
#aboutType #layoutBox.contentBox{ width:100%; background-color:rgba(12,144,48,.1);; padding:100px 0 50px; }
#aboutType #pageLead .header{ font-weight:bold; font-size:1.1rem; }
#aboutType #pageLead .header span{ font-size:1.4rem; margin-left:10px; }
#aboutType #pageLead .object .pict{ width:120px; margin-right:10px; }
#aboutType #pageLead .object .pict#shakensho{ width:150px; border:1px solid #ccc; }
#aboutType #kaitekiToillet{ align-items:center; justify-content:center; }
#aboutType #toilrtCarPict{ width:50vw; max-width: unset; margin:30px auto; }
#aboutType #kaitekiText{ width:100%; max-width: unset; margin-left: 0; }
#aboutType #kaitekiText .noteSpot{ margin-top:12px; }
#aboutType .type-imageCut { display:flex; margin-top:20px; }
#aboutType #toilrtCarPict img{ width:100%; }
#aboutType #layoutBlock{ margin-top:30px; }
#aboutType #layoutBlock.slider{ width:100%; }
#aboutType #layoutBlock.slider .slick-list{ width:100%; padding:0 !important; }
#aboutType #layoutBlock.slider .slick-slide{ padding:0 5vw; }

#aboutType #layoutBlock li{ display:flex; justify-content:center; flex-wrap:wrap;}
#aboutType #layoutBlock li .equipment{ width:100%; display:flex; margin-top:20px; flex-wrap: wrap; justify-content: center; }
#aboutType #layoutBlock li .equipment .equipName{
    padding:0 8px; border:1px solid #ccc; margin-right:10px; margin-bottom: 5px; background-color:#fff; color:#555;
}
#aboutType #layoutBlock li .object{ width:100%; margin:30px auto 0; justify-content:space-between; flex-wrap:wrap; }
#aboutType #layoutBlock li .object .equipPict{ width:calc(50% - 10px); margin:0 0 4vw 0; }
#aboutType #layoutBlock li .object .pict img{ width:100%; }
#aboutType #layoutBlock .layoutGraph{ width:100%; }
#aboutType #layoutBlock .layoutGraph img{ width:95%; max-width: 500px; margin: 0 auto; }
#aboutType #layoutBlock #twoRoom .layoutGraph{ width:100%; }
#aboutType .slideThumb{ width:100%; margin:0 auto; }
#aboutType .slideThumb .slick-slide{ margin-right:10px; }
#aboutType .slideThumb .slick-slide:nth-of-type(3){ margin-right:0; }
#aboutType .slideThumb .slick-slide .header{
    width:100%; background-color:#fff; padding:8px 0; border:1px solid #ccc; border-radius:2px;
    text-align:center; font-size:1rem; line-height:1.4rem; color:#999;
}
#aboutType .slideThumb .slick-slide.slick-current .header{ background-color:#162; color:#fff; font-weight:bold;}

/*設備*/
#aboutType #exteriaBox .pageCopy{ width:100%; margin:0 auto 40px; }
#aboutType #exteriaBox.contentBox{ width:100%; background-color:rgba(12,144,48,.1);; padding-top:100px }
#aboutType #exteriaBox.contentBox .cardList{ width:100%; max-width: unset; margin:0 auto; padding-bottom:50px; }
#aboutType .cardList li{ width:42vw; margin-bottom:36px; margin-right: 0; }
#aboutType .cardList li:nth-of-type(4n){ margin-right:0; }
#aboutType .cardList li .header{ font-weight:bold; font-size:1.1rem; margin-top:4px; color:#162; }
#aboutType .cardList li .text{
    padding:10px; background-color:rgba(12,144,48,.1); border-radius:3px; font-size:.9rem; line-height:1.5rem; 
}
#aboutType .cardList li .pict{ height:37vw; }
#aboutType .cardList li .pict.irregular{ height:auto; }
#aboutType #exteriaBox .cardList li .text{background-color:#fff; }

/*寸法*/
#aboutType #specs.contentBox{  } 
#aboutType #specs .cardList{ position:relative;}
#aboutType #specs .cardList::before{
    content:''; position:absolute; left:2vw; top:0; width:30px; height:30vw; line-height:30vw;
    border:1px solid #999; border-left-color:transparent; border-right-color:transparent;
}
#aboutType #specs .cardList::after{
    content:''; position:absolute; left:4vw; top:0;
    width:1px; height:30vw; background-color:#999;  
}
#aboutType #specs .cardList li{ width:50%; height:30vw; }
#aboutType #specs .cardList li:first-of-type{ margin-bottom:80px; }
#aboutType #specs .cardList li .pict{ height:100%; text-align:center; }
#aboutType #specs .cardList li .pict img{ height:100%; width:auto; margin: 0 auto;}
#aboutType #specs .cardList li#frontPict,
#aboutType #specs .cardList li#rightPict{ position:relative; }
#aboutType #specs .cardList li#frontPict::before{
    content:''; display:block; width:20vw; height:1px; background-color:#999;
    position:absolute; left:13vw; bottom:-40px;  
}
#aboutType #specs .cardList li#frontPict::after{
    content:'167cm'; width:20vw; height:40px; text-align:center;
    border:1px solid #999; border-top-color:transparent; border-bottom-color:transparent;
    position:absolute; left:13vw; bottom:-60px; font-size: 14px;
}
#aboutType #specs .cardList li#rightPict::before{
    content:''; display:block; width:calc(40vw - 2px); height:1px; background-color:#999;
    position:absolute; left:3.5vw; bottom:-40px;  
}
#aboutType #specs .cardList li#rightPict::after{
    content:'365cm'; width:calc(40vw - 2px); height:40px; text-align:center;
    border:1px solid #999; border-top-color:transparent; border-bottom-color:transparent;
    position:absolute; left:3.5vw; bottom:-60px; font-size: 14px;
}
#aboutType #specs .cardList li#carHeight{
    position:absolute; left:-6.5vw; top:12%; transform:rotate(-90deg);
    width:17vw; height:fit-content; z-index: 2; font-size: 14px;
}

#aboutType #specs #carData{ display:flex; justify-content:space-between; flex-wrap:wrap; }
#aboutType #specs #carData .carDataTable{ width:100%; }
#aboutType #specs #carData .carDataTable li{ margin-bottom:15px; border:1px solid #ccc; }
#aboutType #specs #carData .carDataTable .header{ background-color:#162; color:#fff; padding:2px 10px; }
#aboutType #specs #carData .carDataTable .text{ padding:10px; }
#aboutType #specs #carData .carDataTable .hyojun span{ display:inline-block; margin-right:15px; vertical-align:text-top}
#aboutType #specs #number8{ background-color:#fe5806; color:#fff; padding:2px 6px; }
#aboutType #specs #carData .carDataTable table{ width:100%; margin:5px 0; display:block; }
#aboutType #specs #carData .carDataTable table tr{ width:100%;display:block; }
#aboutType #specs #carData .carDataTable td{ width:100%; padding:3px 10px; display:block; }
#aboutType #specs #carData .carDataTable td span{ font-weight:bold; color:#666; }
/*機能・種類*/
/** about 概要・用途 **/


/** 会社概要 **/
#companyFirstSec{ padding-bottom:0; margin-bottom:0; }
#companyHeaderImg .pict{ width:100%; text-align:center; }
#companyHeaderImg img{ width:40vw; height:auto; }
.cornerHeader .header{
    text-align:center; font-size:2.4rem; color:#999; margin-bottom:30px; letter-spacing:.3rem;
    position:relative;
}
#companyData .basicTable{ margin-bottom:100px; }
#kanren .basicTable{ margin-bottom:; }
#companyData .basicTable th{ width: 100%; background-color:#ebf5ed; text-align:center; font-weight:bold; }
#companyData .basicTable td .td-link{color: var(--text-color); text-decoration: underline; transition: all .1s;}
#companyData .basicTable td .td-link:hover{color: #162; transition: all .1s;}
#companyData #kanren .basicTable td,
#companyData #torihiki .basicTable td{ border-bottom:1px solid #ccc; }
#companyData #kanren .basicTable tr td:last-of-type,
#companyData #torihiki .basicTable tr td:last-of-type{ border-bottom:none; }
#companyData #torihiki .basicTable{ margin-bottom:15vw }
#companyData #torihiki .basicTable caption{ color:#162; font-size:5vw }
/** 会社概要 **/

/** お知らせ **/
.NewsPage .pagePrevBox{ display:flex; justify-content:center; margin-top:20px; }
.NewsPage .pagePrevBox .pagePrev a,
.NewsPage .pagePrevBox .pageNext a{
    margin:0 10px; padding:6px 12px; border:1px solid #162; transition:.3s; 
}
.NewsPage .pagePrevBox .pagePrev a:hover,
.NewsPage .pagePrevBox .pageNext a:hover{ background-color:#162; color:#fff; }
.NewsHomeBtn{ margin:40px auto 0; }
.NewsHomeBtn a{
    display:block; width:70%; margin: 0 auto; padding:6px; border:1px solid #162; transition:.3s; 
    text-align:center; 
}
.NewsDetailBox .infoTitle{ font-size:2rem; font-weight:bold; margin-bottom:30px; color:#162; }

.NewsDetailBox .entryBody a img{ max-width:100%; width:auto; }
/** お知らせ **/

/** お客様の声 **/
.VoicePage #topicList{ width:100%; display:flex; flex-wrap:wrap; justify-content:space-between; }
.VoicePage #topicList li{
    width:47%; margin-bottom:60px; border:1px solid #ccc; position:relative;
}
.VoicePage #topicList li a{ display:block; border:none; padding:0; position:relative;}
.VoicePage #topicList li .thumb{
    position:relative; top:0; left:0; width:100%; height:30vw;
    background-image:url(/common/images/daitai.png); background-size:cover; background-position:center;
}
.VoicePage #topicList li .thumbnail_target{
    position: absolute; top:0; left:0; z-index:2; width:100%; height:30vw; overflow:hidden; 
}
.VoicePage #topicList li .thumbnail_target img{ width:100%; height:100%; }
.VoicePage #topicList li .title{
    padding:8px 2vw 0; font-weight:bold; font-size:110%; line-height:1.4; color:#162;
    margin-bottom:3px;
}
.VoicePage #topicList .new{ 
    font-size:3vw; color:#fff; position:absolute; top:0; left:0; padding:0 2px;
    display:block; background-color:red; z-index:12; margin:0;
}
.VoicePage #topicList li .header{ padding:0 2vw 3vw; line-height:1.4; }
.voiceDetailPage .entryBody a img{ max-width:100%; margin:20px 0; }

.NewsDetailBox .infoTitle .mainT{
    font-size:2rem; font-weight:bold; color:#162; line-height:1.4;
}
.NewsDetailBox .infoTitle .subTxt{
    display:inline-block; padding:5px 10px; background-color:#efefef; border-radius:2px; font-size:16px; font-weight:normal; color:#333
}
/** お客様の声 **/
.pagePrevBox{ display:flex; justify-content:center; }
.pagePrevBox p{ padding:15px; }
.pagePrevBox p a{color:#162; font-weight:bold;}


/** 個人情報保護方針 **/
#privacyBlock{ padding-top:0; }
#privacyBlock .privacyList{ width:100%; }
#privacyBlock .privacyList li{ margin-bottom:80px; }
#privacyBlock .privacyList li .listNum{ font-weight:bold; font-size:1.4rem; color:#162; margin-bottom:10px; }
#privacyBlock .privacyList li dl{ margin-top:20px; padding-left:5vw; }
#privacyBlock .privacyList li dt{ font-size:1.1rem; font-weight:bold; color:#666; margin-bottom:6px; }
#privacyBlock .privacyList li dd{ margin-bottom:30px; }
/** 個人情報保護方針 **/

/** サイトマップ **/
#sitemapUrlList .cardList{ justify-content:space-between; }
#sitemapUrlList .cardList li { width:100%; margin-bottom:0; }
#sitemapUrlList dl{ margin-bottom:30px; border-bottom:2px solid #ccc; padding:5vw; }
#sitemapUrlList dt{ font-size:1.6rem; font-weight:bold; margin-bottom:10px; }
#sitemapUrlList dt .text{ font-size:.9rem; color:#666; }
#sitemapUrlList dd{ padding-left:20px; margin-bottom:6px; }
#sitemapUrlList dd.sub{ padding-left:40px; }
#sitemapUrlList a{ transition:.3s; font-weight:bold; }
#sitemapUrlList a:hover{ color:#162; }
/** サイトマップ **/

/**** contact ****/
#contactSec{ padding-top:100px; }
#contactSec .leadText{ text-align:center; margin-bottom:40px; }
.contactBlock{ width:100%; padding:; border:2px solid #162; background-color:#f9f9f9; }
.contactBlock form{ width:100%; }
.tableCase.formTable{ padding:0 4vw; width:100%; }
.inputTable{ display:block; width:100%; }
.inputTable tbody{ display:block; width:100%; }
.inputTable tr{
    border-bottom:1px solid #ccc; display:flex; flex-wrap:wrap; width:100%; padding:20px 0;
}
.inputTable th,
.inputTable td{ display:block; width:100%; text-align:left; font-size:1rem; }
.inputTable th{ padding-bottom:5px; margin-bottom:8px; border-bottom:1px dotted #ccc; }
.inputTable .hissu{ color:#e33; padding-left:.5rem; }
.inputTable th .formKoumokuAdd{
    margin-top:8px; border-radius:3px; border:2px solid #aaa;
    font-size:.85rem; padding:5px 10px;
}
.inputTable .formKoumokuAdd .strong{
    display:inline-block; font-size:1rem; font-weight:bold; background-color:#162; 
    padding:5px 8px; margin-right:5px; margin-bottom:5px;
    border-radius:3px; color:#fff;
}
.inputTable td input[type=text]{
    width:100%; padding:.5rem; background-color:#fff; border:1px solid #ccc;
    font-size:1rem; border-radius:2px;
}
.inputTable td input[type=checkbox]{ display:none; }
.inputTable td input[type=radio] {display: inline !important; margin: -3px 7px 0 7px !important; accent-color: #162 !important; height: 16px; width: 16px; vertical-align: middle;}
.inputTable td .typeRadio{ position:relative; padding-left:2rem;}
.inputTable td .typeRadio::before{
    content:''; display:inline-block; width:18px; height:18px; position:absolute; top:0; left:0;
    border-radius:50%; border:1px solid #ccc; background-color:#fff; box-sizing:border-box;
}
.inputTable td input[type=radio] + .typeRadio::after{
    content:''; display:block; position:absolute; top:3px; left:3px; 
    width:12px; height:12px; background-color:#162; border-radius:50%; opacity:0; transition:.2s;
}
.inputTable td input[type=radio]:checked + .typeRadio::after{ opacity:1; }
.inputTable td .typeChBox{ position:relative; padding-left:1.75rem; display:block; width:100%; }
.inputTable td .typeChBox::before{
    content:''; display:inline-block; width:18px; height:18px; position:absolute; top:0; left:0;
    border:1px solid #ccc; background-color:#fff; box-sizing:border-box;
}
.inputTable td input[type=checkbox] + .typeChBox::after{
    content:''; display:block; position:absolute; top:0; left:3px; width:12px; height:6px; 
    border:2px solid transparent; border-left-color:#162; border-bottom-color:#162;
    transform:rotate(-45deg) skewX(-5deg); opacity:0; transition:.2s;
}
.inputTable td input[type=checkbox]:checked + .typeChBox::after{ opacity:1; }
.inputTable #addressRow td div{ margin-bottom:8px; }
.inputTable td .postal input{ width:70%; margin-left:10px; }
.inputTable td select{
    -webkit-appearance:none; appearance:none; position:relative; background-color: #fff;
    width:100%; padding:.5rem; border:1px solid #ccc; border-radius:2px; background-color;
    padding:.5rem; font-size:1rem;
}
.selectBox{ position:relative; }
.selectBox::after{
    content:''; display:block; width:10px; height:10px; 
    position:absolute; top:16px; right:7%; border-bottom:2px solid #333; border-right:2px solid #333; 
    transform:rotate(45deg); pointer-events:none;
}
.inputTable td textarea{ width:100%; height:8rem;         background-color: #fff; border:1px solid #ccc; padding:.5rem; }
.submitArea{background-color:#fff; padding:20px 0; margin-top:20px; border-radius:5px; }
.submitArea .g-recaptcha > div{ margin:0 auto; }
.submitArea #contact_submit{
    display:block; width:80%; margin:15px auto; padding:5px; color:#fff; font-weight:bold; 
    border-radius:2px; background-color:#162; text-align:center;
}
	
.inputTable .hissu{ background-color: #e33; border-radius: 3px; color: white !important; padding-right: 5px; margin-left: 5px; font-size: 13px; padding-left: 4px; padding-bottom: 1px;}
.inputTable .nini {background-color: #797676; padding-left: 4px; padding-bottom: 1px; border-radius: 3px; color: white; padding-right: 5px; margin-left: 5px; font-size: 13px;
}
	
#required_confirm{ text-align:center; }
.hissRecapcha {
    background-color: #e33;
    padding-left: 6px;
    border-radius: 3px;
    color: white !important;
    padding-right: 5px;
    font-size: 13px;
    width: 40px;
	margin: 0 auto;
}

.anketo {border-left: thick solid #162 !important; font-size: 20px; font-weight: bold; color: #163; margin-top: 20px; padding-left: 10px;}
	
.komoku {color: #e33; font-weight: bold;}
	
.errorMessage{color: #e33; font-size: 16px;}
#txt_others_er{width: calc(100% - 165px); margin: 0 0 0 auto;}
	
/* 確認 */
.submitArea form{ display:flex; justify-content:center; margin: 0 20px; width: calc(100% - 40px);}
.submitArea input[type=button].typeBack{
    width:80%; padding:5px; border:1px solid #162; margin-right:10px; text-align: center;
}
.submitArea input[type=submit]{
    width:80%; padding:5px; background-color:#162; color:#fff; border:none; text-align: center;
}

.contactPageImg{width:150px; margin:0 auto 20px; }
	
#contactSendEndPage{margin: 100px 5vw;}
#contactSendEndPage .pageCopy{ text-align:center; }
#contactSendEndPage .pict img{max-width: 150px;}

/**** contact ****/

	
.forTitleTxt{ font-family:'Century Gothic','Avenir Next','sans-serif'; }
	
		
}

@media screen and (max-width: 587px){

#txt_others_er{width: 100%;}
	
}