@charset "utf-8";
/* --------------------------------------------------
	reset
-------------------------------------------------- */
*,
::before,
::after { box-sizing: border-box;}

html { line-height: 1.15; -webkit-text-size-adjust: 100%; -webkit-tap-highlight-color: transparent;}
body { margin: 0;}
main { display: block;}
p, table, blockquote, address, pre, iframe, form, figure, dl { margin: 0;}
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; margin: 0;}
ul, ol { margin: 0; padding: 0; list-style: none;}
dd { margin-left: 0;}
hr { box-sizing: content-box; height: 0; overflow: visible; border-top-width: 1px; margin: 0; clear: both; color: inherit;}
pre { font-family: monospace, monospace; font-size: inherit;}
address { font-style: inherit;}
a { background-color: transparent; text-decoration: none; color: inherit;}
abbr[title] { text-decoration: underline dotted;}
code, kbd, samp { font-family: monospace, monospace; font-size: inherit;}
small { font-size: 80%;}
sub,
sup { line-height: 0; position: relative; vertical-align: baseline;}

svg, img, embed, object, iframe { vertical-align: bottom;}

/* Forms */
/* ============================================ */
button, input, optgroup, select, textarea { -webkit-appearance: none; appearance: none; background: transparent; padding: 0; margin: 0; border-radius: 0;
 color: inherit; font: inherit; text-align: inherit; text-transform: inherit; vertical-align: middle;
}
button, [type="button"], [type="reset"], [type="submit"] { cursor: pointer;}
button:disabled, [type="button"]:disabled, [type="reset"]:disabled, [type="submit"]:disabled { cursor: default;}
:-moz-focusring { outline: auto;}
select:disabled { opacity: inherit;}
option { padding: 0;}
fieldset { margin: 0; padding: 0; min-width: 0;}
legend { padding: 0;}

progress { vertical-align: baseline;}
textarea { overflow: auto;}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button { height: auto;}
[type="search"] { outline-offset: -2px;}
[type="search"]::-webkit-search-decoration { -webkit-appearance: none;}

::-webkit-file-upload-button { -webkit-appearance: button; font: inherit;}
[type="number"] { -moz-appearance: textfield;}
label[for] { cursor: pointer;}
details { display: block;}
summary { display: list-item;}
[contenteditable]:focus { outline: auto;}

table { border-color: inherit; border-collapse: collapse;}
td,
th { vertical-align: top; padding: 0;}


/*	Slider */
.slick-slider { position: relative; display: block; box-sizing: border-box;
-webkit-user-select: none;
   -moz-user-select: none;
    -ms-user-select: none;
        user-select: none;

-webkit-touch-callout: none;
	-khtml-user-select: none;
	-ms-touch-action: pan-y;
  	  touch-action: pan-y;
-webkit-tap-highlight-color: transparent;
}

.slick-list { position: relative; display: block; overflow: hidden; margin: 0; padding: 0;}
.slick-list:focus { outline: none;}
.slick-list.dragging{ cursor: pointer; cursor: hand;}
.slick-slider .slick-track,
.slick-slider .slick-list{
-webkit-transform: translate3d(0, 0, 0);
   -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
     -o-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
}
.slick-track { position: relative; top: 0; left: 0; display: block;}
.slick-track:before,
.slick-track:after { display: table; content: '';}
.slick-track:after { clear: both;}
.slick-loading .slick-track { visibility: hidden;}
.slick-slide { display: none; float: left; height: 100%; min-height: 1px;}
[dir='rtl'] .slick-slide { float: right;}
.slick-slide img { display: block; }
.slick-slide.slick-loading img { display: none;}
.slick-slide.dragging img { pointer-events: none;}
.slick-initialized .slick-slide { display: block; outline: none;}
.slick-loading .slick-slide { visibility: hidden;}
.slick-vertical .slick-slide{ display: block; height: auto;}
.slick-arrow.slick-hidden { display: none;}

.slick-arrow{ width: 50px; height: 50px; position: absolute; top: 50%; transform: translateY(-50%);
 background: #000; border: none; border-radius: 50%; z-index: 100;
 text-indent: -9999em; outline: none;
}
.slick-prev { left: 0px;}
.slick-next { right: 0px;}
.slick-arrow:before{ position: absolute; content: ''; display: block; width: 0px; height: 0px; top: 50%; transform: translateY(-50%);}
.slick-prev:before { left: 30%; border: solid 9px transparent; border-right: solid 16px #fff; border-left: 0;}
.slick-next:before { right: 30%; border: solid 9px transparent; border-left: solid 16px #fff; border-right: 0;}

/** Dots */
.slick-dotted.slick-slider{ margin-bottom: 30px;}
.slick-dots { position: absolute; bottom: -25px; display: block; width: 100%; padding: 0; margin: 0; text-align: center;}
.slick-dots li { position: relative; display: inline-block; width: 20px; height: 20px; margin: 0 5px; padding: 0; cursor: pointer;}
.slick-dots li button { font-size: 0; line-height: 0; display: block; width: 20px; height: 20px; padding: 5px; cursor: pointer;
 color: transparent; border: 0; outline: none; background: transparent; 
}
.slick-dots li button:hover,
.slick-dots li button:focus{ outline: none;}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before { opacity: 1;}
.slick-dots li button:before { font-family: 'slick'; font-size: 6px; line-height: 20px; position: absolute; top: 0; left: 0;
	width: 20px; height: 20px; content: '•'; text-align: center; opacity: .25; color: black;
}
.slick-dots li.slick-active button:before { opacity: .75; color: black;}

@media (max-width: 481px) {
}


/* Magnific Popup CSS */
.mfp-bg { position: fixed; top: 0; left: 0; z-index: 1042; width: 100%; height: 100%; overflow: hidden; background: rgba(112,60,30,0.58); }
.mfp-wrap { position: fixed; top: 0; left: 0; z-index: 1043; width: 100%; height: 100%; outline: none !important; -webkit-backface-visibility: hidden; }
.mfp-container { text-align: center; position: absolute; width: 100%; height: 100%; left: 0; top: 0; padding: 0 8px; box-sizing: border-box; }
.mfp-container:before { content: ''; display: inline-block; height: 100%; vertical-align: middle; }
.mfp-align-top .mfp-container:before { display: none; }
.mfp-content { position: relative; display: inline-block; vertical-align: middle; margin: 0 auto; text-align: left; z-index: 1045; }
.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content { width: 100%; cursor: auto; }
.mfp-ajax-cur { cursor: progress; }
.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close { cursor: -moz-zoom-out; cursor: -webkit-zoom-out; cursor: zoom-out; }
.mfp-zoom { cursor: pointer; cursor: -webkit-zoom-in; cursor: -moz-zoom-in; cursor: zoom-in; }
.mfp-auto-cursor .mfp-content { cursor: auto; }
.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter { -webkit-user-select: none; -moz-user-select: none; user-select: none; }
.mfp-loading.mfp-figure { display: none; }
.mfp-hide { display: none !important; }
.mfp-preloader { color: #CCC; position: absolute; top: 50%; left: 8px; right: 8px; z-index: 1044; width: auto; text-align: center; margin-top: -0.8em; }
.mfp-preloader a { color: #CCC; }
.mfp-preloader a:hover { color: #FFF; }
.mfp-s-ready .mfp-preloader { display: none; }
.mfp-s-error .mfp-content { display: none; }

button.mfp-close,
button.mfp-arrow { overflow: visible; cursor: pointer; background: transparent; border: 0; -webkit-appearance: none; display: block; outline: none; padding: 0; z-index: 1046; box-shadow: none; touch-action: manipulation; }

button::-moz-focus-inner { padding: 0; border: 0; }

.mfp-counter { position: absolute; top: 0; right: 0; color: #CCC; font-size: 12px; line-height: 18px; white-space: nowrap; }
.mfp-arrow { position: absolute; top: 50%; opacity: 0.65; margin: 0; margin-top: -55px; padding: 0; width: 90px; height: 110px; -webkit-tap-highlight-color: transparent; }
.mfp-arrow:active { margin-top: -54px; }
.mfp-arrow:hover,
.mfp-arrow:focus { opacity: 1; }
.mfp-arrow:before,
.mfp-arrow:after { content: ''; display: block; width: 0; height: 0; position: absolute; left: 0; top: 0;
margin-top: 35px; margin-left: 35px; border: medium inset transparent; }
.mfp-arrow:after { border-top-width: 13px; border-bottom-width: 13px; top: 8px; }
.mfp-arrow:before { border-top-width: 21px; border-bottom-width: 21px; opacity: 0.7; }

.mfp-arrow-left { left: 0; }
.mfp-arrow-left:after { border-right: 17px solid #FFF; margin-left: 31px; }
.mfp-arrow-left:before{ margin-left: 25px; border-right: 27px solid #3F3F3F; }

.mfp-arrow-right { right: 0; }
.mfp-arrow-right:after { border-left: 17px solid #FFF; margin-left: 39px; }
.mfp-arrow-right:before{ border-left: 27px solid #3F3F3F; }

.mfp-iframe-holder { padding-top: 40px; padding-bottom: 40px; }
.mfp-iframe-holder .mfp-content { line-height: 0; width: 100%; max-width: 900px; }
.mfp-iframe-holder .mfp-close { top: -40px; }

.mfp-iframe-scaler { width: 100%; height: 0; overflow: hidden; padding-top: 56.25%; }
.mfp-iframe-scaler iframe { position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; box-shadow: 0 0 8px rgba(0, 0, 0, 0.6); background: #000; }

/* Main image in popup */
img.mfp-img { width: auto; max-width: 100%; height: auto; display: block; line-height: 0; box-sizing: border-box; padding: 40px 0 40px; margin: 0 auto; }

/* The shadow behind the image */
.mfp-figure { line-height: 0; }
.mfp-figure:after { content: ''; display: block; width: auto; height: auto; box-shadow: 0 0 8px rgba(0, 0, 0, 0.6); background: #444;
	position: absolute; left: 0; top: 40px; bottom: 40px; right: 0; z-index: -1;
}
.mfp-figure small { color: #BDBDBD; display: block; font-size: 12px; line-height: 14px; }
.mfp-figure figure { margin: 0; }
.mfp-bottom-bar { margin-top: -36px; position: absolute; top: 100%; left: 0; width: 100%; cursor: auto; }
.mfp-title { text-align: left; line-height: 18px; color: #F3F3F3; word-wrap: break-word; padding-right: 36px; }
.mfp-image-holder .mfp-content { max-width: 100%; }
.mfp-gallery .mfp-image-holder .mfp-figure { cursor: pointer; }

@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
	/** Remove all paddings around the image on small screen */
	.mfp-img-mobile .mfp-image-holder { padding-left: 0; padding-right: 0; }
	.mfp-img-mobile img.mfp-img { padding: 0; }
	.mfp-img-mobile .mfp-figure:after { top: 0; bottom: 0; }
	.mfp-img-mobile .mfp-figure small { display: inline; margin-left: 5px; }
	.mfp-img-mobile .mfp-bottom-bar { background: rgba(0, 0, 0, 0.6); bottom: 0; margin: 0; top: auto; padding: 3px 5px; position: fixed; box-sizing: border-box; }
	.mfp-img-mobile .mfp-bottom-bar:empty { padding: 0; }
	.mfp-img-mobile .mfp-counter { right: 5px; top: 3px; }
	.mfp-img-mobile .mfp-close { top: 0; right: 0; width: 35px; height: 35px; line-height: 35px; background: rgba(0, 0, 0, 0.6); position: fixed; text-align: center; padding: 0; }
}


@media all and (max-width: 900px) {
	.mfp-arrow { -webkit-transform: scale(0.75); transform: scale(0.75); }
	.mfp-arrow-left { -webkit-transform-origin: 0; transform-origin: 0; }
	.mfp-arrow-right { -webkit-transform-origin: 100%; transform-origin: 100%; }
	.mfp-container { padding-left: 6px; padding-right: 6px; }
}





html{
  height: -webkit-fill-available;
}
body{
  min-height: 100vh;
  min-height: -webkit-fill-available;
}



/*		font-style
-------------------------------------------------- */
body { width: 100%;
 background: #CC9F45;
	color: #502612;
/*	font-family: "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;*/
	font-family: "游ゴシック","Yu Gothic","Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3", "メイリオ","Meiryo",sans-serif;
	font-size: 16px;
	*font-size:small;
	*font:x-small;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
body.fixed { position: fixed;}
.min { font-family: "Noto Serif JP","游明朝", "Yu Mincho", "YuMincho", serif;}
.eng { font-family: "Playfair Display", serif;}


a { color:#002159; text-decoration: none;}
a:link   { color:#002159;}
a:visited{ color:#002159;}
a:hover  { color:#002159;}
a:active { color:#002159;}

em{ font-style: normal;}


/*		utility
-------------------------------------------------- */
.cf{ clear: both;}
.cf:after{ content: ''; display: block; clear: both;}


@keyframes showInOUt1 {
 0% { opacity: 0;}
 50% { opacity: 1;}
 80% { opacity: 1;}
100% { opacity: 0;}
}

#loading { position: fixed; left: 0; top: 0; width: 100%; height: 100vh; z-index: 10;}
#loading .inner { position: relative; width: 100%; height: 100%; background: url('../img/bg/loading.jpg') no-repeat 50% 50% / cover; transition: 0.8s linear 2.4s;}
#loading .logo { width: 50%; max-width: 250px; position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); transition: 0.8s linear; opacity: 0;}
#loading .logo img { width: 100%; filter: drop-shadow(0px 0px 10px #754a22) drop-shadow(0px 0px 6px #754a22) drop-shadow(0px 0px 10px #754a22);}

#loading.start .inner { opacity: 0;}
#loading.start .logo { animation: showInOUt1 3.0s linear;}
@media (max-width: 641px) {
	#loading .inner { background: url('../img/bg/loading@sp.jpg') no-repeat 50% 50% / cover;}
	#loading .logo { transform: translate(-50%,-80%);}
}



.menu-btn { position: fixed; right: 0; top: 0; width: 100%; z-index: 102; opacity: 0; transition: 0.3s linear;}
.menu-btn.show { opacity: 1;}
.menu-btn .inner { position: relative; width: 100%; max-width: 1280px; height: 100%; margin: 0 auto;}

.menu-btn .logo { position: absolute; left: 40px; top: 20px; width: 40%; max-width: 250px;}
.menu-btn .logo a { display: block; width: 100%; line-height: 1;}
.menu-btn .logo a img { width: 100%;}

.menu-trig { position: absolute; top: 20px; right: 80px; width: 32px; height: 32px; cursor: pointer;}
.menu-trig div { position: relative; width: 100%; height: 100%;}
.menu-trig div span { position: absolute; left: 50%; display: block; width: 100%; height: 2px; background: #fff; opacity: 1; transition: 0.4s linear;}
.menu-trig div span:nth-of-type(1) { top: 6px; transform: translate(-50%,0px);}
.menu-trig div span:nth-of-type(2) { top: 15px; transform: translate(-50%,0px);}
.menu-trig div span:nth-of-type(3) { top: 24px; transform: translate(-50%,0px);}
.menu-trig.active { right: 20px;}
.menu-trig.active div span:nth-of-type(1) { width: 72%; transform: translate(-50%,9px) rotate(45deg);}
.menu-trig.active div span:nth-of-type(2) { opacity: 0;}
.menu-trig.active div span:nth-of-type(3) { width: 72%; transform: translate(-50%,-9px) rotate(-45deg);}
.menu-cart { position: absolute; top: 18px; right: 20px; width: 35px;}
.menu-cart.hide { display: none;}
.menu-cart a { display: block; width: 100%; max-width: 34px; margin: 0 auto;}
.menu-cart a svg { width: 100%; fill: #fff; vertical-align: bottom;}
@media (max-width: 801px) {
	.menu-btn .logo { left: 20px;}
	.menu-trig { right: 20px;}
	.menu-cart { right: 80px;}
}
@media (max-width: 481px) {
	.menu-btn .logo { top: 20px; left: 15px;}
	.menu-trig { top: 15px; width: 28px;}
	.menu-cart { top: 14px; right: 68px; width: 30px; padding-left: 3px;}
}


/* Header */
/* ============================================ */
#hd { position: fixed; left: 0; top: 0; width: 100%; height: 100vh; z-index: -1;}
#hd:after { content: ''; display: block; width: 100%; height: 100%; position: absolute; left: 0; top: 0; opacity: 0; z-index: 10; background: rgba(100,100,100,0.2);
 transition: 0.2s linear;
}
#hd .inner-hd { position: relative; width: 100%; max-width: 1280px; height: 100%; margin: 0 auto; overflow: hidden;}
#hd .menu { position: absolute; right: -500px; top: 0; width: 100%; z-index: 100; max-width: 320px; height: 100%; padding: 30px 0; background: #703b1d; transition: 0.4s linear 0.2s;}
#hd .menu .scroll { width: 100%; height: 100%; overflow-y: scroll; }
#hd .menu ul.nav { width: 90%; max-width: 260px; margin: 0 auto 20px;}
#hd .menu ul.nav li { padding: 8px 0; font-size: 14px; letter-spacing: 0.15rem; line-height: 1.2;}
#hd .menu ul.nav li.top { margin-bottom: 12px;}
#hd .menu ul.nav li a { display: block; padding: 8px 0; color: #fff; font-weight: 700; text-decoration: none;}
#hd .menu ul.nav li a:hover { color: #6a6a6a;}
#hd .menu ul.nav li.top a { width: 80%; max-width: 120px; padding: 0;}
#hd .menu ul.nav li.top a img { width: 100%;}
#hd .menu ul.nav li ul.sns { padding: 10px 0;}
#hd .menu ul.nav li ul.sns li { display: inline-block; width: 54px; margin: 0; padding: 0; vertical-align: middle;}
#hd .menu ul.nav li ul.sns li a { display: block; width: 32px; padding: 0;}
#hd .menu ul.nav li ul.sns li.icn-i a svg { display: block; width: 100%; height: auto; fill: #fff;}
#hd .menu ul.nav li ul.sns li.icn-x a span { display: block;}
#hd .menu ul.nav li ul.sns li.icn-x a svg { fill: #fff;}
#hd .menu ul.nav li ul.sns li.icn-l a { background: #06c755;}

#hd .menu ul.aside { width: 92%; max-width: 280px; margin: 0 auto; font-size: 0;}
#hd .menu ul.aside li { display: inline-block; width: 50%; padding: 6px 4px; font-size: 10px;}
#hd .menu ul.aside li a { display: block; padding: 5px 0; background: #703b1d; border: solid 1px #fff; border-radius: 20px;
 color: #fff; letter-spacing: -0.05rem; text-align: center; text-decoration: none;
}
#hd .menu ul.aside li a:hover { color: #6a6a6a;}

#hd.open { z-index: 101;}
#hd.open:after { opacity: 1;}
#hd.open .menu { right: 0; z-index: 11;}

@media (max-width: 481px) {
	#hd .menu { padding-top: 30px; }
	#hd .menu ul.nav li { padding: 8px 0;}
	#hd .menu ul.aside { position: relative; left: auto; bottom: auto;}
}



/* Footer */
/* ============================================ */
#ft { position: relative;}
#ft .inner-ft{ padding: 40px 0px; background: #fff;}
#ft h3 { margin: 0 auto 30px; text-align: center;}
#ft h3 img{ width: 32%; max-width: 140px;}
#ft ul { font-size: 0; text-align: center;}
#ft ul li { display: inline-block; font-size: 13px; padding: 0 25px;}
#ft ul li:first-child{ border-left: none;}
#ft ul li a { color: #000;}
#ft ul li a:hover { text-decoration: underline;}
#ft .copyright { padding: 10px 0; background: #000;}
#ft .copyright p { color: #fff; font-size: 12px; text-align: center;}
@media (max-width: 1201px) {
}
@media (max-width: 1001px) {
}
@media (max-width: 801px) {
	#ft .inner-ft{ padding: 50px 0 60px;}
}
@media (max-width: 641px) {
	#ft ul li { display: block; font-size: 13px; padding: 10px; border-left: none;}
}
@media (max-width: 481px) {
	#ft .inner-ft{ padding: 42px 0 20px;}
	#ft p.note { font-size: 11px;}
	#ft p.note span { font-size: 13px;}
	#ft p.note span em { font-size: 16px;}
}


#win-cart .inner { position: relative; width: 92%; max-width: 1000px; margin: 0 auto; padding: 30px; background: #fff; border-radius: 18px;}
#win-cart .ctn { width: 100%; max-width: 600px; margin: 0 auto; padding-bottom: 30px;}
#win-cart .ctn h4 { margin-bottom: 50px; font-size: clamp(12px,2.0vw,18px);; font-weight: 700; letter-spacing: 0.1rem; line-height: 1.2; text-align: center;}
#win-cart .ctn h4 span { display: block; margin-bottom: 8px; font-size: clamp(18px,3.2vw,32px);}
#win-cart .ctn ul { width: 100%; margin: 0 auto; font-size: 0;}
#win-cart .ctn ul li { display: inline-block; width: 50%; padding: 8px; font-size: clamp(11px,2.0vw,18px);}
#win-cart .ctn ul li a { display: block; padding: 8px 0; background: #502612; color: #fff; font-weight: 700; text-align: center; text-decoration: none;}
#win-cart .ctn ul li a em { font-size: clamp(14px,2.1vw,21px);}
#win-cart .ctn ul li span { display: block; padding: 8px 0; background: #967d71; color: #fff; font-weight: 700; text-align: center; text-decoration: none;}
#win-cart .ctn ul li span em { font-size: clamp(14px,2.1vw,21px);}


#win-cart .btn-close { position: absolute; right: 20px; top: 20px; width: 40px; height: 40px;}
#win-cart .btn-close div { position: relative; width: 100%; height: 100%; cursor: pointer;}
#win-cart .btn-close div:before,
#win-cart .btn-close div:after { content: ''; display: block; width: 2px; height: 80%; background: #502612;
 position: absolute; left: 50%; top: 50%;
}
#win-cart .btn-close div:before{ transform: translate(-50%,-50%) rotate(45deg);}
#win-cart .btn-close div:after { transform: translate(-50%,-50%) rotate(-45deg);}
@media (max-width: 481px) {
	#win-cart .inner { padding: 20px 12px;}
	#win-cart .ctn { padding-bottom: 12px;}
	#win-cart .ctn h4 { margin-bottom: 20px;}
	#win-cart .ctn ul { max-width: 220px;}
	#win-cart .ctn ul li { display: block; width: 100%; padding: 12px 0;}
	#win-cart .btn-close { position: absolute; right: 12px; top: 12px; width: 32px; height: 32px;}
}