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

body { color: #231815; background: #ffffff; font-size: 1.6vw; letter-spacing: .08em; line-height: 1.6; font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; font-feature-settings: "palt"; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
@media screen and (max-width: 599px) { body { font-size: 3.2vw; } }

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

.fnt-dor { font-family: "Darumadrop One", sans-serif; font-weight: 400; font-style: normal; }

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: #231815; text-decoration: none; transition: opacity 0.5s; }
a:hover, a:active { opacity: .6; }

#cover { width: 100%; height: 100%; position: fixed; background: #ffffff; 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: 599px) { #loader { width: 210px; height: 175px; } }

#wrapper { overflow: hidden; position: relative; }

#page-top { opacity: 0; position: fixed; bottom: 20px; right: 20px; z-index: 9000; width: 40px; pointer-events: none; }
#page-top img { width: 100%; height: auto; }
#page-top.fade { opacity: 1; transition: opacity .5s; pointer-events: auto; }

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

@media screen and (max-width: 599px) { .nn599 { 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, .fadein1.active, .fadein2.active, .fadein3.active, .fadein4.active, .fadein5.active, .fadein6.active, .fadeinF.active { opacity: 1; transform: translateY(0); }

#header h1 { position: absolute; z-index: 900; top: 2em; left: 5%; width: 9.5em; }
@media screen and (max-width: 599px) { #header h1 { width: 7em; } }
#header h1 img { width: 100%; height: auto; }
#header nav { position: absolute; z-index: 901; top: 35.75em; left: 0; width: 100%; }
#header nav.lower { top: 11em; }
#header nav.fixed { position: fixed; top: 0; }
#header nav .gMenu { position: relative; }
@media screen and (max-width: 599px) { #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; justify-content: space-between; }
@media screen and (max-width: 599px) { #header nav .gMenu ul { display: block; text-align: center; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); } }
#header nav .gMenu ul li { flex-grow: 1; }
@media screen and (max-width: 599px) { #header nav .gMenu ul li { flex: none; width: 100%; } }
#header nav .gMenu ul li a { display: block; background: #00592f; color: #ffffff; text-align: center; padding: .8em 0; }
@media screen and (max-width: 599px) { #header nav .gMenu ul li a { width: 100%; font-size: 7vw; padding: 2.6vw 0; } }
#header nav .gMenu ul li a span { display: block; font-weight: 500; }
#header nav .gMenu ul li a small { display: block; }
#header nav .menu-trigger { display: none; }
@media screen and (max-width: 599px) { #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: #231815; border-radius: 2px; }
  #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: 599px) { #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); } }
#header .sideB { position: fixed; z-index: 901; top: 50%; right: 0; display: flex; flex-direction: column; }
@media screen and (max-width: 599px) { #header .sideB { transform: none; top: inherit; bottom: 12%; } }
#header .sideB a.reserv { position: relative; display: inline-block; background: #00592f url("../img/icn_reserv.svg") no-repeat center 13%/55%; color: #ffffff; font-weight: 500; writing-mode: vertical-rl; padding: 3em .5em 1em; line-height: 2; margin-bottom: 1.5em; box-shadow: 0 0 3px 1px rgba(0, 0, 0, 0.3); }
#header .sideB a.mail { position: relative; display: inline-block; background: #ffffff url("../img/icn_mail.svg") no-repeat center 13%/55%; color: #00592f; font-weight: 500; line-height: 2; letter-spacing: .02em; writing-mode: vertical-rl; padding: 3em .5em 1em; box-shadow: 0 0 3px 1px rgba(0, 0, 0, 0.3); }

main { position: relative; }
main section { position: relative; }
main section .headM { display: block; text-align: center; color: #00592f; font-size: 230%; font-weight: 500; margin-bottom: .2em; }
@media screen and (max-width: 599px) { main section .headM { font-size: 210%; line-height: 1.5; margin-bottom: .4em; } }
main section .headS { display: block; color: #626262; text-align: center; margin-bottom: 2.8em; }
@media screen and (max-width: 599px) { main section .headS { font-size: 110%; } }
main section#topMainSct { background: url("../img/top_main_pic.webp") no-repeat center center/cover; padding: 13em 0; }
@media screen and (max-width: 599px) { main section#topMainSct { padding: 10em 0 16em; } }
main section#topMainSct .copy { display: block; text-align: center; font-size: 170%; letter-spacing: .25em; line-height: 1.6; text-shadow: 0 0 5px #ffffff, 0 0 5px #ffffff, 0 0 5px #ffffff, 0 0 5px #ffffff, 0 0 5px #ffffff, 0 0 5px #ffffff; }
main section#topMainSct .copy span { color: #00592f; font-size: 130%; }
main section#topMainSct .consult { position: absolute; left: 3%; bottom: 1.2em; width: 15em; }
main section#topMainSct .consult a { display: block; box-shadow: 0 0 3px 1px rgba(0, 0, 0, 0.3); }
main section#topMainSct .consult a img { width: 100%; height: auto; }
main section#topAboutSct { padding: 9em 0 0; }
@media screen and (max-width: 599px) { main section#topAboutSct { padding: 4em 0 0; } }
main section#topAboutSct .box1 { position: relative; margin-bottom: 3.5em; }
@media screen and (max-width: 599px) { main section#topAboutSct .box1 { margin-bottom: 3.5em; } }
main section#topAboutSct .box1 .bgImg { width: 84%; height: auto; }
@media screen and (max-width: 599px) { main section#topAboutSct .box1 .bgImg { position: relative; width: 100%; left: -10%; } }
main section#topAboutSct .box1 .txtB { position: absolute; right: 0; top: 7.2em; width: 38%; background: #00592f; color: #ffffff; padding: 1.5em 3.5em 1.5em 2em; }
@media screen and (max-width: 599px) { main section#topAboutSct .box1 .txtB { right: inherit; top: inherit; position: relative; margin: -3em 0 0 16%; width: 84%; } }
main section#topAboutSct .box1 .txtB .ttl { display: block; text-align: center; font-size: 200%; line-height: 1.4; letter-spacing: .15em; margin-bottom: .3em; }
main section#topAboutSct .box1 .txtB .ttl small { display: block; font-size: 45%; letter-spacing: .05em; }
main section#topAboutSct .box1 .txtB .txt { font-size: 80%; }
main section#topAboutSct .box2 { position: relative; margin-bottom: 7em; }
main section#topAboutSct .box2 .bgImg { width: 84%; height: auto; margin-left: 16%; }
@media screen and (max-width: 599px) { main section#topAboutSct .box2 .bgImg { position: relative; width: 100%; right: -10%; margin-left: 0; } }
main section#topAboutSct .box2 .txtB { position: absolute; left: 0; top: 7.2em; width: 38%; background: #9f7447; color: #ffffff; padding: 1.5em 2.5em 2.5em 3em; }
@media screen and (max-width: 599px) { main section#topAboutSct .box2 .txtB { left: inherit; top: inherit; position: relative; margin: -3em 0 0 0; width: 84%; } }
main section#topAboutSct .box2 .txtB .ttl { display: block; text-align: center; font-size: 200%; line-height: 1.4; letter-spacing: .15em; margin-bottom: .3em; }
main section#topAboutSct .box2 .txtB .ttl small { display: block; font-size: 45%; letter-spacing: .05em; }
main section#topAboutSct .box2 .txtB .txt { font-size: 80%; }
main section#topAboutSct .box3 { position: relative; background: #ededed; padding: 7em 0; }
main section#topAboutSct .box3 .logo { display: block; width: 10em; height: auto; margin: 0 auto 2em; }
main section#topAboutSct .box3 .headS { margin-bottom: 0; }
main section#topAboutSct .box3 .btn { display: block; text-align: center; margin-top: 4.5em; }
main section#topAboutSct .box3 .btn a { display: inline-block; color: #00592f; font-weight: 500; letter-spacing: .2em; line-height: 1.6; padding: 0 4em; border: 2px solid #00592f; border-radius: 2em; }
@media screen and (max-width: 599px) { main section#topAboutSct .box3 .btn a { padding: 1em 6em; border-radius: 3em; } }
main section#topBuySct { padding: 6em 6%; }
main section#topBuySct .spAtn { display: none; text-align: right; padding: .2em 2em 0 0; }
@media screen and (max-width: 599px) { main section#topBuySct .spAtn { display: block; } }
main section#topBuySct .achieveBox { position: relative; overflow-y: scroll; border-top: 3px solid #231815; border-bottom: 3px solid #231815; padding-top: .5em; height: 30em; }
main section#topBuySct .achieveBox table { position: relative; width: 99.5%; border-bottom: 1px solid #cbcbcb; border-right: 1px solid #cbcbcb; margin-right: .2em; }
@media screen and (max-width: 599px) { main section#topBuySct .achieveBox table { margin-right: 1.5em; } }
main section#topBuySct .achieveBox table tr th { background: #00592f; text-align: center; color: #ffffff; font-weight: 500; border-left: 1px solid #cbcbcb; padding: .4em .5em; white-space: nowrap; }
@media screen and (max-width: 599px) { main section#topBuySct .achieveBox table tr th { padding: .8em 1em; } }
main section#topBuySct .achieveBox table tr td { text-align: center; font-weight: 500; border-left: 1px solid #cbcbcb; padding: .4em .5em; white-space: nowrap; }
@media screen and (max-width: 599px) { main section#topBuySct .achieveBox table tr td { padding: .8em 1em; } }
main section#topBuySct .achieveBox table tr:nth-child(2n+1) { background: #ededed; }
main section#topCompanySct { background: #ededed; padding: 6em 12% 8em; }
@media screen and (max-width: 599px) { main section#topCompanySct { padding: 6em 12% 5em; } }
main section#topCompanySct .headM { margin-bottom: 0; }
main section#topCompanySct table { position: relative; color: #626262; margin-bottom: 5em; border-top: 1px solid #cbcbcb; width: 100%; }
main section#topCompanySct table tr { border-bottom: 1px solid #cbcbcb; }
main section#topCompanySct table tr th { font-weight: 500; padding: 1.2em 2em; vertical-align: middle; }
@media screen and (max-width: 599px) { main section#topCompanySct table tr th { padding: 1.2em 1em; line-height: 1.3; white-space: nowrap; text-align: center; } }
main section#topCompanySct table tr td { font-weight: 500; padding: 1em 2em; vertical-align: middle; }
@media screen and (max-width: 599px) { main section#topCompanySct table tr td { padding: 1.2em 1em; line-height: 1.3; } }
main section#topCompanySct .gMap iframe { width: 100%; height: 30em; }
main section#picSct ul { position: relative; display: flex; width: 100%; }
@media screen and (max-width: 599px) { main section#picSct ul { flex-wrap: wrap; } }
main section#picSct ul li { width: 25%; }
@media screen and (max-width: 599px) { main section#picSct ul li { width: 50%; } }
main section#picSct ul li img { width: 100%; height: auto; }
main section#privacyMainSct { background: url("../img/top_main_pic.webp") no-repeat center 85%/cover; padding: 5.5em 0; opacity: .5; }
main section#privacyContentSct { padding: 8em 10% 5em; }
@media screen and (max-width: 599px) { main section#privacyContentSct { padding: 5em 10%; } }
main section#privacyContentSct h2 { display: block; font-size: 160%; margin-bottom: 1em; }
main section#privacyContentSct .ttl { display: block; font-size: 130%; padding: 1.2em 0 .8em; }
main section#privacyContentSct .txt { display: block; }

#footer { position: relative; }
#footer .inner { background: #323232; color: #ffffff; text-align: center; padding: 5em 6%; }
@media screen and (max-width: 599px) { #footer .inner { padding: 5em 6% 2em; } }
#footer .inner .logo { display: block; margin: 0 auto 2em; width: 10em; height: auto; }
#footer .inner .add { display: block; font-weight: 500; line-height: 1.6; }
@media screen and (max-width: 599px) { #footer .inner .add { font-size: 110%; } }
#footer .inner .tel { position: relative; transform: scaleY(90%); display: inline-block; font-size: 280%; font-weight: 700; padding-left: 1.3em; background: url("../img/icn_tel.svg") no-repeat left center/1em; margin-bottom: .6em; }
@media screen and (max-width: 599px) { #footer .inner .tel { font-size: 230%; } }
#footer .inner .tel a { color: #ffffff; }
#footer .inner hr { display: block; width: 100%; color: #ffffff; margin-bottom: 2.2em; }
#footer .inner .fMenu { position: relative; display: flex; justify-content: center; }
@media screen and (max-width: 599px) { #footer .inner .fMenu { display: block; } }
#footer .inner .fMenu li { padding: 0 2.5em; }
#footer .inner .fMenu li a { display: block; color: #ffffff; font-size: 80%; text-align: left; margin-bottom: 1em; }
@media screen and (max-width: 599px) { #footer .inner .fMenu li a { text-align: center; font-size: 100%; margin-bottom: .8em; } }
#footer .cpr { background: #231815; padding: .8em 0; color: #ffffff; text-align: center; font-size: 70%; }
@media screen and (max-width: 599px) { #footer .cpr { font-size: 90%; } }
