@charset "utf-8";
/* CSS Document */


/******************************************************************

	会社情報

******************************************************************/

.contents_menu01 ul,
.contents_menu02 ul {
	flex-flow: wrap;
}
.contents_menu01 ul li {
	width: 25%
}
.contents_menu01 ul li a {
	text-align: center;
}

.contents_menu02 ul {
    max-width: 1000px;
}
.contents_menu02 ul li,
.contents_menu02 ul li + li {
    width: 25%;
	padding-left: 5px;
	padding-right: 5px;
}
.contents_menu02 ul li:nth-child(n + 5) {
	margin-top: 10px;
}

#container > main .contents_wrapper {
	padding: 64px 40px 80px;
}

/* センタータイトル */

.center_title_wrapper,
.center_title_wrapper + [class^="contents_menu"] {
	margin: 0 auto 48px;
}
.center_title {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-flow: column;
	max-width: 1000px;
	border-bottom: #008435 solid 2px;
	padding-bottom: 1.5em;
	margin: 0 auto .8em;
}
.center_title h2 {
	font-size: 1.65em;
	font-weight: normal;
	margin: 0;
}
.center_title h2 + .title_en {
    color: #008435;
    font-size: 1.05em;
    letter-spacing: .05em;
    margin-top: .5em;
}

/* コンテンツタイトル */

.contents_title {
	max-width: 800px;
	margin: 0 auto .75em;
}
.contents_title h3 {
	position: relative;
	font-size: 1.3em;
	font-weight: bold;
	margin: 0;
	padding: 0.15em 0 0.15em 1em;/*上下 左右の余白*/
	border-left: solid 6px #008435;/*左線*/
}

#company01 .company_box + .company_box {
	margin: 28px auto 0;
}

.company_block,
.history_block {
	padding-top: 20px;
	margin: -20px auto 0;
}
.company_block + .company_block,
.history_block + .history_block {
	padding-top: 20px;
	margin: 60px auto 0;
}

/* 表設定共通 */

[class^="table_list"] {
	max-width: 1000px;
}
[class^="table_list"] dt {
	font-weight: bold;
}
[class^="table_list"] dd > ul,
[class^="table_list"] dd > ul > li {
	width: 100%;
}
.tb_block_list > li + li {
	border-top: #BCBCBC dotted 1px;
	padding-top: 1em;
	margin-top: 1em;
}



/* ==================================================
	会社概要
================================================== */

.company_box {
	max-width: 800px;
	margin: 0 auto;
}
.company_box p {
	font-size: 1.1em;
	line-height: 2.4em;
}
.company_box .name_ceo,
.company_box .name_ceo img {
	width: 100%;
}
.company_box .name_ceo {
	max-width: calc(200px + 1em);
	padding-right: 1em;
}
.company_box p + .name_ceo {
	margin: 1.25em 0 0 auto;
}

.company_box .housin_box {
	position: relative;
	display: flex;
	flex-flow: column;
    align-items: center;
	border: #008435 double 3px;
    padding: 42px 2em 36px;
	margin-top: 32px;
}
.company_box .housin_box > p {
	position: absolute;
	top: -.5em;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	font-size: 1.3em;
	line-height: 1em;
	color: #008435;
	font-weight: bold;
	background: #FFF;
	padding: 0 1em;
	letter-spacing: .075em;
}

.company_box .housin_box .housin_list li + li {
	margin-top: 1.85em;
}
.company_box .housin_box .housin_list dl,
.company_box .housin_box .housin_list dt,
.company_box .housin_box .housin_list dd {
	margin: 0;
}
.company_box .housin_box .housin_list dt {
	position: relative;
	font-size: 1.3em;
    color: #008435;
	line-height: 1.5em;
    padding: 0 0 0 56px;
	letter-spacing: .025em;
}
.company_box .housin_box .housin_list dd {
	position: relative;
	font-size: 1.1em;
	line-height: 1.5em;
	padding: 0 0 0 94px;
}
.company_box .housin_box .housin_list dt + dd {
	margin-top: .6em;
}
.company_box .housin_box .housin_list dt:before,
.company_box .housin_box .housin_list dd:before {
	position: absolute;
	display: block;
}
.company_box .housin_box .housin_list dt:before {
    top: 0;
	left: 0px;
	font-size: 1.8em
}
.company_box .housin_box .housin_list dd:before {
	content: '・・・';
	left: 54px;
	letter-spacing: -.5em
}
.company_box .housin_box .housin_list li:first-child dt:before {
	content: '01';
}
.company_box .housin_box .housin_list li:nth-child(2) dt:before {
	content: '02';
}
.company_box .housin_box .housin_list li:nth-child(3) dt:before {
	content: '03';
}


/* 表 type.01 */

.table_list01 dt {
	justify-content: flex-start;
	padding-left: 40px;
}

.company_address .office_place {
	font-weight: bold;
	padding: .25em 0 0;
}
.company_address .office_place + .office_address,
.company_address .office_address + .office_tel {
	padding: .5em 0 0;
}

.company_access {
	border: #DDD solid 1px;
	padding: .75em 1.5em;
	margin: 1em 0 0;
}
.company_access > p {
	margin: 0 0 .25em;
}

/* グーグルマップ */
.g-map {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%; /* padding-topでもOK */
	margin: 1.35em auto .65em;
    overflow: hidden;
}
.g-map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}



/* ==================================================
	会社沿革
================================================== */

.termbox {
	max-width: 1000px;
	padding-top: 12px;
	margin: -12px auto 0;
}
.termbox + .termbox {
	margin: 36px auto 0;
}
.termbox h3 {
	font-family: 'Sawarabi Mincho', sans-serif;
	font-size: 1.7em;
	font-weight: normal;
	padding: 0 0 16px;
	margin: 0 0 0 50px;
}
.termbox h3 span {
	font-size: 1.2em;
	padding-right: .25em;
}
.history_img + .history_img {
	margin-top: .75em;
}
.history_img .history_pdf {
	margin-top: .75em;
}
.history_img .history_pdf .pdf_note {
	padding: .5em 0 0 1em;
}
.history_img .history_pdf .link_pdf {
	display: inline-block;
	color: #D60D0D;
	background: #FFF;
	border: #D60D0D solid 2px;
	border-radius: 24px;
	font-weight: bold;
	padding: .5em 2.8em .5em 3.2em;
	text-decoration: none;
}
.history_img .history_pdf .link_pdf:before {
	font-family: 'FontAwesome';
	content: "\f1c1";
	font-size: 1.5em;
	padding-right: .5em;
}
.history_img .history_pdf .link_pdf:hover {
	color: #FFF;
	background: #D60D0D;
	opacity: 1;
}

/* 表内見出し */

.table_list02 dd dd p + [class^="tb_genre"] {
	padding-top: .75em;
}
[class^="tb_genre"]:before {
	display: inline-block;
	color: #FFF;
	font-size: .85em;
	margin-bottom: .5em;
}

/* 製品 */

.tb_genre01_list:before {
	content: '製品';
	background-color: #00862E;
	letter-spacing: .5em;
	padding: .15em 1.5em 0 2em;
}

/* 受賞歴 */

.tb_genre02_list:before {
	content: '受賞歴';
	background: #CC9900;
	letter-spacing: .1em;
	padding: .15em 1.9em 0 2em;
}

/* ポップアップ表示 */

.popup_open_img,
.popup_open_img a img {
	width: 100%;
}
.popup_open_img {
	display: flex;
    align-items: center;
	justify-content: space-between;
	flex-flow: wrap;
	max-width: 480px;
}
.popup_open_img a {
	box-sizing: content-box;
	width: calc(50% - 8px);
	background-color: transparent;
	border: none;
	outline: none;
	padding: .8em 0 0 0;
	appearance: none;
	cursor: pointer;
}

.modal__bg,
.modal__content p,
.modal__content img {
	width: 100%;
}
.modal {
    display: none;
    position: fixed;
    top: 0;
	right: 0;
    width: calc(100% - 200px);
	height: 100%;
	z-index: 1;
}
.modal__bg {
    position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	background-color: rgba(0,0,0,.8);
	cursor: pointer;
	z-index: 2;
}
.modal__content {
    box-sizing: content-box;
	position: absolute;
	left: 50%;
	top: 50%;
	display: flex;
    align-items: center;
	justify-content: center;
	flex-flow: column;
    width: calc(100% - 200px);
	max-width: 800px;
	background-color: #fff;
	padding: 20px;
	z-index: 3;
	transform: translate(-50%,-50%);
}
.modal__content p,
.modal__content .js-modal-close {
	text-align: center;
}
.modal__content p {
	overflow: hidden;
}
.modal__content p + p {
	margin-top: 16px;
}
.modal__content .js-modal-close {
	box-sizing: border-box;
	display: block;
	width: 100%;
	font-weight: bold;
	color: #FFF;
	background-color: #333;
	padding: .5em 1em;
	margin: 16px 20px 0;
}
.modal__content .js-modal-close:hover {
	background-color: #008435;
}



/* レスポンシブ対応 */

@media (max-width: 980px) {
#container > main .contents_wrapper {
	padding: 40px 20px;
}
#container > main .contents_wrapper + .contents_wrapper {
	padding: 0 20px 40px;
}

.company_block + .company_block, .history_block + .history_block {
    padding-top: 20px;
    margin: 40px auto 0;
}

.table_list01 dt {
	padding-left: 1em;
}

.popup_open_img a {
	min-width: 100px;
}

.modal {
    width: 100%;
}
.modal__content {
    width: calc(100% - 120px);
}
}

@media (max-width: 640px) {
.center_title_wrapper,
.center_title_wrapper + [class^="contents_menu"] {
    margin: 0 auto 32px;
}
#container > main .contents_wrapper {
	padding: 40px 10px;
}

/*.contents_menu01 ul {
    justify-content: flex-start;
}*/
.contents_menu01 ul li,
.contents_menu02 ul li,
.contents_menu02 ul li + li {
	width: 33.333%
}
.contents_menu02 ul li,
.contents_menu02 ul li + li {
	padding-right: 0;
	padding-left: 0;
}
.contents_menu02 ul li:nth-child(n + 5) {
	margin-top: 0;
}
.contents_menu02 ul li {
	border-right: #FFF solid 1px;
}
.contents_menu02 ul li:nth-child(n + 4) a {
	border-top: #FFF solid 1px;
}

.company_block,
.history_block {
	padding-top: 80px;
	margin: -80px auto 0;
}
.company_block + .company_block,
.history_block + .history_block {
	padding-top: 80px;
	margin: -32px auto 0;
}

.company_box .name_ceo {
	max-width: calc(200px + .25em);
	padding-right: .25em;
}

.company_box .housin_box {
    padding: 32px 1em 24px;
    margin-top: 16px;
}
.company_box .housin_box .housin_list li + li {
    margin-top: 1.25em;
}
.company_box .housin_box .housin_list dt {
    padding: 0 0 0 40px;
}
.company_box .housin_box .housin_list dd {
	padding: 0 0 0 78px;
}
.company_box .housin_box .housin_list dt:before {
	font-size: 1.25em
}
.company_box .housin_box .housin_list dd:before {
    left: 36px;
}

.termbox {
	padding-top: 70px;
	margin: -80px auto 0;
}
.termbox + .termbox {
    margin: -50px auto 0;
}
.termbox h3 {
	text-align: center;
	margin: 0 auto;
}

.company_access {
	padding: .75em 1em .5em;
}

.modal__content {
    width: calc(100% - 60px);
	padding: 10px;
}
.modal__content p + p, .modal__content .js-modal-close {
    margin-top: .5em;
}
.popup_open_img a {
	width: 100%;
}

[class^="table_list"] dd a.link_pdf {
	width: 100%;
	text-align: center;
    padding: .5em 0;
}
}

@media print{
  /*printで適用する内容*/
.company_block:nth-child(n + 2),
.history_block:nth-child(n + 2) {
	page-break-before: always;	
}
}


