*, *::before, *::after { box-sizing: border-box; }

body { color: #2e2b2c; background: #f3f0ec; font-size: 1.4vw; font-weight: 500; letter-spacing: .1em; font-family: 'Noto Sans JP', BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif; font-feature-settings: "palt"; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
@media screen and (max-width: 519px) { body { font-size: 2.8vw; } }

_:lang(x)::-ms-backdrop, .selector { font-family: "Segoe UI", Meiryo, sans-serif; }

.fnt-unna { font-family: 'Unna', serif; }

p { line-height: 1.8; }

img { border: 0; vertical-align: top; }

input, select { position: relative; top: 1px; }

table, th, td { border-collapse: collapse; border-spacing: 0; }

ul, li { list-style: none; }

a:link, a:visited { color: #960d00; text-decoration: none; transition: opacity 0.5s; }
a:hover, a:active { opacity: .6; }

#cover { width: 100%; height: 100%; position: fixed; background: #f3f0ec; top: 0; left: 0; z-index: 10000; }

#loader { opacity: 0; position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; width: 300px; height: 250px; }
#loader img { width: 100%; height: auto; }
@media screen and (max-width: 519px) { #loader { width: 210px; height: 175px; } }

#wrapper { position: relative; }

#page-top { position: fixed; bottom: 20px; right: 20px; z-index: 9000; width: 40px; opacity: .8; }
#page-top img { width: 100%; height: auto; }

.dd960 { display: none; }
@media screen and (max-width: 959px) { .dd960 { display: block !important; } }

@media screen and (max-width: 959px) { .nn960 { display: none !important; } }

.dd520 { display: none; }
@media screen and (max-width: 519px) { .dd520 { display: block !important; } }

@media screen and (max-width: 519px) { .nn520 { display: none !important; } }

.fadeinS, .fadein1, .fadein2, .fadein3, .fadein4, .fadein5, .fadein6, .fadeinF { opacity: 0; transform: translateY(30px); transition: opacity 1s ease-in, transform 1s ease-out; }
.fadeinS.active, .fadeinS.active, .fadein1.active, .fadein1.active, .fadein2.active, .fadein2.active, .fadein3.active, .fadein3.active, .fadein4.active, .fadein4.active, .fadein5.active, .fadein5.active, .fadein6.active, .fadein6.active, .fadeinF.active, .fadeinF.active { opacity: 1; transform: translateY(0); }

#header { overflow: hidden; position: fixed; z-index: 900; display: flex; justify-content: space-between; width: 100%; padding: 1em 1em 0; font-size: 130%; }
#header h1 { position: relative; letter-spacing: .03em; text-shadow: 1px 1px 1px #d7c8b5; }
@media screen and (max-width: 519px) { #header h1 { display: none; } }
#header nav .gMenu { position: relative; }
@media screen and (max-width: 519px) { #header nav .gMenu { position: fixed; display: block; top: 0; left: 0; width: 100%; margin: 0 auto; z-index: 999; opacity: 0; height: 0; max-height: 0; overflow: hidden; transition: max-height 0s, opacity .4s; }
  #header nav .gMenu.active { opacity: 1; height: 100%; max-height: 100%; background: rgba(255, 255, 255, 0.8); } }
#header nav .gMenu ul { position: relative; display: flex; width: 100%; }
@media screen and (max-width: 519px) { #header nav .gMenu ul { display: block; text-align: center; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); } }
#header nav .gMenu ul li { padding: 0 .5em; }
@media screen and (max-width: 519px) { #header nav .gMenu ul li { flex: none; width: 100%; } }
#header nav .gMenu ul li a { display: block; text-align: center; width: 100%; letter-spacing: .03em; text-shadow: 1px 1px 1px #d7c8b5; }
@media screen and (max-width: 519px) { #header nav .gMenu ul li a { width: 100%; font-size: 7vw; padding: 4vw 0; } }
#header nav .menu-trigger { display: none; }
@media screen and (max-width: 519px) { #header nav .menu-trigger { display: inline-block; transition: all .4s; position: fixed; z-index: 9999; width: 40px; height: 34px; top: 20px; right: 20px; }
  #header nav .menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box; position: absolute; width: 100%; height: 2px; background-color: #960d00; border-radius: 2px; box-shadow: 1px 1px 1px #d7c8b5; }
  #header nav .menu-trigger span:nth-of-type(1) { top: 0; }
  #header nav .menu-trigger span:nth-of-type(2) { top: 16px; }
  #header nav .menu-trigger span:nth-of-type(3) { bottom: 0; } }
@media screen and (max-width: 519px) { #header nav .menu-trigger.active span:nth-of-type(1) { transform: translateY(16px) rotate(-45deg); }
  #header nav .menu-trigger.active span:nth-of-type(2) { opacity: 0; }
  #header nav .menu-trigger.active span:nth-of-type(3) { transform: translateY(-16px) rotate(45deg); } }

main { position: relative; }
main section { position: relative; text-align: center; }
main section#topMainSct { background: url("../img/top_main_pic2.jpg") no-repeat center center/cover; height: 50vw; }
@media screen and (max-width: 519px) { main section#topMainSct { height: 140vw; } }
main section#topMainSct .logo { position: absolute; left: 50%; top: 50%; transform: translateX(-50%) translateY(-55%); width: 25vw; }
@media screen and (max-width: 519px) { main section#topMainSct .logo { width: 50vw; } }
main section#topMainSct .logo img { width: 100%; height: auto; }
main section#topMainSct .infoB { position: absolute; width: 90%; left: 5%; bottom: 1.5em; background: #d7c8b5; padding: 1em 1.8em 0; text-align: left; }
main section#topMainSct .infoB .post { display: block; color: #960d00; margin-bottom: 1em; }
main section#topConceptSct { padding: 1.5em; }
main section#topConceptSct .inner { background: url("../img/top_concept_bg.jpg") no-repeat center bottom/cover; padding: 3.5em 0 2.5em; }
@media screen and (max-width: 519px) { main section#topConceptSct .inner { padding: 5em 0 3em; } }
main section#topConceptSct .inner h2 { display: block; width: 20vw; margin: 0 auto 3em; }
@media screen and (max-width: 519px) { main section#topConceptSct .inner h2 { width: 50vw; } }
main section#topConceptSct .inner h2 img { width: 100%; height: auto; }
main section#topConceptSct .inner p { display: block; color: #fff; margin-bottom: 1em; }
@media screen and (max-width: 519px) { main section#topConceptSct .inner p { font-size: 130%; } }
main section#topStylistSct { padding: 1.5em; background: #7d0a00; }
main section#topStylistSct .inner { background: url("../img/top_stylist_bg.jpg") no-repeat center center/cover; padding: 3em 0; border: 1px solid #fff; }
@media screen and (max-width: 519px) { main section#topStylistSct .inner { padding: 4em 0 1em; } }
main section#topStylistSct .inner h2 { display: block; width: 20vw; margin: 0 auto 3em; }
@media screen and (max-width: 519px) { main section#topStylistSct .inner h2 { width: 50vw; } }
main section#topStylistSct .inner h2 img { width: 100%; height: auto; }
main section#topStylistSct .inner ul { display: flex; justify-content: center; width: 84%; margin: 0 auto; }
@media screen and (max-width: 519px) { main section#topStylistSct .inner ul { display: block; } }
main section#topStylistSct .inner ul li { width: 47.5%; }
@media screen and (max-width: 519px) { main section#topStylistSct .inner ul li { width: 100%; margin-bottom: 3em; } }
main section#topStylistSct .inner ul li img { width: 100%; height: auto; }
main section#topStylistSct .inner ul li .txtB { padding-top: 2em; color: #fff; text-align: left; }
main section#topStylistSct .inner ul li .txtB .name { position: relative; }
main section#topStylistSct .inner ul li .txtB .name span { font-size: 180%; font-weight: 700; letter-spacing: .2em; }
main section#topStylistSct .inner ul li .txtB .name small { font-size: 110%; padding-left: .5em; }
main section#topStylistSct .inner ul li .txtB .job { display: block; letter-spacing: .25em; margin-bottom: .8em; }
main section#topStylistSct .inner ul li .txtB .txt { text-align: justify; text-justify: inter-ideograph; }
main section#topPriceSct { padding: 1.5em; }
main section#topPriceSct .inner { padding: 5em 0 4em; border-bottom: 1px solid #d7c8b5; }
main section#topPriceSct .inner h2 { display: block; width: 20vw; margin: 0 auto 3em; }
@media screen and (max-width: 519px) { main section#topPriceSct .inner h2 { width: 50vw; } }
main section#topPriceSct .inner h2 img { width: 100%; height: auto; }
main section#topPriceSct .inner .priceB { position: relative; width: 90%; margin: 0 auto; display: flex; justify-content: space-between; }
@media screen and (max-width: 519px) { main section#topPriceSct .inner .priceB { flex-direction: column-reverse; } }
main section#topPriceSct .inner .priceB .txtB { width: 48%; }
@media screen and (max-width: 519px) { main section#topPriceSct .inner .priceB .txtB { width: 100%; } }
main section#topPriceSct .inner .priceB .txtB .copy { display: block; font-size: 90%; text-align: justify; text-justify: inter-ideograph; margin-bottom: 1em; }
@media screen and (max-width: 519px) { main section#topPriceSct .inner .priceB .txtB .copy { margin-bottom: 1.8em; } }
main section#topPriceSct .inner .priceB .txtB dl { position: relative; display: flex; width: 80%; margin: 0 auto 1.4em; justify-content: space-between; flex-wrap: wrap; line-height: 1.6; }
@media screen and (max-width: 519px) { main section#topPriceSct .inner .priceB .txtB dl { margin-bottom: 3em; } }
main section#topPriceSct .inner .priceB .txtB dl dt { width: 50%; font-weight: 500; letter-spacing: .15em; text-align: left; }
main section#topPriceSct .inner .priceB .txtB dl dd { width: 50%; text-align-last: right; }
main section#topPriceSct .inner .priceB .txtB .btn a { display: inline-block; letter-spacing: .2em; padding: 1em 0 1em .2em; width: 24vw; border: 1px solid #d7c8b5; border-radius: .5em; background: #f3f0ec; box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.2); }
@media screen and (max-width: 519px) { main section#topPriceSct .inner .priceB .txtB .btn a { width: 100%; font-size: 150%; } }
main section#topPriceSct .inner .priceB .imgB { width: 48%; }
@media screen and (max-width: 519px) { main section#topPriceSct .inner .priceB .imgB { width: 100%; margin-bottom: 1.5em; } }
main section#topPriceSct .inner .priceB .imgB img { width: 100%; height: auto; }
main section#topReservationSct { padding: 1.5em; }
main section#topReservationSct .inner { padding: 4em 0 5em; }
main section#topReservationSct .inner h2 { display: block; width: 20vw; margin: 0 auto 3em; }
@media screen and (max-width: 519px) { main section#topReservationSct .inner h2 { width: 50vw; } }
main section#topReservationSct .inner h2 img { width: 100%; height: auto; }
main section#topReservationSct .inner .atn { display: block; margin-bottom: 2em; }
@media screen and (max-width: 519px) { main section#topReservationSct .inner .atn { margin-bottom: 3em; } }
main section#topReservationSct .inner .btn { display: flex; align-items: center; justify-content: center; }
@media screen and (max-width: 519px) { main section#topReservationSct .inner .btn { display: block; } }
main section#topReservationSct .inner .btn a { display: inline-block; letter-spacing: .2em; padding: 1em 0 1em .2em; width: 24vw; border: 1px solid #d7c8b5; border-radius: .5em; background: #f3f0ec; box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.2); margin: 0 .6em; }
@media screen and (max-width: 519px) { main section#topReservationSct .inner .btn a { display: block; width: 90%; font-size: 150%; margin: 0 auto 1.5em; } }
main section#topReservationSct .inner .btn a.hpb { padding: .6em 0; }
main section#topReservationSct .inner .btn a.hpb img { width: 35%; height: auto; }
main section#topAccessSct { padding: 4em 0; background: url("../img/top_access_bg.jpg") no-repeat center center/cover; }
@media screen and (max-width: 519px) { main section#topAccessSct { padding: 4em 0 6em; } }
main section#topAccessSct h2 { display: block; width: 20vw; margin: 0 auto 3em; }
@media screen and (max-width: 519px) { main section#topAccessSct h2 { width: 50vw; } }
main section#topAccessSct h2 img { width: 100%; height: auto; }
main section#topAccessSct p { display: block; color: #fff; margin-bottom: 1em; }
main section#topAccessSct .gmap { width: 76%; margin: 0 auto; }

#footer { position: relative; padding: 2em 0; background: #d7c8b5; }
#footer .cpr { text-align: center; font-size: 80%; }
