@charset "utf-8";

.cormorant-garamond {
font-family: "Cormorant Garamond", serif;
font-optical-sizing: auto;
font-style: normal;
}

#TITLE {
position: relative;
}
#TITLE .title {
background: url("../img/bg.jpg") repeat center center;
background-size: 600px auto;
}
#TITLE h1 {
padding: 8vw;
}
#TITLE h1 img {
display: block;
margin: 0 auto;
width: 77.067vw;
height: auto;
}
#TITLE img {
display: block;
width: 100%;
height: auto;
}
#TITLE .lead {
margin: 0 auto;
padding: 10.667vw 0;
width: 81.333vw;
font-weight: 700;
font-family: 'A1 Mincho', serif;
font-size: 3.467vw;
letter-spacing: 0.2em;
line-height: 2.27;
text-align: left;
}
@media screen and (min-width: 768px) {
    #navigation {
    height: 133px;
    }
	#TITLE {
	position: relative;
	}
	#TITLE .title {
	display: flex;
	background: url("../img/bg.jpg") repeat center center;
	background-size: 1200px auto;
	height: 744px;
	}
	#TITLE .visual {
	width: 55%;
	}
	#TITLE h1 {
	box-sizing: border-box;
	position: relative;
	flex: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 10px 0 0 0;
	height: 744px;
	z-index: 1;
	}
	#TITLE h1::before {
	transform: translateX(70px);
	content: '';
	position: absolute;
	left: 50%;
	top: 0;
	display: block;
	background-color: #fff;
	width: 165px;
	height: 490px;
	z-index: -1;
	}
	#TITLE h1 img {
	display: block;
	margin: 0 auto;
	width: 414px;
	height: auto;
	}
	#TITLE img {
	display: block;
	object-fit: cover;
	width: 100%;
	height: 744px;
	}
	#TITLE .lead {
	margin: 0 auto;
	padding: 110px 0;
	width: auto;
	font-size: 16px;
	line-height: 3;
	text-align: center;
	}
}

#ZUKAN {
background: url("../img/bg.jpg") repeat center center;
background-size: 600px auto;
}
#ZUKAN .cont {
padding: 15.467vw 5.333vw 14.667vw 5.333vw;
}
#ZUKAN .cont img {
display: block;
width: 100%;
height: auto;
}
#ZUKAN .main {
margin-bottom: 13.333vw;
}
#ZUKAN h2 {
margin-bottom: 6.667vw;
font-weight: 700;
font-family: 'A1 Mincho', serif;
font-size: 5.333vw;
text-align: center;
}
#ZUKAN .main .list {
display: flex;
flex-direction: column;
gap: 4.267vw;
}
#ZUKAN .sub .list {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1.867vw;
}
#ZUKAN .block {
position: relative;
background-color: #fff;
}
#ZUKAN .tree {
transform: translateY(-50%);
position: absolute;
right: 0;
top: 50%;
}
#ZUKAN .tree img {
object-fit: cover;
width: 42.667vw;
height: 56vw;
}
#ZUKAN .pack {
position: relative;
display: flex;
flex-direction: column;
justify-content: space-between;
box-sizing: border-box;
padding: 5.333vw 4.533vw 4.533vw 4.533vw;
min-height: 60vw;
}
#ZUKAN .sub .pack {
padding: 4vw 3.2vw 3.2vw 3.2vw;
min-height: 54.667vw;
}
#ZUKAN .pack h3 {
position: relative;
font-weight: 500;
font-family: "Cormorant Garamond", serif;
letter-spacing: 0;
font-size: 9.333vw;
line-height: 1;
z-index: 1;
}
#ZUKAN .sub .pack h3 {
font-size: 5.333vw;
line-height: 1.2;
}
#ZUKAN .pack h3 span {
display: block;
font-weight: 700;
font-family: 'A1 Mincho', serif;
font-size: 3.2vw;
letter-spacing: 0.2em;
}
#ZUKAN .pack dl {
box-sizing: border-box;
display: flex;
flex-wrap: wrap;
border-left: solid 1.067vw #969696;
padding-left: 2.133vw;
width: 48vw;
font-size: 2.933vw;
line-height: 1.18;
letter-spacing: 0;
}
#ZUKAN .sub .pack dl {
width: 100%;
}
#ZUKAN .pack dt {
position: relative;
width: 3em;
}
#ZUKAN .pack dt::after {
content: ':';
position: absolute;
right: 0.5em;
top: 0;
}
#ZUKAN .pack dd {
margin-bottom: 3.733vw;
min-width: calc(100% - 3em);
}
#ZUKAN .pack dd:has(> br) {
min-width: 100%;
}
#ZUKAN .pack dd:last-child {
margin-bottom: 0;
}
#ZUKAN .pack p.link {
font-family: 'A1 Gothic M', sans-serif;
font-size: 3.733vw;
z-index: 2;
}
#ZUKAN .pack p.link a {
text-decoration: none;
}
#ZUKAN .pack p.link a::before {
content: '';
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
}
#ZUKAN .pack p.link span {
position: relative;
padding-right: 4.533vw;
}
#ZUKAN .pack p.link span::after {
transform: translateY(-50%);
content: '';
display: block;
position: absolute;
right: 0;
top: 50%;
background: url("../img/icon_window.svg") no-repeat center;
background-size: contain;
width: 4vw;
height: 4vw;
}
#ZUKAN .pack p.soon {
font-size: 2.933vw;
}
#ZUKAN .pack p.soon span {
font-family: 'A1 Gothic M', sans-serif;
font-size: 3.2vw;
color: #969696;
}
#ZUKAN .board img {
object-fit: cover;
width: 100%;
height: auto;
}
@media screen and (min-width: 768px) {
	#ZUKAN {
	background: url("../img/bg.jpg") repeat center center;
	background-size: 1200px auto;
	}
	#ZUKAN .cont {
	box-sizing: border-box;
	margin: 0 auto;
	padding: 70px 62px 120px 62px;
	width: 1200px;
	}
	#ZUKAN .main {
	margin-bottom: 110px;
	}
	#ZUKAN .sub {
	padding: 0 46px;
	}
	#ZUKAN h2 {
	margin-bottom: 55px;
	font-size: 26px;
	}
	#ZUKAN .main .list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 55px;
	}
	#ZUKAN .sub .list {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 24px;
	}
	#ZUKAN .tree {
	transform: translateY(-50%);
	position: absolute;
	right: 0;
	top: 50%;
	}
	#ZUKAN .tree img {
	object-fit: cover;
	width: 224px;
	height: 283px;
	}
	#ZUKAN .tree .md img {
	object-fit: cover;
	margin: 10px 0;
	width: 224px;
	height: 263px;
	}
	#ZUKAN .pack {
	padding: 27px 20px 27px 87px;
	min-height: 283px;
	}
	#ZUKAN .sub .pack {
	padding: 15px 20px 10px 20px;
	min-height: 171px;
	}
	#ZUKAN .pack h3 {
	font-size: 55px;
	line-height: 1.1;
	}
	#ZUKAN .pack h3.md {
	font-size: 50px;
	}
	#ZUKAN .pack h3.sm {
	font-size: 45px;
	}
	#ZUKAN .sub .pack h3 {
	font-size: 28px;
	line-height: 1.2;
	}
	#ZUKAN .pack h3 span {
	font-size: 14px;
	}
	#ZUKAN .pack dl {
	border-left: solid 4px #969696;
	padding-left: 8px;
	width: 220px;
	font-size: 11px;
	}
	#ZUKAN .sub .pack dl {
	width: 100%;
	}
	#ZUKAN .pack dt {
	position: relative;
	width: 3em;
	}
	#ZUKAN .pack dt::after {
	content: ':';
	position: absolute;
	right: 0.5em;
	top: 20;
	}
	#ZUKAN .pack dd {
	margin-bottom: 12px;
	min-width: calc(100% - 3em);
	}
	#ZUKAN .sub .pack dd {
	margin-bottom: 3px;
	}
	#ZUKAN .sub .pack dd:has(> br) {
	min-width: calc(100% - 3em);
	}
	#ZUKAN .sub .pack dd:last-child {
	margin-bottom: 0;
	}
	#ZUKAN .pack p.link {
	font-size: 14px;
	}
	#ZUKAN .pack p.link span {
	padding-right: 20px;
	}
	#ZUKAN .pack p.link span::after {
	margin-top: -2px;
	width: 14px;
	height: 14px;
	}
	#ZUKAN .pack p.soon {
	font-size: 11px;
	}
	#ZUKAN .pack p.soon span {
	font-size: 14px;
	}
	#ZUKAN .board img {
	object-fit: cover;
	width: auto;
	height: 283px;
	}
	#ZUKAN .sub .board img {
	object-fit: cover;
	width: 100%;
	height: auto;
	}
	#ZUKAN .main .board {
	position: absolute;
	left: 0;
	top: 0;
	}
}
