html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; outline: 0; font-size: 100%; vertical-align: baseline; background: transparent; font-family: "TsukuGoPr5-R-HelveticaNowTextLight", "Hiragino Kaku Gothic", "Yu Gothic Medium", YuGothic, Meiryo, "MS PGothic", sans-serif; font-weight: 300; }

* { box-sizing: border-box; }

html { font-size: 62.5%; }

body { line-height: 1.6; font-size: 14px; font-size: 1.4rem; -webkit-text-size-adjust: 100%; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main { display: block; }

ul, li { list-style: none; }

blockquote, q { quotes: none; }

blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }

a { margin: 0; padding: 0; font-size: 100%; vertical-align: baseline; background: transparent; text-decoration: none; color: #000000; }

table { border-collapse: collapse; border-spacing: 0; }

input, select { vertical-align: middle; }

img { vertical-align: bottom; max-width: 100%; height: auto; image-rendering: -webkit-optimize-contrast; }

svg { -webkit-backface-visibility: hidden; }

.mfp-bg { background: #ff6e3f; opacity: 1.0; transition: all 1.0s ease-out; }
.mfp-bg.mfp-removing { opacity: 0; }

.mfp-wrap .mfp-content { opacity: 0; transition: all 0.5s ease-out; }
.mfp-wrap.mfp-ready .mfp-content { opacity: 1; }
.mfp-wrap.mfp-removing .mfp-content { opacity: 0; }

.mfp-figure { padding: 0; position: relative; }
.mfp-figure::after { display: none; }
.mfp-figure .mfp-bottom-bar { margin: 0; height: 100%; top: 0; display: flex; justify-content: flex-end; align-items: flex-start; }
.mfp-figure .mfp-title { padding: 4.5px; text-align: center; font-size: 20px; line-height: 1; color: #ff6e3f; }

.mfp-image-holder .mfp-close, .mfp-iframe-holder .mfp-close { color: #000; text-align: center; width: 100%; top: 100%; font-size: 0; opacity: 1.0; }
@media screen and (min-width: 769px) { .mfp-image-holder .mfp-close, .mfp-iframe-holder .mfp-close { position: fixed; top: 0; right: 0; width: 46px; height: 46px; padding: 0; } }
.mfp-image-holder .mfp-close::before, .mfp-image-holder .mfp-close::after, .mfp-iframe-holder .mfp-close::before, .mfp-iframe-holder .mfp-close::after { content: ""; display: block; width: 56px; height: 1px; background: #282828; position: absolute; top: 80px; left: 50%; margin-left: -31px; }
@media screen and (min-width: 769px) { .mfp-image-holder .mfp-close::before, .mfp-image-holder .mfp-close::after, .mfp-iframe-holder .mfp-close::before, .mfp-iframe-holder .mfp-close::after { top: 0; left: 0; margin-top: 20px; margin-left: -2px; } }
.mfp-image-holder .mfp-close::before, .mfp-iframe-holder .mfp-close::before { transform: rotate(45deg); }
.mfp-image-holder .mfp-close::after, .mfp-iframe-holder .mfp-close::after { transform: rotate(-45deg); }

img.mfp-img { padding: 0; }
@media screen and (min-width: 769px) { img.mfp-img { max-width: 962px; } }

.mv { position: relative; background: #282828; }
.mv_header { position: absolute; top: 2.13333vw; left: 2.13333vw; z-index: 10; width: 61.6vw; }
@media screen and (min-width: 769px) { .mv_header { top: 24px; left: 24px; width: 542px; } }
.mv .wrap { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; }
.mv .js_fade { opacity: 0; transition: all 2s; }
.mv .js_fade.done { opacity: 1; }
.mv_pic { position: relative; width: calc(100% / 2); }
@media screen and (min-width: 769px) { .mv_pic { width: calc(100% / 3); } }
@media screen and (max-width: 768px) { .mv_pic:nth-of-type(n+9) { display: none; } }
@media screen and (min-width: 769px) { .mv_pic:nth-of-type(n+10) { display: none; } }
.mv_pic-txt { position: absolute; z-index: 2; top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 14px; letter-spacing: 0.08em; line-height: 1; color: #ff6e3f; }
@media screen and (min-width: 769px) { .mv_pic-txt { font-size: 16px; } }
.mv_pic-txt + div { position: relative; }
.mv_pic-txt + div::before { content: ""; position: absolute; z-index: 1; top: 0; left: 0; width: 100%; height: 100%; transition: 0.3s; background: rgba(0, 0, 0, 0.5); }
.mv_pic a:hover div::before { background: rgba(0, 0, 0, 0.4); }

.main_lead { background: #1e1512; }
@media screen and (max-width: 768px) { .main_lead .wrap { padding: 45px 6%; } }
@media screen and (min-width: 769px) { .main_lead .wrap { width: 560px; margin: 0 auto; padding: 100px 0; } }
.main_lead-txt { position: relative; padding-left: 6px; color: #d1c4c0; font-size: 11px; letter-spacing: 0.13em; line-height: 2.54545; }
@media screen and (min-width: 769px) { .main_lead-txt { font-size: 16px; line-height: 2.375; } }
.main_lead-txt span { font-size: 10px; line-height: 1; }
@media screen and (min-width: 769px) { .main_lead-txt span { font-size: 13px; } }
.main_lead-txt::before { content: ""; display: block; background: #ff6e3f; position: absolute; top: 1.5%; left: 0; width: 1px; height: 97.5%; }
.main_block .wrap { background: #ff6e3f; }
@media screen and (max-width: 768px) { .main_block .wrap { display: flex; flex-wrap: wrap; } }
@media screen and (min-width: 1150px) { .main_block .wrap { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; } }
.main_block .wrap > div { flex-basis: 100%; }
@media screen and (min-width: 1150px) { .main_block .wrap > div { flex-basis: 50%; } }
@media screen and (max-width: 768px) { .main_block-txt { padding: 16.53333vw 12vw; order: 2; } }
@media screen and (max-width: 1150px) { .main_block-txt { padding: 48px 12vw; order: 2; } }
.main_block-txt .block_inner { margin: 0 auto; }
.main_block-txt .block_inner * { color: #1e1512; }
@media screen and (min-width: 769px) { .main_block-txt .block_inner { width: 62.5%; min-width: 300px; max-width: 550px; } }
@media screen and (min-width: 769px) and (max-width: 1024px) { .main_block-txt .block_inner { width: 83.33333%; } }
@media screen and (min-width: 1024px) and (max-width: 1350px) { .main_block-txt .block_inner { width: 83.33333%; } }
.main_block-txt .block_mainttl { font-size: 22px; line-height: 1; letter-spacing: 0.08em; }
@media screen and (min-width: 769px) { .main_block-txt .block_mainttl { font-size: 32px; } }
.main_block-txt .block_mainttl + .block_ttl { margin-top: 30px; }
@media screen and (min-width: 769px) { .main_block-txt .block_mainttl + .block_ttl { margin-top: 70px; } }
.main_block-txt .block_ttl span { display: inline-block; background: #1e1512; padding: 3px 4px 5px 5px; color: #ff6e3f; font-size: 11px; line-height: 1; letter-spacing: 0.13em; }
@media screen and (min-width: 769px) { .main_block-txt .block_ttl span { font-size: 16px; } }
.main_block-txt .block_ttl br + span { margin-top: 4px; }
.main_block-txt .block_txt { margin-top: 1em; font-size: 10px; line-height: 2.2; letter-spacing: 0.15em; }
.main_block-txt .block_txt span { font-size: 10px; line-height: 1; }
@media screen and (min-width: 769px) { .main_block-txt .block_txt span { font-size: 12px; } }
@media screen and (min-width: 769px) { .main_block-txt .block_txt { margin-top: 32px; font-size: 13px; line-height: 2.15385; } }
.main_block-txt .block_txt.txt_underline { text-decoration: underline; margin-bottom: 1em; margin-top: 30px; }
@media screen and (min-width: 769px) { .main_block-txt .block_txt.txt_underline { margin-top: 70px; } }
.main_block-txt .block_txt.txt_name { font-size: 13px; line-height: 1.92308; }
@media screen and (min-width: 769px) { .main_block-txt .block_txt.txt_name { font-size: 18px; line-height: 1.77778; } }
.main_block-txt .block_txt .txt_price { display: block; font-size: 12px; line-height: 1.83333; }
@media screen and (min-width: 769px) { .main_block-txt .block_txt .txt_price { font-size: 16px; line-height: 1.75; } }
.main_block-txt .block_btn { margin-top: 36px; }
@media screen and (min-width: 769px) { .main_block-txt .block_btn { margin-top: 60px; } }
.main_block-txt .block_btn a { display: block; width: 100%; line-height: 48px; text-align: center; transition: 0.3s; background: #ffffff; border: 2px solid #1e1512; color: #1e1512; }
@media screen and (min-width: 769px) { .main_block-txt .block_btn a { border: 2px solid #1e1512; } }
@media screen and (min-width: 769px) { .main_block-txt .block_btn a:hover { background: #1e1512; border: 2px solid #1e1512; color: #ffffff; } }
@media screen and (max-width: 768px) { .main_block-pic { order: 1; } }
.main_block-pic img { width: 100%; }
.main_block-pic .block_inner { margin: 0 auto; }
@media screen and (max-width: 768px) { .main_block-pic .block_inner { padding: 16.53333vw 12vw; } }
@media screen and (max-width: 1150px) { .main_block-pic .block_inner { padding: 48px 12vw; } }
@media screen and (min-width: 769px) { .main_block-pic .block_inner { width: 62.5%; min-width: 300px; max-width: 550px; padding: 120px 0; } }
@media screen and (min-width: 769px) and (max-width: 1024px) { .main_block-pic .block_inner { width: 83.33333%; } }
@media screen and (min-width: 1024px) and (max-width: 1350px) { .main_block-pic .block_inner { width: 83.33333%; } }
.main_block-pic .block_txt { background: #241a17; color: #a5a5a5; font-size: 10px; line-height: 2.2; letter-spacing: 0.15em; padding: 0 0 0 5px; }
@media screen and (min-width: 769px) { .main_block-pic .block_txt { font-size: 13px; line-height: 2.15385; } }
.main_block-pic .block_txt + .block_txt { margin-top: 25px; }
@media screen and (min-width: 769px) { .main_block-pic .block_txt + .block_txt { margin-top: 24px; } }
@media screen and (min-width: 769px) { .main_block.block_02 .main_block-txt, .main_block.block_04 .main_block-txt { order: 2; } }
@media screen and (min-width: 769px) { .main_block.block_02 .main_block-pic, .main_block.block_04 .main_block-pic { order: 1; } }
.main_block.block_03 .main_block-pic { background: #1e1512; }
.main_block.block_05 .wrap { background: #ffffff; }
.main_sticky { display: none; position: fixed; top: 50%; right: 0; transform: translateY(-50%); z-index: 100; }
.main_sticky ul { display: flex; flex-direction: column; }
.main_sticky ul li { width: 8vw; }
@media screen and (min-width: 769px) { .main_sticky ul li { width: 40px; } }
.main_sticky ul li:nth-child(n+2) { margin-top: 3px; }
@media screen and (min-width: 769px) { .main_sticky ul li:nth-child(n+2) { margin-top: 1px; } }

.footer { background: #1e1512; padding: 60px 0; }
@media screen and (max-width: 768px) { .footer .wrap { padding: 0 12.8vw; } }
.footer_btn a { display: block; width: 100%; line-height: 48px; text-align: center; transition: 0.3s; letter-spacing: 0.15em; background: #1e1512; border: 2px solid #d2c4bf; color: #d2c4bf; }
@media screen and (min-width: 769px) { .footer_btn a { width: 280px; margin: 0 auto; border: 2px solid #d2c4bf; } }
@media screen and (min-width: 769px) { .footer_btn a:hover { background: #d2c4bf; border: 2px solid #d2c4bf; color: #1e1512; } }
.footer_copyright { margin-top: 30px; text-align: center; }
.footer_copyright small { color: #d2c4bf; font-size: 8px; letter-spacing: 0.15em; }

.js_slidein::before { position: absolute; z-index: 1; top: 0; left: 0; display: inline-block; width: 0; height: 100%; content: ''; background: #ffffff; }

.block_05 .js_slidein::before { background: #ff6e3f; }

.js_slidein { display: inline-block; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); opacity: 0; overflow: hidden; }

.js_slidein.slide_move::before { -webkit-animation: passing-bar 1.5s ease 0s 1 normal forwards; animation: passing-bar 1.5s ease 0s 1 normal forwards; }

.js_slidein.slide_move { -webkit-animation: passing-txt 0s ease .1s 1 normal forwards; animation: passing-txt 0s ease .1s 1 normal forwards; }

@-webkit-keyframes passing-bar { 0% { left: 0; width: 0; opacity: 1.0; }
  50% { left: 0; width: 100%; opacity: 1.0; }
  51% { left: 0; width: 100%; opacity: 1.0; }
  99% { left: 100%; width: 0; opacity: 1.0; }
  100% { left: 100%; width: 0; opacity: 0; } }
@keyframes passing-bar { 0% { left: 0; width: 0; opacity: 1.0; }
  50% { left: 0; width: 100%; opacity: 1.0; }
  51% { left: 0; width: 100%; opacity: 1.0; }
  99% { left: 100%; width: 0; opacity: 1.0; }
  100% { left: 100%; width: 0; opacity: 0; } }
@-webkit-keyframes passing-txt { 0% { opacity: 0; }
  50% { opacity: 0; }
  100% { opacity: 1; } }
@keyframes passing-txt { 0% { opacity: 0; }
  50% { opacity: 0; }
  100% { opacity: 1; } }
