@charset "utf-8";
/* CSS Document */
.zen-kaku-gothic-new-regular {
font-family: "Zen Kaku Gothic New", sans-serif;
}
.libre-bodoni {
font-family: "Libre Bodoni", serif;
}
.Lato {
font-family: 'Lato', sans-serif;
}

.vjs-control-bar,
.vjs-big-play-button,
.vjs-loading-spinner {
display: none !important;
}

#contents {
font-weight: 400;
font-family: "Libre Bodoni","Zen Kaku Gothic New", sans-serif;
width: auto;
font-feature-settings: "palt";
-webkit-font-feature-settings: "palt";
letter-spacing: 0.05em;
color: #333;
}
#pageBody {
background: none;
zoom: 100%;
overflow: hidden;
}

/* #mainVisual
================================================== */
#mainVisual {}
#mainVisual .cont {
position: relative;
padding-bottom: 35px;
}
#mainVisual .title {
position: absolute;
left: 23px;
top: 70px;
}
#mainVisual .title p {
margin-bottom: 13px;
font-weight: 400;
font-family: "Libre Bodoni", serif;
font-style: italic;
font-size: 32px;
line-height: 1.35;
letter-spacing: 0.075em;
color: #776633;
}
#mainVisual .title h1 {
font-family: "Zen Kaku Gothic New", sans-serif;
font-weight: 400;
font-size: 16px;
line-height: 1.88;
letter-spacing: 0.15em;
color: #776633;
}
#mainVisual .title h1 span {
background-color: #fff;
padding: 0 3px;
}
#mainVisual .image {
margin-left: auto;
width: 80%;
}
#mainVisual .image img {
width: 100%;
height: auto;
object-fit: cover;
}

/* mainContents section
================================================== */
#contents .banner a:hover img,
#mainVisual a:hover img {
filter: alpha(opacity=100);
-moz-opacity:1.0;
opacity:1.0;
}

/* #Catch
================================================== */
#Catch  {
background-color: #f1efe5;
}
#Catch .cont {
box-sizing: border-box;
position: relative;
margin: 0 auto;
padding: 70px 0 62px 0;
width: 295px;
}
#Catch .cont::after {
display: none !important;
}
#Catch .movie {
display: flex;
justify-content: center;
align-items: center;
margin-bottom: 66px;
width: 250px;
}
#Catch .movie .inner {
width: 250px;
}
#Catch .pack {
display: flex;
flex-direction: column;
justify-content: center;
gap: 36px;
text-align: left;
}
#Catch .pack p {
white-space: nowrap;
font-size: 14px;
line-height: 2.58;
letter-spacing: 0.15em;
color: #776633;
}
#Catch .pack p:nth-of-type(even) {
margin-left: 23px;
}

/* #Gift
================================================== */
#Gift  {
background-color: #fff;
}
#Gift h2 {
padding: 53px 0 30px 0;
font-weight: 400;
font-size: 30px;
font-style: italic;
letter-spacing: 0.05em;
text-align: center;
color: #776633;
}
#Gift .main {
display: flex;
flex-direction: column;
gap: 75px;
margin: 0 auto 24px auto;
width: 315px;
}
#Gift .main .block {
position: relative;
}
#Gift .main img {
margin-bottom: 20px;
width: 100%;
height: auto;
}
#Gift .main .pack {
box-sizing: border-box;
display: flex;
flex-direction: column;
align-items: flex-start;
background-color: #fff;
text-align: left;
}
#Gift .main .pack h4 {
margin-bottom: 22px;
font-weight: 400;
font-family: "Libre Bodoni", serif;
font-style: italic;
font-size: 18px;
line-height: 1.25;
letter-spacing: 0.05em;
color: #776633;
}
#Gift .main .pack h4 span {
display: inline-block;
padding-top: 4px;
font-weight: 400;
font-family: "Zen Kaku Gothic New", sans-serif;
font-style: normal;
font-size: 15px;
letter-spacing: 0;
}
#Gift .number {
display: flex;
flex-wrap: wrap;
margin: 0 0 15px 0;
text-align: center;
}
#Gift .number dt {
box-sizing: border-box;
background-color: #776633;
border-right: none;
border: solid 1px #776633;
border-radius: 3px 0 0 3px;
padding-top: 2px;
width: 60px;
height: 23px;
font-size: 11px;
line-height: 21px;
color: #fff;
}
#Gift .number dd {
box-sizing: border-box;
background-color: #fff;
border: solid 1px #776633;
border-radius: 0 3px 3px 0;
border-left: none;
padding: 0 4px 0 4px;
min-width: 42px;
height: 23px;
font-size: 13px;
line-height: 23px;
color: #776633;
}
#Gift .price {
margin-bottom: 20px;
font-size: 14px;
line-height: 1.3;
color: #776633;
}
#Gift .price span {
font-size: 18px;
}
#Gift .main .pack .cnt {
margin-bottom: 28px;
flex: 1;
font-size: 12px;
line-height: 1.54;
letter-spacing: 0;
color: #776633;
}
#Gift .main .pack .cart {
margin-left: 40px;
font-size: 16px;
}
#Gift .main .pack .cart a {
transition: background 0.7s ease,color 0.7s ease;
box-sizing: border-box;
display: flex;
justify-content: center;
align-items: center;
background-color: #fff;
border: solid 1px #776633;
padding-top: 5px;
width: 240px;
height: 52px;
text-decoration: none;
color: #776633;
}
#Gift .main .pack .cart a:hover {
background-color: #776633;
color: #fff;
}
#Gift .etc {
display: flex;
flex-direction: column;
gap: 60px;
margin: 75px auto 75px auto;
width: 315px;
}
#Gift .etc .block {
flex: 1;
display: flex;
align-items: center;
gap: 26px;
}
#Gift .etc .block:last-child {
flex-direction: row-reverse;
}
#Gift .etc .block::after {
display: none;
}
#Gift .etc .block .pack {
flex: 1;
}
#Gift .etc .block p {
font-size: 13px;
line-height: 2;
text-align: left;
color: #776633;
}

/* #Item
================================================== */
#Item  {
background-color: #e0cdbb;
}
#Item .cont {
margin: 0 auto;
width: 315px;
text-align: left;
color: #776633;
}
#Item .head {
align-items: center;
padding: 62px 0 62px 0;
}
#Item .head img {
display: block;
margin: 0 auto;
}
#Item .head p {
margin-top: 54px;
font-size: 15px;
line-height: 2;
}
#Item .items {
display: flex;
flex-direction: column;
flex-wrap: wrap;
gap: 60px 66px;
padding-bottom: 75px;
}
#Item .items .block {
display: flex;
flex-wrap: wrap;
}
#Item .items .block:nth-of-type(even) {
flex-direction: row-reverse;
}
#Item .items .image {
width: 90px;
}
#Item .items .block:nth-of-type(even) .image img {
display: block;
margin-left: auto;
}
#Item .items .pack {
flex: 1;
display: flex;
flex-direction: column;
align-items: flex-start;
}
#Item .items h3 {
white-space: nowrap;
margin-bottom: 8px;
font-weight: 500;
font-size: 18px;
letter-spacing: 0;
max-width: 225px;
}
#Item .items h4 {
margin-bottom: 11px;
font-weight: 500;
font-size: 15px;
line-height: 1.8;
letter-spacing: 0;
}
#Item .items h4 span {
border-bottom: solid 1px #c36c40;
}
#Item .items p {
font-size: 13px;
line-height: 1.85;
letter-spacing: 0;
}

/* #Story
================================================== */
#Story  {
background-color: #f1efe5;
}
#Story .cont {
position: relative;
margin: 0 auto;
padding: 65px 0 69px 0;
width: 315px;
text-align: left;
}
#Story h2 {
margin-bottom: 44px;
font-weight: 400;
font-style: italic;
font-size: 35px;
line-height: 1.15;
letter-spacing: 0.1em;
text-align: center;
color: #766735;
}
#Story .list {
display: flex;
flex-direction: column;
gap: 68px;
counter-reset: number 0;
}
#Story .list::after {
display: none;
}
#Story .block {
position: relative;
display: flex;
flex-wrap: wrap;
align-items: center;
}
#Story .block .image {
position: relative;
margin-bottom: 39px;
}
#Story .block:nth-of-type(2) .image {
position: relative;
margin-bottom: 85px;
}
#Story .block:nth-of-type(3) .image {
padding-top: 37px;
}
#Story .block .image::before {
counter-increment: number 1;
content: counter(number) "";
position: absolute;
font-family: "Libre Bodoni", serif;
font-size: 60px;
font-weight: 400;
line-height: 0;
font-style: italic;
}
#Story .block:nth-of-type(1) .image::before {
right: -43px;
top: 12px;
color: #c3c5a7;
}
#Story .block:nth-of-type(2) .image::before {
left: 3px;
top: 250px;
color: #b4bdb6;
}
#Story .block:nth-of-type(3) .image::before {
right: 107px;
top: 3px;
color: #e0ccbb;
}
#Story h3 {
margin-bottom: 26px;
font-weight: 400;
font-size: 21px;
line-height: 2.05;
letter-spacing: 0.15em;
}
#Story .block:nth-of-type(1) h3 {
position: absolute;
right: 0;
top: 60px;
writing-mode: vertical-rl;
}
#Story .block:nth-of-type(2) h3 {
position: absolute;
left: 40px;
top: 181px;
white-space: nowrap;
line-height: 1.8;
color: #b4bdb6;
}
#Story .block:nth-of-type(3) h3 {
position: absolute;
right: 17px;
top: 8px;
writing-mode: vertical-rl;
}
#Story h3 span {
background-color: #c36c40;
color: #fff;
}
#Story .block:nth-of-type(1) h3 span {
padding: 14px 5px 5px 0;
}
#Story .block:nth-of-type(1) h3 span:last-child {
margin-top: 15px;
}
#Story .block:nth-of-type(2) h3 span {
padding: 4px 0 0 7px;
}
#Story .block:nth-of-type(2) h3 span:last-child {
margin-left: 30px;
}
#Story .block:nth-of-type(3) h3 span {
padding: 14px 5px 5px 0;
}
#Story p {
font-size: 15px;
line-height: 2;
letter-spacing: 0;
color: #776633;
}
#Story p.note {
margin-top: 12px;
font-size: 12px;
line-height: 1.84;
}

/* #Hint
================================================== */
#Hint  {
background: url("../img/hin_bg.png") repeat center center;
background-size: 24px auto;
}
#Hint .cont {
position: relative;
margin: 0 auto;
padding: 399px 0 75px 0;
width: 315px;
text-align: left;
color: #776633;
}
#Hint h2 {
position: absolute;
left: 15px;
top: 59px;
}
#Hint .image {
position: absolute;
right: 0;
top: 75px;
}
#Hint .list {
counter-reset: number 0;
display: flex;
flex-wrap: wrap;
flex-direction: column;
align-items: flex-start;
gap: 48px;
}
#Hint .list::after {
display: none;
}
#Hint .block {
position: relative;
display: flex;
flex-wrap: wrap;
flex-direction: column;
align-items: flex-start;
}
#Hint .block:nth-of-type(1) {
margin-left: 80px;
}
#Hint .block:nth-of-type(2) {
margin-left: 30px;
}
#Hint .block:nth-of-type(3) {
margin-left: 0;
}
#Hint .block::before {
counter-increment: number 1;
content: counter(number) "";
position: absolute;
left: 3px;
top: 36px;
font-family: "Libre Bodoni", serif;
font-size: 60px;
font-weight: 400;
line-height: 0;
font-style: italic;
color: #c36c40;
}
#Hint .block:nth-of-type(1)::before {
left: 8px;
top: 36px;
}
#Hint .block:nth-of-type(2)::before {
left: 3px;
top: 16px;
}
#Hint h3 {
margin-bottom: 19px;
padding-left: 50px;
font-weight: 400;
font-size: 18px;
line-height: 1.67;
letter-spacing: 0.15em;
}
#Hint .block:nth-of-type(2) h3 {
margin-bottom: 27px;
}
#Hint h3 span {
border-bottom: solid 1px #c36c40;
}
#Hint p {
font-size: 15px;
line-height: 2;
letter-spacing: 0;
}

/* #QA
================================================== */
#QA  {
background-color: #f1efe5;
}
#QA .cont {
position: relative;
margin: 0 auto;
padding: 66px 0 69px 0;
width: 315px;
text-align: left;
}
#QA h2 {
margin-bottom: 46px;
font-weight: 400;
font-style: italic;
font-size: 35px;
line-height: 1.15;
letter-spacing: 0.2em;
text-align: center;
color: #766735;
}
#QA .list {
display: flex;
flex-direction: column;
gap: 44px;
margin: 0 auto;
}
#QA .list::after {
display: none;
}
#QA h3 {
margin-bottom: 18px;
font-family: "Zen Kaku Gothic New", sans-serif;
font-weight: 400;
font-size: 16px;
line-height: 1.69;
letter-spacing: 0.15em;
color: #c36c40;
}
#QA p {
font-family: "Zen Kaku Gothic New", sans-serif;
font-size: 15px;
line-height: 2;
letter-spacing: 0;
color: #776633;
}
#QA .note {
display: flex;
flex-direction: column;
gap: 5px;
margin-top: 29px;
font-size: 12px;
line-height: 1.84;
color: #776633;
}

/* #QA
================================================== */
#Island  {
background-color: #fff;
}
#Island .cont {
margin: 0 auto;
padding: 70px 0 55px 0;
width: 315px;
text-align: left;
}
#Island .image img {
display: block;
margin: 0 auto;
width: 169px;
}
#Island .pack {
margin-top: 49px;
}
#Island p {
font-size: 15px;
line-height: 2;
letter-spacing: 0;
color: #776633;
}