@charset "utf-8";

/* 全体共通設定 */
body{
	margin:0;
	background-color:#fff;
	color:#2a2a2a;
	font-family:Noto Sans JP,Arial;
	font-size:20px;
}


@media screen and (max-width:779px){
	body{
		font-size:22px;
	}
}

a {
	text-decoration: none;
}
.tel_area ul li a {
		color:#fff;
}

/* hタグ設定 */
@media (min-width: 721px) {
	h1 {
		color:#fff;
		font-size:42px;
		font-weight:bold;
		float:left;
		width:230px;
		margin-top:-25px;
		margin-left:20px;
	}
	h1 span{
		font-size:10px;
	}
}

@media (max-width: 720px) {
	h1 {
		color:#fff;
		font-size:27px;
		font-weight:bold;
		float:left;
		width:135px;
		margin-top:-25px;
		margin-left:20px;
	}
	h1 span{
		font-size:7px;
	}
}

@media (min-width: 776px) {
	.cont_title {
		width:100%;
		height:40px;
		margin-top:2px;
		/*padding: 10px 0px;*/
		background-color: #000;
		background-image: url(../img/h2_bg.png);
		line-height: 40px;

	}

	h2 {
		height: 40px;
		padding: 0;
		margin: 0 0 0 20px;
		/*background-color: #000;*/
		color: #fff;
		position: absolute;
		font-size: 24px;
		font-family: 'Noto Sans JP';
		font-weight: bold;

	}
}

@media (max-width: 775px) {
	.cont_title {
		width:100%;
		height:80px;
		margin-top:2px;
		background-color: #000;
		background-image: url(../img/h2_bg.png);
		line-height: 40px;

	}

	h2 {
		height: 80px;
		padding: 0;
		margin: 0 0 0 20px;
		/*background-color: #000;*/
		color: #fff;
		position: absolute;
		font-size: 24px;
		font-family: 'Noto Sans JP';
		font-weight: bold;

	}
}

h2 span{
	font-size:14px;
}

/* ぱんくず */
@media (min-width: 721px) {
	.cont_title ul {
		height:40px;
		margin: 0;
		padding: 0;
		float: right;
		list-style:none;
		display: flex;
		color:#fff;
		font-size:14px;
		line-height: 40px;
		font-weight: 900;
	}
}

@media (max-width: 720px) {
	.cont_title ul {
		/*width: 100%;*/
		height:40px;
		margin: 0;
		padding: 0;
		float: left;
		list-style:none;
		display: flex;
		color:#fff;
		font-size:14px;
		line-height: 40px;
		font-weight: 900;
		position: absolute;
		top: 102px;
		right: 0px;
	}
}

.cont_title ul li {
	height:40px;
	line-height: 40px;
	padding-left: 10px;
	background-position: right;
	background-repeat: no-repeat;
}

.cont_title ul li img {
	width:25px;
	height:25px;
	margin-top: 8px;
}

.cont_title ul li#li_bg {
	padding-right: 50px;

	background-image: url(../../img/pan_li_01.png);

}

@media (min-width: 721px) {

	.cont_title ul li#li_bg_end {
		padding-right: 80px;
		background-image: url(../../img/pan_li_02.png);

	}
}

@media (max-width: 720px) {

	.cont_title ul li#li_bg_end {
		padding-right: 20px;
		/*background-image: url(../../img/pan_li_02.png);*/

	}
}


h3 {
	width: 100%;
	height: 60px;
	margin-top: 10px;
	margin-bottom: 25px;
	background-color: #000;
	color: #fff;
	/*padding: 10px 20px 20px;*/
	font-size: 20px;
	font-family: 'Noto Sans JP';
	font-weight: bold;
	border-radius: 20px 0 20px 0;
}

h3 p{
	/*margin-top: 10px;*/
	margin-left: 13px;
	margin-bottom: 10px;
	padding-top: 10px;
}

h3 div{
	width:100%;
	height:3px;
	background-color: #fff;
	margin-top: 5px;
}

h4 {
	width: 100%;
	/*height: 30px;*/
	color: #fff;
	font-size: 18px;
	font-family: 'Noto Sans JP';
	font-weight: bold;
	background-color: #000;
}

h4 p {
	margin-left:10px;
	padding-bottom:5px;
}

h5 {
	width: 100%;
	color: #000;
	font-size: 16px;
	font-family: 'Noto Sans JP';
	font-weight: bold;
	border-bottom: 2px solid;
	border-left: 5px solid;
	margin-top: 95px;
}

h5 p {
	margin-left:10px;
	margin-bottom:7px;
	font-size: 16px;
}

h6 {
	width: 100%;
	color: #000;
	font-size: 16px;
	font-family: 'Noto Sans JP';
	font-weight: bold;
	margin-top: 60px;
	border-bottom: solid 2px #000;
}

h7 {
	width: 100%;
	color: #000;
	font-size: 14px;
	font-family: 'Noto Sans JP';
	font-weight: bold;
}

/* ヘッダー */
@media (min-width: 721px) {
	.header {
		width: 100%;
		height:105px;
		background-color: #000;
		/*padding: 10px;*/
	}

	.tel_area{
		float:right;
		width:235px;
		color:#fff;
		font-size:25px;
		font-family:fantasy;
		margin-top:-3px;
	}


	.tel_area ul{
		list-style:none;
		margin-top: 40px;
	}

	.tel_area ul li#tokyo:before{
		content: "";
		display: inline-block;
		width: 25px;
		height: 25px;
		background-image: url('../img/tel_tokyo.svg');
		background-position: center;
		background-size: contain;
		/*content:url(../img/tel_tokyo.svg);
		display:inline-block;
		width:20px;
		height:auto;
		margin-right:10px;
		position:relative;
		top:3px;
		left:0;*/
	}

	.tel_area ul li#osaka:before{
		content: "";
		display: inline-block;
		width: 25px;
		height: 25px;
		background-image: url('../img/tel_osaka.svg');
		background-position: center;
		background-size: contain;
	}
}

@media (max-width: 720px) {
	.header {
		width: 100%;
		height:60px;
		background-color: #000;
		/*padding: 10px;*/
	}

	.tel_area{
		float:right;
		width:180px;
		color:#fff;
		font-size:18px;
		font-family:fantasy;
		margin-top:-10px;
	}


	.tel_area ul{
		list-style:none;
		font-family: 'Noto Sans JP';
		font-weight: bold;
		margin-top: 25px;
	}


	.tel_area ul li#tokyo a::before {
		content: "";
		display: inline-block;
		width: 15px;
		height: 15px;
		background-image: url('../img/tel_tokyo.svg');
		background-position: center;
		background-size: contain;
	}

	.tel_area ul li#osaka:before{
		content: "";
		display: inline-block;
		width: 15px;
		height: 15px;
		background-image: url('../img/tel_osaka.svg');
		background-position: center;
		background-size: contain;
	}
}

/* ヘッダー電話番号リンクの切替 */
@media (max-width: 720px) {
	.pc_none {
		display:none;
	}
}

@media (min-width: 721px) {
	.sp_none {
		display:none;
	}
}

/* メニュー */


/* メインコンテンツ */
section {
	width: 100%;
	margin: 0;
	padding: 0;
}

.bg1 {
	background-color: #fff;
}

.bg2 {
	background-color: #E4E4E4;
}

/*section.bg1 div,section.bg2 div {
		margin: 0 auto 0;
		width: 95%;
}*/



.cont_body {
	width: 90%;
	margin: 0 auto 15px;
	padding: 20px 0 30px;
}

.index_list {
	margin: 0 auto 35px;
	padding: 0 10px;
	text-align: center;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
ul.index_list li {
	position: relative;
}
@media (min-width: 721px) {

	ul.index_list li {
		list-style:none;
		/*width: 40%;*/
		width: 424px;
		/*max-width: 400px;*/
		/*min-width: 300px;*/
		height: 60px;
		margin:10px;
		border: 2px solid #000;
		/*display: inline-flex;*/
		display: inline-block;
		line-height: 60px;
		display: flex;
		align-items: center;
		font-size: 16px;
	}
}

@media (max-width: 720px) {

	ul.index_list li {
		list-style:none;
		width: 100%;
		/*width: 40%;*/
		/*max-width: 400px;*/
		min-width: 280px;
		height: 60px;
		margin:10px 0;
		border: 2px solid #000;
		/*display: inline-flex;*/
		display: inline-block;
		line-height: 60px;
		display: flex;
		align-items: center;
		font-size: 14px;
	}
}

ul.index_list li#col_000 {
	background-color: #000;
	color:#fff;
	text-align: left;
}

ul.index_list li#col_000:hover {
	background-color: #fff;
	color:#000;
	text-align: left;
}

ul.index_list li#col_fff {
	background-color: #fff;
	color:#000;
}

ul.index_list li#col_fff:hover {
	background-color: #000;
	color:#fff;
}

.li_img {
	width: auto;
	height: 60px;
	margin-right: 10px;
}

.cont_body span {
	line-height:1.2;
	margin:0 auto;
}

ul.index_list li span.com_tag {
	width:50px;
	height:12px;
	margin-top:3px;
	padding: 3px 5px;
	background-color: #fff;
	color:#d70505;
	border-radius: 50px;
	font-size: 10px;
	font-weight: bold;
	float:left;
	position: absolute;
	top: 1px;
	left: 2px;
}


/* 詳細ページ */

.cont_title ul li a {
		color:#fff;
}

@media (min-width: 721px) {
	.main_img {
		width:100%;
		height: 350px;
		object-fit: cover;
		margin-bottom:30px;
	}
}

@media (max-width: 720px) {
	.main_img {
		width:100%;
		/*height: 350px;*/
		object-fit: cover;
		margin-bottom:30px;
	}
}

.body_main_text p {
	font-size:14px;
	line-height: 25px;
}
#mb85px {
	margin-bottom: 85px;
}


.container {
	display: flex;
	flex-wrap: wrap; /* 折り返しを許可 */
	gap: 20px; /* テキストと画像の隙間 */
}

.text_box,.text_box2 {
	flex: 1 1 45%; /* テキストが基本左側 */
}

.img_box,.img_box2 {
	flex: 1 1 480px; /* 画像が基本右側 */
	text-align: right;
}

.img_box img,.img_box2 img {
	max-width: 480px; *//* レスポンシブ対応 */
	height: auto;
	width: 100%;
	border: 2px solid #906f21;
	border-radius: 10px;
	box-shadow: 5px 5px 3px 3px rgb(178, 178, 178);
}

.img_box :hover img,.img_box2 :hover img,.banner_area :hover img {
	opacity: 0.8;
}

/* ウィンドウ幅が狭いとき（例：1032px以下） */
@media (max-width: 1032px) {
	.container {
		flex-direction: column; /* 要素を縦並びに */
	}

	.img_box {
		order: 2; /* 画像を下に配置 */
		text-align: center; /* スマホでは中央寄せが見やすい */
		width: 100%;
		margin-bottom: -200px;
	}

	.text_box {
		order: 1; /* テキストを上に配置 */
		width: 100%;
	}

	.img_box2 {
		order: 1; /* 画像を上に配置 */
		text-align: center; /* スマホでは中央寄せが見やすい */
		width: 100%;
		margin-bottom: -150px;
	}

	.text_box2 {
		order: 2; /* テキストを下に配置 */
		width: 100%;
	}
}

.list_box {
	border: solid 2px #000;
	/*padding:10px;*/
	font-size:14px;
	margin: 40px auto;
}


.source_box {
	border: solid 2px #000;
	padding:15px;
	font-size:14px;
	margin: 40px auto;
	border-radius: 20px 0;
}



#border_black {
	border: 2px solod #000;
	padding:10px;
}

.float_none {
	/*clear: both;*/
}

/*figure {
	float: right;
	margin: 0 0 15px 15px;

}

@media (min-width: 721px) {
	figure img {
		width: 480px;
		border: 2px solid #906f21;
		border-radius: 10px;
		box-shadow: 5px 5px 3px 3px rgb(178, 178, 178);
	}
}

@media (max-width: 720px) {
	figure img {
		width: 95%;
		border: 2px solid #906f21;
		border-radius: 10px;
		box-shadow: 5px 5px 3px 3px rgb(178, 178, 178);
	}
}*/

/*.body_main_text ul {
	font-size:14px;
	list-style: square　!important;
	border: none;
	margin: 10px;
	float: none;
	display: flex;*/
	/*flex-direction: column;
	margin-bottom: 50px;*/

/*}*/

/*.body_main_text ul li {
	height: 20px;
	list-style: square;
	border: none;
	list-style: square　!important;
	display: flex;*/
	/*flex-direction: column;*/

/*}*/

@media (min-width: 721px) {
	.banner_area {
		display: flex;
		justify-content: space-between;
		gap: 10px;
		width: 100%;
		text-align: center;
		/*margin: 20px auto;*/
		padding-top: 60px;
	}

	.banner_area a{
		margin: 0 auto;
	}

	.banner_area a img{
		width: calc(90% - 5px);
		height: auto;
		border: 2px solid #906f21;
		border-radius: 10px;
		box-shadow: 5px 5px 3px 3px rgb(178, 178, 178);
		margin-bottom:30px;
	}
}

@media (max-width: 720px) {
	.banner_area {
		width: 100%;
		text-align: center;
		padding-top: 60px;
	}

	.banner_area a img{
		width: 100%;
		max-width: 544px;
		border: 2px solid #906f21;
		border-radius: 10px;
		box-shadow: 5px 5px 3px 3px rgb(178, 178, 178);
	}
}

.product_link_area{
	width: 100%;
	text-align: right;
	margin-top: 30px;
}

.product_link{
	width: 295px;
	padding: 10px 30px 10px 10px;
	background:url("..//projects/project_06/images/product_arrow.png") no-repeat right #000;
	/*background-color: #000;
	background-image:url("/images/product_arrow.png");*/
	color:#fff;
	font-size:10px;
	font-family: 'Noto Sans JP';
	font-weight: bold;
	text-align: left;
	float: right;
}
/*
.product_link::after {
	content: ' ';
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	background-color: #000;
	height: calc(60px / 2);
	width: 60px;
}*/

.product_link span{
	font-size:14px;
	margin:0 10px;
}

.table_set {
	width:100%;
	font-size:14px;
	border-collapse: collapse;
}

.table_head {
	text-align: center;
	background-color: #000;
	color:#fff;
	font-weight: bold;
	white-space:nowrap;
}

.table_set tbody td {
	border-bottom: 1px solid #000;
	border-left: none;
	border-right: none; 
}

.table_set thead tr td,.table_set tbody tr td {
	padding: 10px;
}
#text_center {
	text-align: center;
}

.col_gray {
	background-color: #ebebeb;
}

.table_head tbody tr td ul li {
	margin-bottom: 10px;
}

/* フッター */
.footer {
	width: 100%;
	height: 30px;
	background-color: #000;
	padding: 5px 0;
	text-align: center;
	color:#fff;
	font-size:14px;
	font-family: 'Noto Sans JP';
	line-height: 30px;
	margin-top: 100px;
}

/* topへ */
.totop{
	width: 60px;
	height: 60px;
	padding-top:-5px;
	border-radius: 50%;
	background-color: #000;
	text-align: center;
	color:#fff;
	font-size:14px;
	position: fixed;
	right: 20px;
	bottom: 20px;
}

/* mock-up用 */

.list_box_mock {
	width: 100%;
	border: solid 2px #000;
	/*padding:10px;*/
	font-size:14px;
	margin: 40px auto;
}

#w100per {
	width: 100%;
}

.img_border {
	border: 2px solid #906f21;
	border-radius: 10px;
	box-shadow: 5px 5px 3px 3px rgb(178, 178, 178);
}

#banner_pc {
	width: 100%;
	/*margin:0 auto;*/
	margin-left:13%;
}