@charset "utf-8";
/* company greeting --------------- */
.imgPresident {
    margin-bottom: 2em;
    text-align: center;
}
.imgPresident img {
    margin-bottom: 1em;
}
.imgPresident span {
    font-size: 1.2em;
}

@media print, screen and (min-width: 768px) {
.areaGreeting {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}
.imgPresident {
    flex: 0 0 200px;
    margin-bottom: 0;
    margin-right: 30px;
    font-size: 14px;
}
}
/* philosophy  --------------- */
.areaPhilosophy {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 307px;
    background: url(../../company/images/bg_philosophy_sp.png) no-repeat center 0;
}
.areaPhilosophy ul {
    list-style: none;
    margin-top: 1em;
    padding: 0 3%;
    text-align: center;
}
.areaPhilosophy li {
    margin-bottom: 1em;
    color: #fff;
    font-weight: bold;
    font-size: 20px;
    line-height: 1.5;
}

@media print, screen and (min-width: 768px) {
.areaPhilosophy {
    height: 312px;
    background: url(../../company/images/bg_philosophy.png) no-repeat center 0;
}
.areaPhilosophy ul {
    padding: 0;
    white-space: nowrap;
}
.areaPhilosophy li {
    margin-bottom: 0;
    font-size: 24px;
    line-height: 2.9;
}
}
/* company outline --------------- */
.tblOutline {
    width: 100%;
    margin-bottom: 2.5em;
}
.tblOutline th {
    width: 24%;
    border-bottom: 1px solid #ccc;
    padding: 8px 0 8px 5px;
    color: #36c;
    font-weight: normal;
    text-align: left;
}
.tblOutline td {
    width: 76%;
    border-bottom: 1px solid #ccc;
    padding: 8px 0 8px 1em;
}
sup {
    font-size: 10px;
}
.areaClm2to1 {
    margin-bottom: 1.5em;
    text-align: center;
}
.areaClm2to1 figure, .imgProduct figure {
    margin-bottom: 2em;
}
.areaClm2to1 figure span {
    font-size: 0.86em;
}
.areaClm2to1 img, .imgProduct img {
    margin-bottom: 0.5em;
}

@media print, screen and (min-width: 768px) {
.tblOutline th {
    width: 24%;
    padding: 15px 0 15px 50px;
}
.tblOutline td {
    width: 76%;
    padding: 15px 0;
}
.areaClm2to1 {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}
.areaClm2to1::after {
    content: "";
    display: block;
    width: 50%;
}
.areaClm2to1 div {
    width: 50%
}
}
/* company history --------------- */
.tblHistory {
    width: 100%;
    border-top: 1px solid #ccc;
}
.tblHistory th {
    display: block;
    padding: 7px 10px 0;
    color: #36c;
    font-weight: normal;
    text-align: left;
}
.tblHistory td {
    display: block;
    border-bottom: 1px solid #ccc;
    padding: 7px 10px;
}
/*.tblHistory tr td:nth-of-type(2) {
	background-color: #f1f3f5;
	border-bottom: 1px solid #ccc;
	font-size: 0.87em;
}
.tblHistory tr td:nth-of-type(2).empty {
	background-color: transparent;
	border-top: none;
	padding: 0;
	font-size: 0;
}*/

@media print, screen and (min-width: 768px) {
.tblHistory th {
    display: table-cell;
    width: 35%;
    border-bottom: 1px solid #ccc;
    padding: 10px 0 10px 50px;
    vertical-align: middle;
}
.tblHistory td {
    display: table-cell;
    width: 65%;
    padding: 10px 15px;
    vertical-align: middle;
}
/*.tblHistory tr td:nth-of-type(1) {
	width: 40%;
}
.tblHistory tr td:nth-of-type(2) {
	border-top: none;
	width: 34%;
}
.tblHistory tr td:nth-of-type(2).empty {
	background-color: #f1f3f5;
	padding: 10px 15px;
}*/
}
/* facility --------------- */
.anchorLink {
    list-style: none;
    max-width: 300px;
    margin: 2.5em auto;
    text-align: center;
}
.anchorLink li {
    margin-bottom: 0.8em;
}
.anchorLink li a {
    display: block;
    padding: 7px;
    border: 1px solid #36c;
}
.anchorLink li a:hover {
    text-decoration: none;
    opacity: 0.7;
}
.areaDistance {
    position: relative;
    max-width: 432px;
    border: 1px solid #99B2E5;
    padding: 15px 15px 10px;
    margin: 0 auto 2.5em;
}
.areaDistance p {
    font-size: 1.6rem;
}
.areaDistance p.number {
    position: absolute;
    bottom: -2px;
    left: 20px;
    color: #B2DEF3;
    font-size: 56px;
    line-height: 1.0;
}
.tblFacility {
    border-top: 1px solid #ccc;
    width: 100%;
}
.tblFacility th {
    border-bottom: 1px solid #ccc;
    padding: 5px 0;
    color: #36c;
    font-weight: normal;
    text-align: center;
    vertical-align: middle;
}
.tblFacility tr th:nth-of-type(1) {
    width: 32%;
}
.tblFacility tr th:nth-of-type(2) {
    width: 29%;
}
.tblFacility tr th:nth-of-type(3) {
    width: 33%;
}
.tblFacility tr th:nth-of-type(4) {
    width: 6%;
}
.tblFacility td {
    border-bottom: 1px solid #ccc;
    padding: 7px 5px;
    vertical-align: middle;
}
.tblFacility tr td:nth-of-type(4) {
    text-align: center;
    background-color: #f1f3f5;
}

@media print, screen and (min-width: 768px) {
.anchorLink {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    max-width: inherit;
    width: 100%;
}
.anchorLink li {
    width: 30%;
}
.anchorLink li a {
    padding: 8px 12px;
}
.areaDistance {
    padding: 23px 23px 15px;
}
.areaDistance p {
    font-size: 1.8rem;
}
.areaDistance p.number {
    bottom: -5px;
    left: 24px;
    font-size: 66px;
    line-height: 1.0;
}
.tblFacility th {
    padding: 10px 0;
}
.tblFacility td {
    padding: 10px 8px;
}
}
/* accessmap --------------- */
.txtMap {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    margin-bottom: 3em;
}
.txtMap dt {
    margin-right: 1.5em;
    white-space: nowrap;
}
.googlemap {
    width: 100%;
    height: 400px;
    border: 0;
    margin-bottom: 1.5em;
}
.areaByCar {
    width: 16em;
    margin: 0 auto;
}

@media print, screen and (min-width: 768px) {
.googlemap {
    height: 500px;
}
}
