@charset "UTF-8";

/* --------------------------------------------------
	タイトル
-------------------------------------------------- */

#title {
	height: 300px;
	background: #999 url('/img/common/title_bg.jpg') no-repeat center center;
	background-size: cover;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	position:relative;
}
#title:before {
	content:"";
	position:absolute;
	z-index:1;
	width:100%;
	height:100%;
	background:rgba(0,0,0,0.3);
}

#title h1 {
	margin-top: 100px;
	font-size: 3.6rem;
	position:relative;
	z-index:2;
}

@media screen and (max-width: 1024px) {
#title { height: 280px; }
#title h1 { margin-top: 80px; font-size: 3.2rem; }
}

@media screen and (max-width: 767px) {
#title h1 { font-size: 2.8rem; }
}

/* --------------------------------------------------
	パンくず
-------------------------------------------------- */

#path { margin: 20px auto; width: 1200px; }
#path li{display:inline-block;}
#path span { margin: 0 5px;  }
#path strong { font-weight: normal; }
#path li span{

}
@media screen and (max-width: 1024px) {
#path { padding: 0 20px; width: 100%; }
}

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

/* --------------------------------------------------
	
-------------------------------------------------- */

main { padding-bottom: 100px; }
section { padding: 50px 0; }
section section { padding: 30px 0; }
section section:last-of-type { padding: 25px 0 0; }
#page { margin: 0 auto; width: 1200px; }
#page h3 { margin-bottom: 20px;margin-top:40px; padding-bottom: 10px; border-bottom: solid 1px #444; font-size: 2.4rem; }
#page ul, #page ol { margin: 20px 0 20px 40px; }
#page p { margin: 20px 0 20px; }
#page table { width: 100%; border-top: solid 1px #444; border-collapse: collapse; }
#page th, #page td { padding: 15px 20px; border-bottom: solid 1px #444; }
#page th { background: #333; }
#page td {}

@media screen and (max-width: 1024px) {
main { padding-bottom: 80px; }
#page { padding: 0 20px; width: 100%; }
}

@media screen and (max-width: 767px) {
	main { padding-bottom: 60px; }
	#page table, #page table tbody, #page table tbody tr { display: block; width:100%; }
	#page th, #page td { padding: 15px 10px; width: 100%; display: block; }
	#page .table_container table, #page .table_container table tbody{
		display:table
	}
	#page .table_container table tbody tr{
		display:table-row;
	}
	#page .table_container table th, #page .table_container table td {
		display:table-cell;
		white-space: nowrap;
		padding:8px 24px;
	}
	#page th { padding: 5px 10px; }
}


#Default.Company #page ol, #Default.Company #page ul { margin: 0; list-style: none; }

#Sake #page #sakeArchives ul { margin: 0; list-style: none; display: flex; flex-wrap: wrap; justify-content: space-between; }
#Sake #page #sakeArchives ul::after { content: ''; width: 360px; height: 0; }
#Sake #page #sakeArchives li { margin-bottom: 60px; width: 360px; }
#Sake #page #sakeArchives li a { display: block; }
#Sake #page #sakeArchives li img { margin-bottom: 10px; width: 360px; height: 270px; object-fit: contain; }
#Sake #page #sakeArchives li strong { font-size: 1.8rem; }
#Sake #page #sakeArchives li p { margin: 0; }

@media screen and (max-width: 1024px) {
	#Sake #page #sakeArchives ul::after { width: 32%; }
	#Sake #page #sakeArchives li { margin-bottom: 40px; width: 32%; }
	#Sake #page #sakeArchives li img { width: 100%; height: auto; }
}

@media screen and (max-width: 767px) {
	#Sake #page #sakeArchives ul { display: block; }
	#Sake #page #sakeArchives li { margin: 0 auto 40px; width: 100%; max-width: 360px; }
}

#Sake #page #sakeSingle #item { display: flex; justify-content: space-between; }
#Sake #page #sakeSingle #itemImage { width: 400px; }
#Sake #page #sakeSingle #itemImage img { height:auto; }
#Sake #page #sakeSingle #itemText { width: 760px; }
#Sake #page #sakeSingle #itemText p:first-of-type { margin-top: 0; }
#Sake #page #sakeSingle #item .midashi { font-size:2.4rem; font-weight:bold; }
#Sake #page #sakeSingle #item .midashi { font-size:2.4rem; font-weight:bold; }
#Sake #page #sakeSingle #item .items_box td.capacity { text-align:center; }
#Sake #page #sakeSingle #item .items_box td.quantity { text-align:center; }

@media screen and (max-width: 1024px) {
	#Sake #page #sakeSingle #itemImage { width: 32%; }
	#Sake #page #sakeSingle #itemImage img { width: 100%; height: auto; }
	#Sake #page #sakeSingle #itemText { width: 66%; }
}

@media screen and (max-width: 767px) {
	#Sake #page #sakeSingle #item { display: block; }
	#Sake #page #sakeSingle #itemImage { margin-bottom: 20px; width: 100%; text-align: center; }
	#Sake #page #sakeSingle #itemImage img { width: 100%; max-width: 400px; }
	#Sake #page #sakeSingle #itemText { width: 100%; }
}

#News #page #newsSingle .meta { font-size: 1.5rem; text-align: right; }

#News #page #newsIndex ul { margin: 0 auto 40px; width: 900px; list-style: none; position: relative; }
#News #page #newsIndex ul::before { content: ''; width: 100%; height: 1px; background-image: linear-gradient(to right, #999, #999 1px, transparent 1px, transparent 3px); background-size: 3px 1px; background-repeat: repeat-x; display: block; position: absolute; top: 0; }
#News #page #newsIndex li { padding: 20px 0; display: flex; position: relative; }
#News #page #newsIndex li::after { content: ''; width: 100%; height: 1px; background-image: linear-gradient(to right, #999, #999 1px, transparent 1px, transparent 3px); background-size: 3px 1px; background-repeat: repeat-x; display: block; position: absolute; bottom: 0; }
#News #page #newsIndex li .date { margin: 0 20px; }
#News #page #newsIndex li .category { margin-right: 20px; width: 120px; border: solid 1px #fff; text-align: center; display: inline-block; }


.Service ul.d-flex {
	flex-wrap:wrap;
}
.Service ul.d-flex li{
	width:25%;
}

@media screen and (max-width: 767px) {
	.Service ul.d-flex li{
		width:100%;
	}
}

.SakeIndex figure{
	margin-bottom:40px;
}

.Company .flex-box{
	display:flex;
}

.Company .flex-box ._left{
	padding-right: 16px;
    width: 250px;
    flex-shrink: 0;
}
.Company .flex-box ._right p{
	margin-top:0!important;
}

@media screen and (max-width: 767px) {
	.Company .flex-box{
		flex-wrap:wrap;
	}

	.Company .flex-box ._left{
	    width: 100%;
		padding-right:0;
	}
	.Company .flex-box ._right p{
	    width: 100%;
		margin-top:20px!important;
	}
}
