@charset "UTF-8";

/*==============================
下層ページ
===============================*/
.ColorWhite {
	color: #fff;
}

.ColorLiteBlue {
    color: #00a0dc;
}

.LowMainTitle {
    padding: 210px 0 80px; /* トップマージンはボトムプラス130px */
    /*background-color: #0a51a3;*/
    max-height: 80vh;
    text-align: center;
    color: #fff;
}
@media screen and (max-width: 1180px) {
	.LowMainTitle {
		padding: 180px 0 100px;
	}
}
.LowMainTitle h2 {
    font-size: 1.8em;
}

#Low h3 {
    font-size: 1.5em;
    margin-bottom: 2.7em;
    position: relative;
    text-align: center;
}
#Low h3::before {
background: #1E90FF;
background: linear-gradient(90deg,rgba(30, 144, 255, 1) 0%, rgba(0, 160, 220, 1) 100%);
  border-radius: 5px;
  bottom: -.7em;
  content: "";
  height: 3px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%); /* 線の中央寄せ */
  width: 4em;
}

#Low h4 {
  padding: 0.3em .9em;/*文字周りの余白*/
  background: #eaf3ff;/*背景色*/
  border-bottom: solid 2px #013d82;/*下線*/
    font-size: 1.2em;
    margin-bottom: 1.2em;
    font-weight: bold;
}
#Low h5 {
    font-size: 1.1em;
    font-weight: bold;
    border-bottom: 1px solid #013d82;
    padding-bottom: .2em;
    margin-bottom: 1em;
}
#Low h6 {
    font-size: 1.1em;
    font-weight: bold;
    border-left: 4px solid #013d82;
    padding-left: .2em;
    margin-bottom: 1em;
}

#Low table {
    border-collapse:  collapse; /* セルの線を重ねる */
    width:  100%;               /* 幅指定 */
    background-color: #fff;
}
#Low th,#Low td {
    border: solid 1px #ccc;          /* 枠線指定 */
    padding: 14px 20px;
    line-height: 1.7;
}
#Low th {
    text-align: left;           /* 文字の揃え位置指定 */
    background: #eaf3ff;/*背景色*/
}
#Low td {
    text-align: left;        /* 文字の揃え位置指定 */
    text-align: justify;
}
#Low table ul {
    list-style: disc outside;
    margin-left: 1em;
}

#Low .WAll {
    max-width: 100%;
    margin: auto;
}
#Low .W1200Box {
    max-width: 1200px;
    margin: auto;
}
#Low .W1050Box {
    max-width: 1050px;
    margin: auto;
}
#Low .W980Box {
    max-width: 980px;
    margin: auto;
}
#Low .W880Box {
    max-width: 880px;
    margin: auto;
}
#Low .W780Box {
    max-width: 780px;
    margin: auto;
}
#Low .W680Box {
    max-width: 680px;
    margin: auto;
}
@media screen and (max-width: 800px) {
    #Low .W1200Box,
    #Low .W1050Box,
    #Low .W980Box,
    #Low .W880Box,
    #Low .W780Box,
    #Low .W680Box {
        width: 100%;
    }
}

#Low .overwrapBox {
    /*height: 200px;*/
    position: relative;
    display: flex;
    align-items: center;
}
@media screen and (max-width: 800px) {
    #Low .overwrapBox {
        position: unset;
        display: block;
    }
}
#Low .overwrapBox .ObjectLeft {
    width: 40%;
    /*height: 200px;*/
    margin: 0;
    display: grid;
    place-items: center center;
	position: absolute;
	top: 2vw;
}
@media screen and (max-width: 800px) {
    #Low .overwrapBox .ObjectLeft {
        width: 100%;
		position: static;
		top: 0;
    }
}
#Low .overwrapBox .txtRight {
    /*position: absolute;*/
    /*right: 0;*/
    /*top: clamp(10px, 4vw, 70px);*/
    width: 65%;
    color: #fff;
    background: rgba(50, 50, 50, .98);
    padding: 60px 70px;
    box-sizing: border-box;
    z-index: 1;
	text-align: justify;
	margin-top: clamp(50px, 6vw, 100px);
	margin-right: 0;
	margin-left: auto;
}
@media screen and (max-width: 800px) {
    #Low .overwrapBox .txtRight {
        width: 100%;
        position: unset;
		margin-top: 0;
    }
}

#Low .overwrapBoxTwoPhoto .TwoPhoto {
    width: 90%;
    display: flex;
    gap: 4px;
    flex-wrap: nowrap;
}
#Low .overwrapBoxTwoPhoto .TwoPhoto .InFirst,
#Low .overwrapBoxTwoPhoto .TwoPhoto .InSecond {
    width: 50%;
}
#Low .overwrapBoxTwoPhoto .txtBottom {
    width: 80%;
    margin: -60px 0 0 auto;
    color: #fff;
    background: rgba(50, 50, 50, .98);
    padding: 60px 70px;
    box-sizing: border-box;
    z-index: 1;
    text-align: justify;
}

@media screen and (max-width: 800px) {
    #Low .overwrapBoxTwoPhoto .TwoPhoto {
        display: block;
    }
    #Low .overwrapBoxTwoPhoto .TwoPhoto .InFirst,
    #Low .overwrapBoxTwoPhoto .TwoPhoto .InSecond {
        width: 100%;
    }
    #Low .overwrapBoxTwoPhoto .txtBottom {
        margin-top: -60px;
        width: 95%;
    }
}


.LH18 {
    line-height: 1.8;
}

#Low .BackBlue {
	color: #fff;
	/*background: rgba(50, 50, 50, .98);*/
	background-color: rgba(24, 62, 126, .8);
	padding: 60px 70px;
}

#Low .list-circle>li {
    padding-left: 30px;
    margin-top: 1em;
    position: relative;
}
#Low .list-circle>li.blue::before {
    content: "";
    background: #013d82;
    display: block;
    width: 0.5em;
    height: 0.5em;
    border-radius: 100%;
    position: absolute;
    top: 0.6em;
    left: .6em;
}


#Low .VideoTwo .Grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4%;
}
#Low .VideoTwo .Grid video {
    width: 100%;
}
#Low .VideoTwo .flex {
    justify-content: center;
    gap: 4%;
}
#Low .VideoTwo .flex div {
    width: 48%;
    margin-bottom: 30px;
}
@media screen and (max-width: 800px) {
    #Low .VideoTwo .flex div {
        width: 100%;
    }
}
#Low .VideoTwo .flex div video {
    width: 100%;
}



/*==============================
事業紹介ディレクトリ
===============================*/
#Low .BgPlant {
    background:#fff url(../img/engineering/plant/prosess/bg_process.png) no-repeat right center;
    background-attachment: fixed;
    /*background-size: contain;*/
}
@media screen and (max-width: 800px) {
    #Low .BgPlant {
        background:#fff url(../img/engineering/plant/prosess/bg_process.png) no-repeat right top;
        background-attachment: fixed;
    }
}
#Low .BgPlant:before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -2;
    width: 100%;
    height: 100vh;
    background-repeat: no-repeat;
    background-position: 50% 100%;
    background-image: url(../img/common/bg_index_plant.jpg);
    background-size: cover;
}
#Low .BgPlant:after {
    content:"";
    display:block;
    position:fixed;
    top:0;
    left:0;
    z-index:-2;
    width:100%;
    height:100vh;
    background-size:cover;
    background-color: rgba(24, 62, 126, .8);
}


#Low .BgLife {
    background:#fff url(../img/engineering/plant/prosess/bg_process.png) no-repeat right center;
    background-attachment: fixed;
    /*background-size: contain;*/
}
@media screen and (max-width: 800px) {
    #Low .BgLife {
        background:#fff url(../img/engineering/plant/prosess/bg_process.png) no-repeat right top;
        background-attachment: fixed;
    }
}
#Low .BgLife:before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -2;
    width: 100%;
    height: 100vh;
    background-repeat: no-repeat;
    background-position: 50% 100%;
    background-image: url(../img/common/bg_index_life.jpg);
    background-size: cover;
}
#Low .BgLife:after {
    content:"";
    display:block;
    position:fixed;
    top:0;
    left:0;
    z-index:-2;
    width:100%;
    height:100vh;
    background-size:cover;
    background-color: rgba(24, 62, 126, .8);
}

/*==============================
アコーディオン
===============================*/
#Low .toggle {
	display: none;
}
#Low .Label {		/*タイトル*/
	padding: .6em 1em;
	display: block;
	cursor: pointer;
}
#Low .Label::before{		/*タイトル横の矢印*/
	content:"";
	width: 6px;
	height: 6px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	position: absolute;
	top:calc( 50% - 3px );
	right: 20px;
	transform: rotate(135deg);
}
#Low .Label,
#Low .content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
#Low .content {		/*本文*/
	height: 0;
	margin-bottom:10px;
	padding:0 20px;
	overflow: hidden;
	font-size: .9em;
	line-height: 1.7;
}
#Low .toggle:checked + .Label + .content {	/*開閉時*/
	height: auto;
	padding:20px ;
	transition: all .3s;
}
#Low .toggle:checked + .Label::before {
	transform: rotate(-45deg) !important;
}

/*==============================
実績紹介ディレクトリ
===============================*/
#Low .achievements {
    background:#fff;
}
@media screen and (max-width: 800px) {
    #Low .achievements {
        background:#fff;
    }
}
#Low .achievements:before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -2;
    width: 100%;
    height: 100vh;
    background-repeat: no-repeat;
    background-position: 50% 100%;
    background-image: url(../img/common/bg_index_plant.jpg);
    background-size: cover;
}
#Low .achievements:after {
    content:"";
    display:block;
    position:fixed;
    top:0;
    left:0;
    z-index:-2;
    width:100%;
    height:100vh;
    background-size:cover;
    background-color: rgba(24, 62, 126, .8);
}

/*==============================
ビジネスコンテンツの業務内容テーブル
===============================*/
#BusinessCont table th {
    white-space: nowrap;
    font-weight: bold;
}
@media screen and (max-width: 800px) {
    #BusinessCont table tr {
        display: flex;
        flex-direction: column;
    }
}
#BusinessCont .ExObj {
    display: flex;
    gap:40px;
    flex-wrap: wrap;
    justify-content: center;
}
#BusinessCont .ExObj dl {
    flex: 1;
    min-width: calc(25% - 40px);
    max-width: calc(25% - 40px);
    position: relative;
}
@media screen and (max-width: 800px) {
    #BusinessCont .ExObj {
        gap:30px;
    }
    #BusinessCont .ExObj dl {
        min-width: calc(50% - 15px);
        max-width: calc(50% - 15px);
    }
}
#BusinessCont .ExObj dl dt {
    aspect-ratio: 1 / 1;
    background: #FFFFFF;
    background: linear-gradient(130deg,rgba(255, 255, 255, 1) 0%, rgba(237, 237, 237, 1) 100%);
    border: 1px solid #dedede;
    padding: 16px 18px;
    display: flex;
    /* text-align: center; */
    justify-content: center;
    align-items: center;
}
#BusinessCont .ExObj dl dt img {
    height: auto;
    width: auto;
    margin-top: -8px;
}
#BusinessCont .ExObj dl dd {
    position: absolute;
    left: -.5em;
    bottom: -.5em;
    padding: .5em;
    font-style: italic;
    /*font-size: .9em;*/
    font-size: .7em;
    color: #ffe012;
    background: #333;
	line-height: 1.5;
}


/*==============================
プラントライフサイクルエンジニアリング
===============================*/
#Low #Plse:before {
    content:"";
    display:block;
    position:fixed;
    top:0;
    left:0;
    z-index:-2;
    width:100%;
    height:100vh;
    background-repeat:no-repeat;
    background-position:50% 100%;
    background-image: url(../img/common/bg_index_plant.jpg);
    background-size:cover;
}
#Low #Plse:after {
    content:"";
    display:block;
    position:fixed;
    top:0;
    left:0;
    z-index:-2;
    width:100%;
    height:100vh;
    background-size:cover;
    background-color: rgba(24, 62, 126, .8);
}


/*==============================
SF FEED
===============================*/
#Low #FsFeed .MoveBox {
    padding-bottom: 10px;
}
#Low #FsFeed .MoveBox .MovePos {
    width: 100%;
    max-width: 800px;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 5em;
    position: relative;
    z-index: 1;
}
#Low #FsFeed .MoveBox .MovePos video {
    width: 100%;
    max-width: 800px;
}

@media screen and (max-width: 800px) {
    #FsFeed .W1200Box.flex {
        flex-direction: column;
    }
    #FsFeed .W1200Box.flex .HalfBox48 {
        width: 100%;
        margin-bottom: 50px;
    }
}

#Low #BusinessContFsFeed .WorkIcon {
    margin-top: 3em;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 4px;
}
#Low #BusinessContFsFeed .WorkIcon dl {
    text-align: center;
    background-color: #dceffb;
    padding: 30px 2px 20px;
}
#Low #BusinessContFsFeed .WorkIcon dl dt {
    width: clamp(40px, 50%, 80%);
    margin: auto;
}
#Low #BusinessContFsFeed .WorkIcon dl dd {
    line-height: 1.5;
    font-weight: bold;
}
#Low #BusinessContFsFeed .WorkIcon dl dd span{
    font-size: .84em;
}
@media screen and (max-width: 800px) {
    #Low #BusinessContFsFeed .WorkIcon dl dd {
        font-size: .8em;
    }
}

#Low #BusinessCont .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 200px solid transparent;
  border-left: 200px solid transparent;
  border-top: 60px solid #00a0dc;
  border-bottom: 0;
  margin-top: 10px;
  margin-bottom: 4px;
}

#Low #BusinessContFsFeed .speechBubble {
  position: relative;
  display: inline-block;
  width: 100%;
  margin-bottom: 20px;
  padding: 16px;
  border-bottom: 1px solid #000000;
  border-radius: 8px;
  /*background-color: #d6fdff;*/
  text-align: left;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
}

#Low #BusinessContFsFeed .speechBubble::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 20px 16px 0 16px;
  border-color: #000000 transparent transparent;
  translate: -50% 100%;
}

#Low #BusinessContFsFeed .speechBubble::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 18.4px 14.7px 0 14.7px;
  border-color: #f5f5f4 transparent transparent;
  translate: -50% 100%;
}


#Low #BusinessContFsFeed .Think {
    margin-top: 1em;
    display: flex;
    justify-content: safe center;
}
#Low #BusinessContFsFeed .Think dl {
    background-color: #fff;
    width: 16%;
    margin: 0 0.6%;
}
@media (max-width: 800px) {
    #Low #BusinessContFsFeed .Think {
        flex-wrap: wrap;
    }
    #Low #BusinessContFsFeed .Think dl {
        width: 32%;
        margin: 0 0.5%;
    }
}
#Low #BusinessContFsFeed .Think dl dt {
    background-color: #eee7c9;
    text-align: center;
    font-size: .96em;
}
#Low #BusinessContFsFeed .Think dl dd {
    padding: 10px;
    font-size: .86em;
}
#Low #BusinessContFsFeed .Think dl dd ul {
    list-style: disc;
    padding-left: 1em;
    line-height: 1.6;
}

#Low #BusinessContFsFeed .summary {
    border: 2px solid #013d82;
    border-radius: 4px;
    text-align: center;
    background-color: #fff;
    padding: 10px 20px;
    width: fit-content;
    margin: auto;
    font-size: 1.1em;
    font-weight: bold;
}

@media (max-width: 800px) {
    #Low #BusinessContFsFeed .HalfBox48 {
        width: 76%;
        margin-right: auto;
        margin-left: auto;
    }
}


/*==============================
プロジェクトマネジメント
===============================*/
#Low .TenArea {
    border: solid 2px #013d82;
    background-color: #f5f5ee;
    padding: 50px 50px 40px;
}
#Low .TenArea ol {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
  margin: 0;
}
#Low .TenArea ol li {
  font-size: 1.2em;
  line-height: 1.6;
  padding-left: 2em;
  margin-bottom: .5em;
  position: relative;
  font-weight: bold;
}
#Low .TenArea ol li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #013d82;
  border: 1px solid;
  border-radius: 50%;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 2em;
  width: 2em;
  color: #ffffff;
  font-size: 85%;
  line-height: 1;
  position: absolute;
  top: 0;
  left: 0;
}


#BusinessCont .WorkGrid {
  display: grid;
  gap: 30px;
  grid-template-columns: 1fr 2fr;
}
#BusinessCont .WorkGrid div {
    margin-bottom: 40px;
    background-color: #fff;
    padding: 10px 30px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;

}
@media screen and (max-width: 800px) {
    #BusinessCont .WorkGrid {
        grid-auto-flow: column;
        grid-template-rows: repeat(2, auto);
    }
}
#BusinessCont .WorkGrid div h5 {
    text-align: center;
}
#BusinessCont .WorkGrid div p {
    text-align: center;
    line-height: 1.5;
}
#BusinessCont .WorkGrid div p:first-of-type {
    font-size: 1.1em;
    font-weight: bold;
    color: #013d82;
}
#BusinessCont .WorkGrid div figure {
    margin-top: auto;
    width: 100%;
}
#BusinessCont .WorkGrid div figure img {
    width: 100%;
    margin-top: 20px;
}


/*==============================
建築設計
===============================*/
#Low #LifeScience .MoveBox {
    width: 48%;
}
#Low #LifeScience .MoveBox video {
    width: 100%;
    max-width: 800px;
}
@media (max-width: 800px) {
    #Low #LifeScience .MoveBox {
        width: 100%;
    }
}

@media (max-width: 800px) {
    #Low #LifeScience .W1200Box .HalfBox48 {
        width: 100%;
    }
}
/*==============================
設備（空調・給排水・電気）設計
===============================*/
#Low #LifeScience .Grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4%;
}
#Low #LifeScience .Grid video {
    width: 100%;
}
@media screen and (max-width: 800px) {
    #Low #LifeScience .Grid {
        grid-template-columns: repeat(1, 1fr);
    }
}


/*==============================
実績紹介ページ
===============================*/
#AchievementsNavi ul li {
    width: 23%;
    position: relative;
    margin: .5% 1%;
}

@media screen and (max-width: 1200px) {
    #AchievementsNavi ul li {
        width: 30%;
    }
}
@media screen and (max-width: 820px) {
    #AchievementsNavi ul li {
        width: 98%;
    }
}
#AchievementsNavi ul li:after {
    content: "";
    margin-left: .3em;
    position: absolute;
    top: 1.2em;
    right: 10px;
    z-index: 1;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
}
@media screen and (max-width: 820px) {
    #AchievementsNavi ul li:after {
        top: 1.5em;
    }
}
#AchievementsNavi ul li a.button {
    width: 100%;
    display: inline-block;
    padding: .75rem 1.25rem;
    border-radius: 10rem;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: .15rem;
    transition: all .3s;
    position: relative;
    overflow: hidden;
    z-index: 1;
    text-align: center;
    font-size: .8em;
}
#AchievementsNavi ul li a.button:before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0%;
    height: 100%;
    background-color: #1194d4;
    transition: all .3s;
    border-radius: 10rem;
    z-index: -1;
}
#AchievementsNavi ul li a.button:after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #0068af;
    border-radius: 10rem;
    z-index: -2;
}

#Achievements .Category {
    padding: 40px 0;
}
#Achievements .Category:nth-child(odd) {
    background-color: #f8fbff;
}
#Achievements .Category:nth-child(even) {
    background-color: #f5f5f5;
}
@media screen and (max-width: 800px) {
    #Achievements .Category .flex {
        display: block;
    }
}

#Achievements .Category .MediTitle {
    font-weight: bold;
    padding: 3px 16px;
    display: inline-block;
    /*background-color: #ffe012;*/
    margin-bottom: 6px;
    font-size: 1.1em;
}
#Achievements .Category a.js-modal-open {
    border: 2px solid #0068af;
    background: #ffffff;
    background: linear-gradient(135deg,rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 88%, rgba(0, 160, 220, 1) 88%, rgba(0, 160, 220, 1) 90%, rgba(0, 104, 175, 1) 90%, rgba(0, 104, 175, 1) 100%);
    padding: 20px;
    display: flex;
    color: #000;
    margin: 20px 0;
}
@media screen and (max-width: 800px) {
    #Achievements .Category a.js-modal-open {
        width: 100%;
    }
}
#Achievements .Category a.js-modal-open figure {
    width: 28%;
    max-width: 140px;
    margin-right: 2%;
}
#Achievements .Category a.js-modal-open figure img {
    vertical-align: bottom;
}
#Achievements .Category a.js-modal-open dl {
    max-width: 70%;
    width: 90%;
}
#Achievements .Category a.js-modal-open dl dt {
    font-weight: bold;
    font-size: 1.05em;
}

/*======#modal========*/
.modal {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1100;
    width: 100%;
    height: 100vh;
    transition: opacity .3s, visibility .3s;
}

.modal-open {
    cursor: pointer;
}

.modal.is-active {
    visibility: visible;
    opacity: 1;
}

/* オーバーレイ */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .6);
    cursor: pointer;
}

/* モーダルコンテンツ */
.modal-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 900px;
    width: 97%;
    min-height: 200px;
    max-height: 99vh;
    background-color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.modal-content__inner {
    padding: 30px;
    position: relative;
    overflow: scroll;
}
.modal-content__inner .ProjectName {
    color: #0059a7;
    text-align: center;
    font-weight: bold;
    font-size: 1.7em;
    margin-bottom: 20px;
}
.modal-content__inner .achievementsPhoto {
    width: 100%;
    margin: 0 auto 20px;
    display: flex;
    justify-content: space-between;
}
@media screen and (max-width: 800px) {
    .modal-content__inner .achievementsPhoto {
        flex-direction: column;
    }
}
.modal-content__inner .achievementsPhoto figure {
    width: 52%;
    text-align: center;
    margin: 0;
}
@media screen and (max-width: 800px) {
    .modal-content__inner .achievementsPhoto figure {
        margin: auto;
    }
}
.modal-content__inner .achievementsPhoto .discription {
    width: 44%;
}
@media screen and (max-width: 800px) {
    .modal-content__inner .achievementsPhoto .discription {
        width: 100%;
    }
}
.modal-content__inner .achievementsPhoto .discription dl {
    display: flex;
    align-items: center;
    margin: 0 0 1em;
}
.modal-content__inner .achievementsPhoto .discription dl dt {
    padding: 3px 6px;
    background-color: #0059a7;
    font-weight: bold;
    color: #fff;
    width: 6em;
    min-width: 100px;
    text-align: center;
    line-height: 1.8;
}
@media screen and (max-width: 800px) {
    .modal-content__inner .achievementsPhoto .discription dl dt {
        min-width: 145px;
    }
}
.modal-content__inner .achievementsPhoto .discription dl dd {
    padding: 6px 0 6px 10px;
    margin: 0;
}
.modal-content__inner .Comment {
    border: 1px solid #0059a7;
    padding: 20px;
    font-size: .9em;
}
.modal-content__inner img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 380px;
}
/* 閉じるボタン */
.modal-close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    border: none;
    background: transparent;
    cursor: pointer;
    font-size: 24px;
}






/*==============================
会社情報ディレクトリ
===============================*/
#Low .BgCompany {
    background:#fff;
    /*background-attachment: fixed;*/
    /*background-size: contain;*/
}
/*@media screen and (max-width: 800px) {
    #Low .BgCompany {
        background:#fff url(../img/engineering/plant/prosess/bg_process.png) no-repeat right top;
        background-attachment: fixed;
    }
}*/
#Low .BgCompany:before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -2;
    width: 100%;
    height: 100vh;
    background-repeat: no-repeat;
    background-position: top center;
    background-image: url(../img/company/bg_index_company.jpg);
    background-size: 100%;
}
#Low .BgCompany:after {
    content:"";
    display:block;
    position:fixed;
    top:0;
    left:0;
    z-index:-2;
    width:100%;
    height:100vh;
    background-size:cover;
    background-color: rgba(24, 62, 126, .8);
}

/* 代表メッセージ */
#Low #CompanyGreet .NameBox {
	text-align: right;
}
#Low #CompanyGreet .NameBox img {
	width: 200px;
	height: auto;
}
@media screen and (max-width: 800px) {
    #Low #CompanyGreet .NameBox img {
		width: 300px;
		height: auto;
    }
}
#Low #CompanyGreet .NameBox p {
	font-size: .82em;
	line-height: 1.5;
}
#Low #CompanyGreet .GreetText p{
	margin-bottom: .8em;
}


/* 経営理念 */
#Low #CompanyPhilosophy .BgPhilosophy {
    background-image: url("../img/company/philosophy/bg_philosophy_01.jpg");
    background-position: bottom;
    background-size: cover;
    position: relative;
    z-index: 0;
    margin: 0 !important;
}
/*#Low #CompanyPhilosophy .BgPhilosophy:before {
    content: '';
    position: absolute;
	top: 0;
	right: 0;
    width: 50%;
    height: 100%;
    background: rgba(255,255,255,.66);
    z-index: -1;
}*/
#Low #CompanyPhilosophy .BgPhilosophy .mission {
	padding-bottom: 90px;
}
@media screen and (max-width: 800px) {
	#Low #CompanyPhilosophy .BgPhilosophy:before {
		background-color:transparent;
	}
	#Low #CompanyPhilosophy .BgPhilosophy .flexitemCenter {
		display: block;
		padding-bottom: 30px;
	}
	#Low #CompanyPhilosophy .BgPhilosophy .flexitemCenter .HalfBox45 {
		width: 100%;
	}
}
#Low #CompanyPhilosophy .BgPhilosophy .LabelTitle{
	width: fit-content;
    padding: 5px 20px ! Important;
	color: #fff !important;
	    background-color: #000;
}
#Low #CompanyPhilosophy .BgPhilosophy .headc {
	padding: 1.8em 0 1.4em;
	font-size: 2.4em;
    margin-bottom: 0 !important;
	font-weight: bold;
	text-shadow: 0 2px 2px #fff;;
	line-height: 1.4;
	    color: #013d82;
	text-align: center;
}

#Low #CompanyPhilosophy .BgPhilosophy .mission .WhiteBox p {
	font-size: 1.1em;
}
#Low #CompanyPhilosophy .BgPhilosophy .mission .Text {
	width: 100%;
	width: 700px;
	margin: auto;
	padding: 50px 60px;
	background-color: rgba(255,255,255,.8);
	box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
}
@media screen and (max-width: 800px) {
	#Low #CompanyPhilosophy .BgPhilosophy .headc {
		font-size: 1.8em;
		padding-bottom: 1em;
	}
	#Low #CompanyPhilosophy .BgPhilosophy .mission .Text {
		width: 100%;
		padding: 30px;
		margin-bottom: 30px;
		background-color: rgba(255,255,255,.7);
	}
}

#Low #CompanyPhilosophy .BgVision {
    background-image: url("../img/company/philosophy/bg_philosophy_02.jpg");
    background-position: bottom;
    background-size: cover;
    position: relative;
    z-index: 0;
    margin: 0 !important;
	padding-top: 80px;
}
#Low #CompanyPhilosophy .BgVision:before {
    content: '';
    position: absolute;
	top: 0;
	left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,.68);
    z-index: -1;
}
#Low #CompanyPhilosophy .BgVision .LabelTitle{
	width: fit-content;
    padding: 5px 20px ! Important;
	color: #fff !important;
	background-color: #000;
}
#Low #CompanyPhilosophy .BgVision .headc {
	padding: 1.2em 0 1em;
	font-size: 2.4em;
    margin-bottom: 0 !important;
	font-weight: bold;
	text-shadow: 0 2px 2px #fff;
	line-height: 1.4;
	color: #013d82;
}
@media screen and (max-width: 800px) {
	#Low #CompanyPhilosophy .BgVision .headc {
		font-size: 1.55em;
	}
}
#Low #CompanyPhilosophy .BgVision .mission .Text {
	padding: 0 0px 80px;
}
#Low #CompanyPhilosophy .BgVision .mission .Text p {
	margin-bottom: 18px;
}

#Low #CompanyPhilosophy .BgFuture {
    background-image: url("../img/company/philosophy/bg_future.png");
	background-size: cover;
    background-position: center;
    background-attachment: fixed;
    position: relative;
    padding-top: 6em !important;
    padding-bottom: 14em !important;
}
#Low #CompanyPhilosophy .BgFuture:after {
    content: 'X-ONE Way';
    position: absolute;
    white-space: pre;
    top: 100px;
    right: 5vw;
    font-size: 10em;
    line-height: .8em;
    color: #fff;
    font-weight: bold;
    text-align: right;
    text-shadow: 1px 1px 1px #a6c2dc, -1px 1px 1px #a6c2dc, 1px -1px 1px #a6c2dc, -1px -1px 1px #a6c2dc, 1px 0px 1px #a6c2dc, 0px 1px 1px #a6c2dc, -1px 0px 1px #a6c2dc, 0px -1px 1px #a6c2dc;
    mix-blend-mode: multiply;
	font-family: 'Oswald', sans-serif;
}
@media screen and (max-width: 800px) {
    #Low #CompanyPhilosophy .BgFuture:after {
        font-size: 4em;
        top: 20px;
    }
}
#Low #CompanyPhilosophy .BgFuture .LabelTitle {
  width: fit-content;
  padding: 5px 20px ! Important;
  color: #fff !important;
  background-color: #000;
}
#Low #CompanyPhilosophy .BgFuture .headc {
  padding: 1.2em 0 1em;
  font-size: 2.4em;
  margin-bottom: 0 !important;
  font-weight: bold;
  text-shadow: 0 2px 2px #fff;
  line-height: 1.4;
  color: #013d82;
}
@media screen and (max-width: 800px) {
	#Low #CompanyPhilosophy .BgFuture .headc {
		font-size: 1.8em;
	}
}
#Low #CompanyPhilosophy .BgFuture .mission .Text p {
	margin-bottom: 18px;
}
#Low #CompanyPhilosophy .BgFuture .mission .CompCatch {
    padding: .5em 0 .5em 1.5em;
    font-size: 1.1em;
    text-align: center;
    font-weight: bold;
}
#Low #CompanyPhilosophy .BgFuture .mission .CompName {
    padding: 0.5em 0 0.5em 1.5em;
    font-size: 1.1em;
    text-align: right;
    font-weight: bold;
}
@media screen and (max-width: 800px) {
	#Low #CompanyPhilosophy .BgFuture .mission .CompCatch,
	#Low #CompanyPhilosophy .BgFuture .mission .CompName {
		padding: .5em 0;
		text-align: center;
	}
}
#Low #CompanyPhilosophy .MoveBox {
	background-color: #fff;
	padding-bottom: 10px;
}
#Low #CompanyPhilosophy .MoveBox .MovePos {
    width: 100%;
    max-width: 800px;
    text-align: center;
    margin-top: -200px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 5em;
	position: relative;
	z-index: 1;
}
#Low #CompanyPhilosophy .MoveBox .MovePos video {
    width: 100%;
    max-width: 800px;
}
	
#Low #CompanyPhilosophy .BgRespect {
}
#Low #CompanyPhilosophy .BgRespect .LabelTitle {
  width: fit-content;
  padding: 5px 20px ! Important;
  color: #fff !important;
  background-color: #000;
}
#Low #CompanyPhilosophy .BgRespect .headc {
  padding: 1.2em 0 1em;
  font-size: 2.4em;
  margin-bottom: 0 !important;
  font-weight: bold;
  text-shadow: 0 2px 2px #fff;
  line-height: 1.4;
  color: #013d82;
}
@media screen and (max-width: 800px) {
	#Low #CompanyPhilosophy .BgRespect .headc {
		font-size: 1.8em;
	}
}
#Low #CompanyPhilosophy .BgRespect .mission .Text p {
	margin-bottom: 18px;
}

#Low #CompanyPhilosophy .BgPurpose {
	background-image: url(../../img/company/philosophy/bg_vision.jpg);
    background-size: cover;
    background-position: center;
}
#Low #CompanyPhilosophy .BgPurpose .LabelTitle {
  width: fit-content;
  padding: 5px 20px ! Important;
  color: #fff !important;
  background-color: #0068af;
}

.LabelTitleBgBlue {
	background-color: #0068af!important;
}

#Low #CompanyPhilosophy .BgPurpose .headc {
  padding: 1.2em 0 1em;
  font-size: 2.4em;
  margin-bottom: 0 !important;
  font-weight: bold;
  text-shadow: 0 2px 2px #fff;
  line-height: 1.4;
  color: #013d82;
}
@media screen and (max-width: 800px) {
	#Low #CompanyPhilosophy .BgPurpose .headc {
		font-size: 1.7em;
	}
}
#Low #CompanyPhilosophy .BgPurpose .mission .Text p {
	margin-bottom: 18px;
}

/*基本方針*/
#Low #CompanyPolicy .Label {
	color: #fff;
	background:#0068af;
	font-size: 1.1em;
}
#Low #CompanyPolicy .IndentAst {
	text-indent: -1.5em;
    padding-left: 1.5em;
}


/* 労働安全衛生 */
#Low #CompanySafety .BgSafety {
    background-image: url("../img/company/safety/bg_safety.jpg");
    background-position: bottom;
    background-size: cover;
    position: relative;
    z-index: 0;
    margin: 0 !important;
}
#Low #CompanySafety .LabelTitle {
  width: fit-content;
  padding: 5px 20px ! Important;
  color: #fff !important;
  background-color: #000;
}
#Low #CompanySafety .BgSafety .headc {
  padding: 1.8em 0 2.4em;
  font-size: 1.8em;
  margin-bottom: 0 !important;
  font-weight: bold;
  text-shadow: 0 2px 2px #666;
  line-height: 1.4;
}

#Low #CompanySafety .calcFlex {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}
@media screen and (max-width: 800px) {
	#Low #CompanySafety .calcFlex {
		flex-direction: column;
	}
	#Low #CompanySafety .calcFlex .HalfBox58,
	#Low #CompanySafety .calcFlex .HalfBox40 {
		width: 100%;
	}
}
#Low #CompanySafety ol.safety {
    counter-reset: my-counter;
    list-style: none;
    padding: 0;
    margin-bottom: 30px;
}
#Low #CompanySafety ol.safety li {
    padding-left: 30px;
    position: relative;
	font-size: .94em;
}
#Low #CompanySafety ol.safety li:before {
    content: counter(my-counter);
    counter-increment: my-counter;
    background-color: #005bac;
    border: 1px solid;
    border-radius: 50%;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 24px;
    width: 24px;
    color: #ffffff;
    font-size: 85%;
    line-height: 1;
    position: absolute;
    top: .4em;
    left: 0;
}
#Low #CompanySafety .safety_flex {
    display: flex;
    justify-content: space-between;
    align-items: end;
}
@media screen and (max-width: 800px) {
	#Low #CompanySafety .safety_flex {
		display: block;
	}
	#Low #CompanySafety .safety_flex .HalfBox65 {
		width: 100%;
	}
	#Low #CompanySafety .safety_flex .HalfBox30 {
		width: 70%;
		margin: 20px auto;
	}
}
#Low #CompanySafety .safety_flex .HalfBox30 img {
    border: 1px solid #ddd;
}

	

#Low #CompanySafety .SafetyTable {
	width: 100%;
}
#Low #CompanySafety .SafetyTable th {
	font-weight: bold;
}
#Low #CompanySafety .SafetyTable th,
#Low #CompanySafety .SafetyTable td {
	text-align: center;
	vertical-align: middle;
	font-size: .9em;
	padding: .25em!important;
}
#Low #CompanySafety .SafetyTable thead th,
#Low #CompanySafety .SafetyTable thead td {
    background-color: #fafafa;
    color: #000;
}
#Low #CompanySafety .SafetyTable tbody td {
    background-color: #f8faff;
}
#Low #CompanySafety .GoodCatch {
	border: 1px solid #005bac;
    color: #000 !important;
    padding: 5px 15px !important;
    font-weight: bold;
	width: fit-content;
	margin-bottom: 16px;
}
#Low #CompanySafety .GoodCatch:before {
    content: '';
    display: inline-block;
    width: 30px;
    height: 30px;
    background-image: url("../img/company/safety/icon_goodcatch.svg");
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    margin-right: 8px;
    margin-bottom: 5px;
}
#Low #CompanySafety .GoodCatchTxt:before {
    content: '';
    display: inline-block;
    width: 1.2em;
    height: 1.2em;
    background-image: url("../img/company/safety/icon_goodcatch.svg");
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    margin-right: .2em;
    margin-bottom: 5px;
}
#Low #CompanySafety h5.h5GoodCatch_icon:before {
    content: '';
    display: inline-block;
    width: 40px;
    height: 40px;
    background-image: url("../img/company/safety/icon_goodcatch.svg");
    background-repeat: no-repeat;
    background-size: contain;
    vertical-align: middle;
    margin-right: 8px;
    margin-bottom: 5px;
    background-color: #fff;
    position: unset;
}
#Low #CompanySafety h5.h5GoodCatch span {
    color: #ff0000;
}
#Low #CompanySafety ul.StarIcon {
    padding-bottom: 30px !important;
	padding-left: 26px;
	font-size: .9em;
	line-height: 1.8;
}
#Low #CompanySafety ul.StarIcon li:before {
    content: '★';
    color: #005bac;
    margin-right: .5em;
    margin-left: -1.5em;
}

#Low #CompanySafety .GoodCatchPointBox {
    text-align: center;
    margin-top: 20px;
}
#Low #CompanySafety .GoodCatchPointBox .GoodCatchPoint {
    display: inline-block;
    text-align: center;
    border: 2px solid #005bac;
    padding: 40px 24px 14px;
    border-radius: 6px;
    margin-right: auto;
    margin-left: auto;
    position: relative;
    background-color: #f8faff;
}
#Low #CompanySafety .GoodCatchPointBox .GoodCatchPoint dt {
    width: 60px;
    height: 60px;
    margin: -70px calc(50% - 60px);
    padding: 10px;
    position: absolute;
    background-color: #005bac;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}
#Low #CompanySafety .GoodCatchPointBox .GoodCatchPoint dd {
    color: #ff0000;
}
#Low #CompanySafety #safety_summary {
    background-image: url("../img/company/safety/safety_summary.jpg");
    background-position: center top;
    background-size: cover;
    background-repeat: no-repeat;
}
#Low #CompanySafety #safety_summary .Shadowtxt {
	font-size: 3em;
    color: #005bac;
    text-shadow: #fff 1px 1px 10px, #fff -1px 1px 10px, #fff 1px -1px 10px, #fff -1px -1px 10px;
    text-align: center;
    line-height: 1.3;
    padding: 30px 0;
	font-family: 'Oswald', sans-serif;
}
#Low #CompanySafety #safety_summary .allright {
	text-align: right;
	font-weight: bold;
}


/* 健康経営 */

#Low #CompanyHealth .safety_flex {
    display: flex;
    justify-content: space-between;
    align-items: end;
}
@media screen and (max-width: 800px) {
    #Low #CompanyHealth .safety_flex {
		flex-direction: column;
		align-items: center;
    }
    #Low #CompanyHealth .safety_flex .HalfBox65 {
		width: 100%;
    }
    #Low #CompanyHealth .safety_flex .HalfBox35 {
		width: 60%;
    }
}
#Low #CompanyHealth #Declaration {
    background: linear-gradient(45deg, #e8fff2, #e0e8fe, #fffbe8);
    background-size: 200% 200%;
    animation: bggradient 10s ease infinite;
}
#Low #CompanyHealth .LabelTitle {
  width: fit-content;
  padding: 5px 20px ! Important;
  color: #fff !important;
  background-color: #000;
}
	
#Low #CompanyHealth #Declaration .Name {
	font-weight: bold;
	text-align: right;
}
#Low #CompanyHealth .PointBox {
    width: 100%;
    max-width: 430px !important;
}
#Low #CompanyHealth .flex_OneThird {
	display: flex;
	gap: 10px;
	width: 100%;
	justify-content: flex-start;
}
#Low #CompanyHealth .flex_OneThird div.OneThird {
    width: calc(100% / 3);
}
@media screen and (max-width: 800px) {
    #Low #CompanyHealth .flex_OneThird div.OneThird.OneThirdSp2 {
        width: calc(100% / 2);
    }
}

/*20201009_add*/
#Low #CompanyHealth .Message_flex {
    display: flex;
    justify-content: space-between;
    /* align-items: center; */
    align-items: flex-start;
    line-height: 1.8;
}
@media (max-width: 800px) {
    #Low #CompanyHealth .Message_flex {
        flex-direction: column;
    }
}
@media (max-width: 800px) {
    #Low #CompanyHealth .Message_flex .HalfBox65 {
        width: 100%;
    }
    #Low #CompanyHealth .Message_flex .HalfBox30 {
        width: 60%;
        margin: 10px auto;
    }
}
#Low #CompanyHealth .Message_flex .M_Name {
    text-align: right;
    font-size: .8em;
}
#Low #CompanyHealth .BlueFlex {
    display: flex;
    gap: 18px;
    margin-bottom: 10px;
}
@media (max-width: 800px) {
    #Low #CompanyHealth .BlueFlex {
        display: block;
        margin-bottom: 18px;
        padding-bottom: 18px;
    }
}
#Low #CompanyHealth .BlueFlex .Min {
    font-size: 1.3em;
    font-weight: bold;
    margin-top: 5px;
}
#Low #CompanyHealth .heart {
    margin: 8px auto 30px;
    width: 140px;
}
#Low #CompanyHealth .Future {
    display: flex;
    padding: 0 4%;
    align-items: stretch;
    gap: 4%;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 1.5em;
}
@media (max-width: 800px) {
    #Low #CompanyHealth .Future {
        display: block;
    }
}
#Low #CompanyHealth .Future dl {
    display: flex;
    align-items: stretch;
    flex-direction: column;
    border: 1px solid #999;
    width: 48%;
    padding: 10px;
    background-color: #edf6fd;
    border: 3px solid #005bac;
    border-radius: 10px;
    margin-bottom: 30px;
}
@media (max-width: 800px) {
    #Low #CompanyHealth .Future dl {
        width: 100%;
        margin-bottom: 50px;
    }
}
#Low #CompanyHealth .Future dl dt {
    text-align: center;
    margin-top: -1.5em;
    margin-left: auto;
    margin-right: auto;
    background-color: #3a81bb;
    color: #fff;
    width: 80%;
    padding-bottom: 2px;
    border-radius: 6px;
}
#Low #CompanyHealth .Future dl dd {
    font-size: .9em;
    padding: 10px 25px 10px 25px;
}
@media (max-width: 800px) {
    #Low #CompanyHealth .Future dl dd {
        letter-spacing: -1px;
    }
}
/*20201009_add*/


#Low .Number {
    padding-left: 40px;
    margin-bottom: 10px;
    position: relative;
    font-weight: bold;
}
#Low .Number span {
	font-weight: normal;
}
#Low .Number:before {
    background-color: #005bac;
    border: 1px solid;
    border-radius: 50%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 32px;
    width: 32px;
    color: #ffffff;
    font-size: 85%;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
}
@media screen and (max-width: 800px) {
	#Low .Number:before {
		top: .5em;
	}
}
#Low .Number_01:before {
    content: "1";
}
#Low .Number_02:before {
    content: "2";
}
#Low .Number_03:before {
    content: "3";
}
#Low .Number_04:before {
    content: "4";
}
#Low .Number_05:before {
    content: "5";
}
#Low .Number_06:before {
    content: "6";
}
#Low .Number_07:before {
    content: "7";
}
#Low .Number_08:before {
    content: "8";
}
#Low .Number_09:before {
    content: "9";
}
#Low .table-wrap {
    overflow-x: scroll;
}
#Low .table-wrap table.Health {
	display: initial;
	font-size: .9em;
}
@media (max-width: 800px) {
    #Low .table-wrap table.Health {
        white-space: nowrap;
    }
}
	
#Low .table-wrap table.Health th {
	font-weight: bold;
	vertical-align: middle;
	white-space: nowrap;
}
#Low .table-wrap table.Health td {
	vertical-align: middle;
}
#Low .Captions {
    font-size: .75em;
}

/*会社概要*/
#Low #CompanyAbout table th {
	white-space: nowrap;
}

	
/*会社沿革*/
#Low #CompanyHistory .HistoryWrap {
    position: relative;
    line-height: 1.6;
    width: 100%;
    max-width: 800px;
    /*margin: auto;*/
}
#Low #CompanyHistory .HistoryWrap:before {
    display: inline-block;
    position: absolute;
    top: .5em;
    left: 9.96em;
    width: 2px;
    height: calc(100% - 18px);
    background-color: #ccc;
    content: "";
}
@media screen and (max-width: 800px) {
	#Low #CompanyHistory .HistoryWrap:before {
		left: 5.56em;
	}
}
#Low #CompanyHistory .HistoryWrap dl {
    display: flex;
    -ms-flex-wrap: wrap;
    -ms-flex-pack: justify;
    margin-bottom: 2em;
    position: relative;
}
#Low #CompanyHistory .HistoryWrap dl:before {
    position: absolute;
    display: block;
    width: 3em;
    /* height: 1em; */
    border-radius: 20px;
    left: 11em;
    padding: 0 .5em;
    top: .3em;
    z-index: 5;
    color: #fff;
    font-size: .8em;
}
@media screen and (max-width: 800px) {
	#Low #CompanyHistory .HistoryWrap dl:before {
		left: 5.5em;
	}
}
#Low #CompanyHistory .HistoryWrap dl.CTA:before {
	content: "CTA";
    background: #37ae56;
}
#Low #CompanyHistory .HistoryWrap dl.CKS:before {
	content: "CKS";
    background: #e02347;
}
#Low #CompanyHistory .HistoryWrap dl.CST:before {
	content: "CST";
    background: #005bac;
}
#Low #CompanyHistory .HistoryWrap dl.CXO:before {
	content: "CXO";
    background: #005BAC;
	background: linear-gradient(45deg,rgba(0, 160, 220, 1) 0%, rgba(0, 91, 172, 1) 100%);
}
#Low #CompanyHistory .HistoryWrap dl dt {
    font-size: 1em;
    font-weight: bold;
    width: 8em;
    /* text-align: right; */
    font-family: serif;
}
@media screen and (max-width: 800px) {
	#Low #CompanyHistory .HistoryWrap dl dt {
		width: 4em;
	}
}
#Low #CompanyHistory .HistoryWrap dl dd {
    width: calc(100% - 13em);
    padding-left: 5em;
    /* white-space: pre-wrap; */
    /* word-break: break-all; */
}
@media screen and (max-width: 800px) {
	#Low #CompanyHistory .HistoryWrap dl dd {
		width: calc(100% - 5em);
		padding-left: 4em;
	}
}
	
#Low #CompanyHistory .HistoryWrap dl dd p {
    margin-bottom: 12px;
    position: relative;
}
#Low #CompanyHistory .HistoryWrap dl dd p:before {
    position: absolute;
    content: "";
    top: .9em;
    width: 2.5em;
    height: 2px;
    left: -3em;
    background: #ccc;
}
	
#Low #CompanyHistory .CompanyCategory {
	display: flex;
	gap: 20px;
	justify-content: space-between;
}
@media screen and (max-width: 800px) {
	#Low #CompanyHistory .CompanyCategory {
		flex-direction: column;
	}
}
#Low #CompanyHistory .CompanyCategory dl {
	padding: .8em 1em;
	text-align: center;
	font-weight: bold;
}
#Low #CompanyHistory .CompanyCategory dl dt {
	color: #fff;
	margin-bottom: .7em;
	margin-left: auto;
	margin-right: auto;
	padding: 0 10px;
	font-size: .85em;
	border-radius: 30px;
	line-height: 1.5;
	font-weight: normal;
	width: fit-content;
}
#Low #CompanyHistory .CompanyCategory dl dd {
	line-height: 1.6;
}
#Low #CompanyHistory .CompanyCategory dl.CTA {
	background-color: #ecf7ef;
}
#Low #CompanyHistory .CompanyCategory dl.CTA dt {
	background-color: #37ae56;
}
#Low #CompanyHistory .CompanyCategory dl.CKS {
	background-color: #fdf4f6;
}
#Low #CompanyHistory .CompanyCategory dl.CKS dt {
	background-color: #e02347;
}
#Low #CompanyHistory .CompanyCategory dl.CST {
	background-color: #f3f9fd;
}
#Low #CompanyHistory .CompanyCategory dl.CST dt {
	background-color: #005bac;
}
.triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 100px solid transparent;
  border-left: 100px solid transparent;
  border-top: 60px solid #005bac;
  border-bottom: 0;
	margin: auto;
}
#Low #CompanyHistory .Establishment {
	text-align: center;
	margin-top: 30px;
	margin-bottom: 30px;
	padding-top: 30px;
	padding-bottom: 30px;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}
#Low #CompanyHistory .Establishment p {
	font-weight: bold;
	font-size: 1.2em;
}
#Low #CompanyHistory .Establishment .Logo {
	width: 300px;
	margin: auto;
	margin-top: 20px;
}

	
/*アクセス*/
	#CompanyAccess h4.Access {
		background: transparent;
		border-bottom: 1px solid #EBEBEB;
		padding: .3em 0;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		margin-bottom: 30px;
	}
	#CompanyAccess h4.Access span {
		margin-right: .4em;
	}
	#CompanyAccess #CorpIcon {
		width: 2.2em;
		vertical-align: bottom;
	}
	#CompanyAccess #CorpIcon .cls-1_Icon {
		fill: #005bac;
	}
	#CompanyAccess #CorpIcon .cls-2_Icon {
		fill: #00a0dc;
	}
	#CompanyAccess #CorpIcon .cls-3_Icon {
		fill: #e02347;
	}
	#CompanyAccess #CorpIcon .cls-4_Icon {
		fill: #37ae56;
	}
	#CompanyAccess .Access2wrapp {
		display: flex;
		gap: 4%;
		flex-wrap: wrap;
	}
@media screen and (max-width: 800px) {
	#CompanyAccess .Access2wrapp {
		flex-direction: column;
	}
}
	#CompanyAccess .Access2wrapp span.Station {
		background-color: #00a0dc;
		color: #fff;
		padding: .2em .5em;
		font-size: .9em;
	}
	#CompanyAccess .Access2wrapp.SalesOffice,
	#CompanyAccess .Access2wrapp.BusinessOffice,
	#CompanyAccess .Access2wrapp.WorkOffice {
		justify-content: space-between;
	}
	#CompanyAccess .Access2wrapp.SalesOffice dl,
	#CompanyAccess .Access2wrapp.BusinessOffice dl,
	#CompanyAccess .Access2wrapp.WorkOffice dl {
		width: 48%;
		margin-bottom: 40px;
	}
@media screen and (max-width: 800px) {
	#CompanyAccess .Access2wrapp.SalesOffice dl,
	#CompanyAccess .Access2wrapp.BusinessOffice dl,
	#CompanyAccess .Access2wrapp.WorkOffice dl {
		width: 100%;
	}
}
	#CompanyAccess .Access2wrapp.SalesOffice dl dt {
		font-weight: bold;
		font-size: 1.08em;
		background-color: rgba(243, 248, 254, 1);
		padding: 5px 10px;
		margin-bottom: 8px;
	}
	#CompanyAccess .Access2wrapp.BusinessOffice dl dt {
		font-weight: bold;
		font-size: 1.08em;
		background-color: #fef2f5;
		padding: 5px 10px;
		margin-bottom: 8px;
	}
	#CompanyAccess .Access2wrapp.WorkOffice dl dt {
		font-weight: bold;
		font-size: 1.08em;
		background-color: #f5fef7;
		padding: 5px 10px;
		margin-bottom: 8px;
	}
	#CompanyAccess .Access2wrapp.SalesOffice dl dd,
	#CompanyAccess .Access2wrapp.BusinessOffice dl dd,
	#CompanyAccess .Access2wrapp.WorkOffice dl dd {
		font-size: .9em;
		line-height: 1.7;
	}

/*グループ会社紹介*/
	#Low #CompanyGroup .CompBox {
		display: flex;
		border-top: 0.1rem solid #C8D2DC;
	}
@media screen and (max-width: 800px) {
	#Low #CompanyGroup .CompBox {
		flex-direction: column;
	}
}
	#Low #CompanyGroup .CompBox:last-of-type {
		border-bottom: 0.1rem solid #C8D2DC;
	}
	#Low #CompanyGroup .CompBox dt,
	#Low #CompanyGroup .CompBox dd {
		padding: 2.4rem;
	}
@media screen and (max-width: 800px) {
	#Low #CompanyGroup .CompBox dd {
		padding: 1.4rem;
	}
}
	#Low #CompanyGroup .CompBox dt {
	    background: #EAF3FF;
		background: linear-gradient(10deg,rgba(234, 243, 255, 1) 0%, rgba(245, 249, 255, 1) 100%);
		font-weight: bold;
		width: 40%;
		display: flex;
		align-items: center;
		font-size: 1.2em;
	}
@media screen and (max-width: 800px) {
	#Low #CompanyGroup .CompBox dt {
		width: 100%;
	}
}
	#Low #CompanyGroup .CompBox dd {
		font-size: .9em;
		line-height: 1.7;
		width: 60%;
	}
@media screen and (max-width: 800px) {
	#Low #CompanyGroup .CompBox dd {
		width: 100%;
	}
}


a.BrankLink {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
	font-weight: bold;
}

a.BrankLink .BrankIcon {
  margin-left: 0.5em;
  vertical-align: middle;
}
a.BrankLink:hover {
	opacity: 1;
	text-decoration: underline;
}
a.BrankLink .BrankIcon .icon-part1 {
  fill: #00a0dc; /* 水色 */
}

a.BrankLink .BrankIcon .icon-part2 {
  fill: #013d82; /* 濃い青 */
}



/*採用情報*/
#Low .BgRecruit {
  background: #fff;
  background-attachment: fixed;
  background-size: contain;
}
#Low .BgRecruit:before {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -2;
  width: 100%;
  height: 100vh;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url(../img/recruit/bg_index_recruit.jpg);
  background-size: 100%;
}
#Low .BgRecruit::after {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -2;
  width: 100%;
  height: 100vh;
  background-size: cover;
  background-color: rgba(24, 62, 126, .8);
}

#Recruit .top__plans__Inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
@media screen and (max-width: 800px) {
	#Recruit .top__plans__Inner {
		flex-direction: column;
	}
}
#Recruit .top__plans__Inner .plancategory {
    width: 50%;
}
#Recruit .top__plans__Inner .plancategory {
    width: 50%;
}
@media screen and (max-width: 800px) {
	#Recruit .top__plans__Inner .plancategory {
		width: 100%;
	}
}
#Recruit .top__plans__Inner a.m-panel01 {
    display: flex;
    position: relative;
    align-items: flex-end;
    width: 100%;
	height: 50vh;
    max-width: 900px;
    margin: 0 auto;
    overflow: hidden;
    letter-spacing: 0;
    text-decoration: none;
    padding: 10%;
    z-index: 2;
}
@media screen and (max-width: 800px) {
	#Recruit .top__plans__Inner a.m-panel01 {
		height: 30vh;
	}
}
#Recruit .top__plans__Inner a.m-panel01:hover {
  opacity: 1 !important;
}
#Recruit .top__plans__Inner .m-panel01 .m-panel01__img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease, -webkit-transform 0.5s ease;
    will-change: transform;
}
#Recruit .top__plans__Inner .m-panel01 .m-panel01__img:after {
    content: "";
    position: absolute;
    top: 0;
	left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    transition-duration: 0.4s;
    z-index: 2;
}	
#Recruit .top__plans__Inner .m-panel01 .m-panel01__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    position: relative;
}
#Recruit .top__plans__Inner a.m-panel01:hover .m-panel01__img img {
  transform: scale(1.05);
  transition-duration: 0.4s;
  z-index: 2;
  opacity: 0.9;
}
#Recruit .top__plans__Inner .m-panel01 .m-panel01__body {
    position: relative;
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    color: #fff;
}
#Recruit .top__plans__Inner .m-panel01 .m-panel01__body .m-panel01__txt {
    text-shadow: 0px 0px 5px black;
}
#Recruit .top__plans__Inner .m-panel01 .m-panel01__body h3.m-panel01__ttl {
    text-shadow: 0px 0px 5px black;
	text-align: left;
	background: none;
	padding-left: 20px;
}
#Recruit .top__plans__Inner .m-panel01 .m-panel01__body h3.m-panel01__ttl:before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: calc(100% - 2px);
    background-color: #1E90FF;
    content: "";
    width: 6px;
}
#Recruit .top__plans__Inner .m-panel__btn {
    margin-top: 50px;
}

#Recruit .top__plans__Inner .m-panel__btn .e-btn {
    min-width: 220px;
    border-radius: 12px;
    color: #fff;
    display: inline;
    padding: 15px 30px;
    border: 1px solid #fff;
    background: transparent;
    font-size: 1.4rem;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
#Recruit .top__plans__Inner a.m-panel01:hover .m-panel__btn .e-btn {
  border-color: #1E90FF;
  background: #00a0dc;
  color: #fff;
}

/*キャリア採用/シニア採用*/


/*キャリア採用/シニア採用-募集要項ページ*/
	#Recruit .RecruitDetailTxt {
		background-color: #f5f5f7;
		padding: 40px 50px;
	}
	#Recruit .RecruitDetailTxt p {
		margin-bottom: 10px;
		font-size: .9em;
		line-height: 1.8;
	}
	#Recruit .RecruitDetailTxt p:last-of-type {
		margin-bottom: 0;
	}
	.UnderLineGray {
		border-bottom: 1px solid #ddd;
		margin-bottom: 50px;
		padding-bottom: 50px;
	}



/*サイトマップ*/
	#Sitemap a {
		color: #000;
		display: flex;
		justify-content: flex-start;
		align-items: center;
	}
	#Sitemap a::after {
		content: '';
		transform: translateY(-50%) rotate(-45deg);
		width: .5em;
		height: .5em;
		border-right: 2px solid #003366;
		border-bottom: 2px solid #003366;
		pointer-events: none;
		z-index: 1;
		transition: all 0.3s ease;
		margin-left: .5em;
		margin-top: .5em;
	}
	#Sitemap .CategoryTop {
		width: 100%;
		font-size: 1.5em;
		font-weight: bold;
		padding-bottom: 20px;
		margin-bottom: 20px;
		border-bottom: 1px solid #ddd;
	}
	#Sitemap .CategoryMiddle {
		width: 100%;
		font-size: 1.2em;
		font-weight: bold;
		padding-bottom: 14px;
		margin-bottom: 20px;
		border-bottom: 1px solid #ddd;
	}
	#Sitemap .InnerInner {
		padding: 0 0 0 4%!important;
	}
	#Sitemap .Child {
		padding: 0 0 0 4%;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		margin-bottom: 20px;
	}
	#Sitemap .Child a {
		width: 31%;
		margin-bottom: 1em;
	}
@media (max-width: 999px) {
	#Sitemap .Child a {
		width: 48%;
	}
}
	



/*==============================
メールフォーム
===============================*/
/* CSS Document */

/*form#mail_form{
	width : 960px;
	margin : 50px auto;
	padding : 10px 0;
	background : #ffffff;
	border : 1px solid #cccccc;
	border-radius : 7px;
	box-shadow : 0 0 7px rgba( 0, 0, 0, 0.2 );
}*/
.textcenter {
    text-align: center !important;
}

form#mail_form dl{
	width: 99%;
    margin: 0 auto;
    overflow: hidden;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    border-bottom: 1px solid #ccc;
}

form#mail_form dl dt{
    clear: both;
    width: 35%;
    border-top: 1px solid #cccccc;
    padding: 20px 3% 20px;
    text-align: right;
    overflow: hidden;
    position: relative;
    background-color: #f1f1f1;
    display: flex;
    justify-content: space-between;
	align-items: center;
}

form#mail_form dl dd{
	width : 65%;
	float : right;
	border-top : 1px solid #cccccc;
	padding : 20px 0 20px 5%;
	margin: 0;
	box-sizing: border-box;
}

/*form#mail_form dl dt:last-of-type,
form#mail_form dl dt:last-of-type+dd{
	border-bottom : 1px solid #cccccc;
}*/

form#mail_form dl dt span{
	display : block;
	font-size : 85%;
	color : #3377ff;
}


/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

form#mail_form dl dt span.required,
form#mail_form dl dt span.optional{
	display : inline-block;
	float : left;
	color : #ffffff;
	line-height : 1;
	padding : 8px 9px;
	border-radius : 3px;
}

form#mail_form dl dt span.required{
	background : #d9534f;
	border : 1px solid #d43f3a;
    /*position: absolute;*/
    left: 10px;
    top: 30px;
}

form#mail_form dl dt span.optional{
	background : #337ab7;
	border : 1px solid #2e6da4;
	display: none;
}

form#mail_form dl dd span.error_blank,
form#mail_form dl dd span.error_format,
form#mail_form dl dd span.error_match{
	display : block;
	color : #ff0000;
	margin-top : 3px;
}


span.loading{
	width : 50px;
	height : 50px;
	border-radius : 50%;
	border-top : 5px solid rgba( 255, 255, 255, 0.2 );
	border-right : 5px solid rgba( 255, 255, 255, 0.2 );
	border-bottom : 5px solid rgba( 255, 255, 255, 0.2 );
	border-left : 5px solid #ffffff;
	-webkit-transform : translateZ( 0 );
	-ms-transform : translateZ( 0 );
	transform : translateZ( 0 );
	-webkit-animation : load-circle 1.0s linear infinite;
	animation : load-circle 1.0s linear infinite;
	position : absolute;
	top : 50%;
	left : 50%;
	margin-top : -25px;
	margin-left : -25px;
}

@-webkit-keyframes load-circle{
	0%{
		-webkit-transform : rotate( 0deg );
		transform : rotate( 0deg );
	}
	100%{
		-webkit-transform : rotate( 360deg );
		transform : rotate( 360deg );
	}
}

@keyframes load-circle{
	0%{
		-webkit-transform : rotate( 0deg );
		transform : rotate( 0deg );
	}
	100%{
		-webkit-transform : rotate( 360deg );
		transform : rotate( 360deg );
	}
}


/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */


form#mail_form input[type="text"],
form#mail_form input[type="email"],
form#mail_form input[type="tel"]{
	max-width : 90%;
	/*height : 2em;*/
	padding : 2px 2%;
	border : 1px solid #cccccc;
	border-radius : 3px;
	background : #fafafa;
	-webkit-appearance : none;
	font-size : 100%;
	font-family : inherit;
	/*margin-top : 7px;*/
}

form#mail_form input[type="text"]:focus,
form#mail_form input[type="email"]:focus,
form#mail_form input[type="tel"]:focus,
form#mail_form textarea:focus{
	box-shadow : 0px 0px 5px #55ccff;
	border : 1px solid #55ccff;
	background : #ffffff;
}

form#mail_form ul li input[type="radio"],
form#mail_form ul li input[type="checkbox"]{
	margin-right : 10px;
	margin-top : 7px;
}

form#mail_form ul li:first-child input[type="radio"],
form#mail_form ul li:first-child input[type="checkbox"]{
	margin-top : 0px;
}

form#mail_form select{
	font-size : 100%;
	font-family : inherit;
	margin-top : 10px;
}

form#mail_form textarea{
	display : block;
	width : 90%;
	max-width : 90%;
	height : 200px;
	padding : 2px 2%;
	resize : vertical;
	border : 1px solid #cccccc;
	border-radius : 3px;
	background : #fafafa;
	-webkit-appearance : none;
	font-size : 100%;
	font-family : inherit;
}


form#mail_form ul{
	list-style-type : none;
}

form#mail_form ul li label:hover{
	cursor : pointer;
}


form#mail_form input#company{
	width : 60%;
}

form#mail_form input#name_1,
form#mail_form input#name_2,
form#mail_form input#read_1,
form#mail_form input#read_2,
form#mail_form input#postal,
form#mail_form input#phone,
form#mail_form input#schedule{
	width : 30%;
}

form#mail_form input#mail_address,
form#mail_form input#mail_address_confirm{
	width : 80%;
}

form#mail_form input#postal+a{
	display : inline-block;
	padding : 9px 15px;
	vertical-align : middle;
	line-height : 1;
	background : #5bc0de;
	border : 1px solid #46b8da;
	border-radius : 3px;
	color : #ffffff;
	font-family : inherit;
	text-decoration : none;
	position : relative;
	top : -1px;
}

form#mail_form input#postal+a:hover{
	cursor : pointer;
	background : #31b0d5;
	border : 1px solid #269abc;
}

form#mail_form input#address{
	width : 98%;
}


form#mail_form p#form_submit{
	width : 99%;
	margin : 0 auto;
	padding : 15px 0;
	/*border-top : 1px solid #cccccc;*/
}

/*form#mail_form input[type="button"]{
	padding : 9px 15px;
	vertical-align : middle;
	line-height : 1;
	background : #5cb85c;
	border : 1px solid #4cae4c;
	border-radius : 3px;
	color : #ffffff;
	font-family : inherit;
	-webkit-appearance : none;
	font-size : 100%;
}*/


form#mail_form input[type="button"] {
    width: 180px;
    padding: 15px 40px;
    margin: 40px;
    font-size: 1.2em;
    background-color: #3abbcc;
    color: #fff;
    border-style: none;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    transition: .2s;
}

/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}



#form_submit_button:disabled {
    cursor: default;
	background-color: #ddd!important;
}


form#mail_form input[type="button"]:hover{
	cursor : pointer;
	background : #013d82;
    border-style: none;
}

/*form#mail_form input#form_submit_button{
	margin-left : 35%;
}*/


#contact-privacy {
    border: 2px solid #ccc;
    background-color: #fff;
    font-size: 12px;
    height: 200px;
    margin: 10px 0;
    overflow: auto;
    padding: 8px;
}





/* --responsive----------------------------------------------------------------------------------------------------------------- */

/* 800pixel start */
@media screen and ( max-width : 800px ){

form#mail_form{
	width : 100%;
}

form#mail_form dl{
	overflow : visible;
}

form#mail_form dl dt{
    width: 100%;
    text-align: left;
    padding: 10px;
    font-weight: bold;
    display: block;
}

form#mail_form dl dd{
    width: 100%;
    float: none;
    border-top: none;
    padding: 20px 0 20px 0px;
}

form#mail_form dl dt span{
	font-weight : normal;
}
form#mail_form dl dd ul li {
	margin-bottom: .75em;
}
.checkbox:before {
    top: 22px;
    left: 10px;
 }
.checkbox:after {
    top: 18px;
    width: 28px;
    height: 28px;
}

/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

form#mail_form dl dt span.required,
form#mail_form dl dt span.optional{
	margin-right: 1em;
    margin-bottom: 2em;
    top: 9px;
}


/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */

form#mail_form input[type="text"],
form#mail_form input[type="email"],
form#mail_form input[type="tel"]{
	margin-top : 0px;
}



form#mail_form select{
	margin-top : 0;
}

form#mail_form input#phone,
form#mail_form input#schedule{
	width : 50%;
}


form#mail_form .HalfBox33 {
	width: 100%;
}

}
/* 800pixel end */



.inp {
border:0;
padding:5px;
font-size:1em;
color:#1f1f1f;
border:solid 1px #ccc;
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
-moz-box-shadow: inset 0 0 1px rgba(0,0,0,0.2);
-webkit-box-shadow: inset 0 0 1px rgba(0, 0, 0, 0.2);
box-shadow: inner 0 0 1px rgba(0, 0, 0, 0.2);
margin-right:4px;
width:250px;
}
.inp2 {
border:0;
padding:5px;
font-size:1em;
color:#1f1f1f;
border:solid 1px #ccc;
width:96%;
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
-moz-box-shadow: inset 0 0 1px rgba(0,0,0,0.2);
-webkit-box-shadow: inset 0 0 1px rgba(0, 0, 0, 0.2);
box-shadow: inner 0 0 1px rgba(0, 0, 0, 0.2);
margin-right:4px;
}

.inp300 {
border:0;
padding:5px;
font-size:1em;
color:#1f1f1f;
border:solid 1px #ccc;
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
-moz-box-shadow: inset 0 0 1px rgba(0,0,0,0.2);
-webkit-box-shadow: inset 0 0 1px rgba(0, 0, 0, 0.2);
box-shadow: inner 0 0 1px rgba(0, 0, 0, 0.2);
margin-right:4px;
width:300px;
}
.inp400 {
border:0;
padding:5px;
font-size:1em;
color:#1f1f1f;
border: solid 1px #ccc;
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
-moz-box-shadow: inset 0 0 1px rgba(0,0,0,0.2);
-webkit-box-shadow: inset 0 0 1px rgba(0, 0, 0, 0.2);
box-shadow: inner 0 0 1px rgba(0, 0, 0, 0.2);
margin-right:4px;
width:400px;
}


input:focus ,
textarea:focus {
    border:solid 1px #45c0e3;
}


input#submit,
input.submit {
    padding: 15px 40px;
	margin:40px;
    font-size: 1.2em;
    background-color: #1464c4;
    color: #fff;
    border-style: none;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
}
input#submit:hover,
input.submit:hover {
    background-color: #3076c9;
	cursor:pointer;
}

input#reset_button,
input.reset_button {
    padding: 15px 40px;
	margin:40px;
    font-size: 1.2em;
    background-color: #eaeaea;
    color: #333;
    border:1px solid #999;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
	behavior: url(PIE.htc);
}
input#reset_button:hover,
input.reset_button:hover {
	background-color:#efefef;
	cursor:pointer;
}

input#back {
    padding: 15px 40px;
	margin:40px;
    font-size: 1.2em;
    background-color: #eaeaea;
    color: #333;
    border:1px solid #999;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
	behavior: url(PIE.htc);
}
input#back:hover {
	background-color:#efefef;
	cursor:pointer;
}
.ERR {
	color:#900;
}
.TxT-Center {
    text-align: center;
}
.TxtRed {
    color: #ff0000;
}


select {
border: #bbb solid 1px;
height: 2.2em;
font-size:1em;
}
input,
textarea,
select {
  vertical-align: middle;
  /*margin: 0.25em 0;*/
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: push-button;
}
input#submit:disabled {
    background-color: #fdc33b;
    cursor: pointer;
}



input[type=radio], input[type=checkbox] {
  display: none;
}

.radio, .checkbox {
  box-sizing: border-box;
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
  position: relative;
  display: inline-block;
  padding: 0px 2em 0px 2em;
  border-radius: 4px;
  vertical-align: middle;
  cursor: pointer;
}
.radio:hover, .checkbox:hover {
  /*background-color: #efefef;*/
}
.radio:hover:after, .checkbox:hover:after {
  border-color: #45c0e3;
}

.checkbox:after {
  -webkit-transition: border-color 0.2s linear;
  transition: border-color 0.2s linear;
  position: absolute;
  top: 50%;
  left: 0;
  /*left: 15px;*/
  display: block;
  margin-top: -11px;
  width: 20px;
  height: 20px;
  border: 1px solid #bbb;
  content: '';
  border-radius: 3px;
}
.radio:after {
  -webkit-transition: border-color 0.2s linear;
  transition: border-color 0.2s linear;
  position: absolute;
  top: 50%;
  left: 0;
  /*left: 15px;*/
  display: block;
  margin-top: -12px;
  width: 22px;
  height: 22px;
  border: 1px solid #bbb;
  content: '';
  border-radius: 50%;
}

.radio:before {
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
  position: absolute;
    top: 43%;
    left: 4px;
  display: block;
  margin-top: -6px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background-color: #1464c4;
  content: '';
  opacity: 0;
}
input[type=radio]:checked + .radio:before {
  opacity: 1;
}

.checkbox:before {
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
  position: absolute;
  top: 50%;
  left: 6px;
  display: block;
  margin-top: -9px;
  width: 8px;
  height: 15px;
  border-right: 4px solid #1464c4;
  border-bottom: 4px solid #1464c4;
  content: '';
  opacity: 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
input[type=checkbox]:checked + .checkbox:before {
  opacity: 1;
}



/*table_contact
-----------------------------------------------------------*/
.table_contact{
	width:100%;
	border-collapse: collapse;
	border-spacing: 0;
	border: 1px solid #d8d8d8;
}
 
.table_contact th{
	-moz-box-sizing: border-box;     /* box-size[borderãƒ»padding è¾¼ã¿] */
	box-sizing: border-box;     /* box-size[borderãƒ»padding è¾¼ã¿] */
	border: 1px solid #d8d8d8;
	padding: 15px 10px 12px;
	width: 20%;
	font-style: normal;
	text-align: center;
	vertical-align:middle;
	background-color: #f2f2f5;
}
 
.table_contact td{
	padding: 15px 10px 12px;
	text-align: left;
	vertical-align: top;
	border-top: dotted 1px #d8d8d8;
}
 
@media (max-width: 640px){
.table_contact{
	border-bottom:none;
}
.table_contact th{
	padding: 5px 10px;
	width:100%;
	display:block;
	margin: 0 auto;
	border:none;
	text-align: left;
}
.table_contact td{
	padding: 5px 10px;
	width:100%;
	display: list-item;
	list-style:none;
	border-top: none !important;
	border-bottom:1px solid #d8d8d8;
}
}




.table_a th.req {
	background-image:url("../images/form_icon_required.png") ;
	background-repeat:no-repeat;
	background-position:right top;
}
.none {
	background-color:#ffdddd !important;
}



.red02 {
    color: #e83838!important;
    font-style: normal;
}

.radio-btns {
        display: none; 
    }
.mwform-radio-field label,
.mwform-checkbox-field label {
        position: relative;
        display: inline-block;
        padding: 0 0 0 1.8em;
        cursor: pointer;
    }
    .radio-btns+span::before,
    .mwform-radio-field span::after {
        position: absolute;
        content: '';
        top: 50%;
        border-radius: 100%;
        -webkit-transition: all .2s;
        transition: all .2s;
    }
    .radio-btns+span::before {
        left: 0;
        width: 18px;
        height: 18px;
        margin-top: -10px;
        background: #f3f3f3;
        border: 1px solid #ccc;
    }
    .radio-btns+span:hover::before {
        background: #fff;
    }
    .radio-btns+span::after {
        opacity: 0;
        left: 4px;
        width: 12px;
        height: 12px;
        margin-top: -6px;
        background: #3498db;
        -webkit-transform: scale(2);
        transform: scale(2);
    }
    .radio-btns:checked + span::before {
        background: #fff;
        border: 1px solid #3498db;
    }
    .radio-btns:checked + span::after {
        opacity: 1;
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    .checkbox:checked + span::before {
        background: #fff;
        border: 1px solid #3498db;
    }
    .checkbox:checked + span::after {
        opacity: 1;
    }


