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

body { color: #113516; background: #fff; font-size: 1.4vw; letter-spacing: .05em; line-height: 1.6; font-family: "Zen Maru Gothic", sans-serif; font-weight: 500; 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: 2.8vw; } }

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

.fnt-zkgn { font-family: "Zen Kaku Gothic New", sans-serif; font-weight: 700; 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: #113516; text-decoration: none; transition: opacity 0.5s; }
a:hover, a:active { opacity: .6; }

#cover { width: 100%; height: 100%; position: fixed; background: #fff; 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); }

.poBtn { position: relative; display: inline-block; line-height: 1; padding: 1em 3em; border: 1px solid #113516; border-radius: 2em; }

.poBox { padding: 2em; border: 1px solid #113516; }

#header { overflow: hidden; position: fixed; z-index: 900; display: flex; justify-content: space-between; width: 100%; padding: 1em 1em 0; }
#header .webBtn { position: fixed; top: 5em; right: 6%; }
@media screen and (max-width: 599px) { #header .webBtn { top: 1em; right: 18%; } }
#header .webBtn a { display: inline-block; padding: .65em .65em .5em .5em; color: #fff; background: url("../img/btn_bg1.svg") no-repeat center center/contain; text-align: center; font-size: 170%; line-height: 1.1; }
#header .instaBtn { position: fixed; top: 0; left: 0; }
#header .instaBtn a { display: inline-block; padding: 1em 1em 3.8em .6em; color: #fff; background: url("../img/btn_bg2.svg") no-repeat left top/contain; }
#header .instaBtn a .ttl { position: relative; display: block; font-size: 220%; font-weight: 700; line-height: 1.2; padding-left: 1.3em; background: url("../img/icn_insta.svg") no-repeat left top/1.2em; margin-bottom: .2em; }
#header .instaBtn a .txt { display: block; font-size: 90%; line-height: 1.2; padding-left: 1.8em; }
#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; width: 100%; display: block; text-align: center; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); }
@media screen and (max-width: 599px) { #header nav .gMenu ul { top: 45%; } }
#header nav .gMenu ul li { padding: 0 .5em; }
#header nav .gMenu ul li a { display: block; text-align: center; width: 100%; font-size: 200%; padding: 1.6vw 0; }
@media screen and (max-width: 599px) { #header nav .gMenu ul li a { font-size: 220%; padding: .6em 0; } }
#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: #113516; box-shadow: 2px 2px 1px #fff; 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; }
#header nav .menu-trigger.active span:nth-of-type(1) { transform: translateY(18px) 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; }
main section#topMainSct { padding: 8em 0 12em; background: url("../img/top_bg1.webp") no-repeat center top/100%; }
@media screen and (max-width: 599px) { main section#topMainSct { padding: 14em 0 14em; background-size: 225%; } }
main section#topMainSct h1 { position: relative; z-index: 100; display: block; margin: 0 auto; width: 32%; }
@media screen and (max-width: 599px) { main section#topMainSct h1 { width: 70%; } }
main section#topMainSct h1 img { width: 100%; height: auto; }
main section#topMainSct::before { content: ""; position: absolute; left: -5em; top: 8em; width: 24em; height: 23em; background: url("../img/sd_cat.webp") no-repeat center center/contain; }
@media screen and (max-width: 599px) { main section#topMainSct::before { left: -7em; top: 24em; width: 17em; height: 15em; } }
main section#topMainSct::after { content: ""; position: absolute; right: -1em; top: 12em; width: 22em; height: 18em; background: url("../img/sd_dog.webp") no-repeat center center/contain; }
@media screen and (max-width: 599px) { main section#topMainSct::after { right: -6em; top: 26.5em; width: 17em; height: 12em; } }
main section#topInfoSct { background: url("../img/top_bg2.webp") no-repeat center top/cover; padding: 2em 7% 14em; display: flex; flex-wrap: wrap; justify-content: center; top: -5em; margin-bottom: -5em; }
@media screen and (max-width: 599px) { main section#topInfoSct { display: block; } }
main section#topInfoSct .timeBox { width: 50%; padding-right: 3%; margin-bottom: 4em; }
@media screen and (max-width: 599px) { main section#topInfoSct .timeBox { width: 100%; padding-right: 0; margin-bottom: 3em; } }
main section#topInfoSct .timeBox .ttl { font-size: 200%; font-weight: 700; padding-top: 4em; margin-bottom: .2em; }
main section#topInfoSct .timeBox table { position: relative; width: 100%; margin-bottom: .8em; }
main section#topInfoSct .timeBox table tr { border-bottom: 1px solid #113516; }
main section#topInfoSct .timeBox table tr td { vertical-align: middle; text-align: center; font-size: 130%; line-height: 1; padding: .4em 0; }
main section#topInfoSct .timeBox table tr td.week { font-weight: 700; padding: .4em .2em; }
main section#topInfoSct .timeBox table tr td.week.end { padding: .4em 0 .4em .2em; }
main section#topInfoSct .timeBox table tr td.week.t2 { letter-spacing: -.3em; padding: .4em .4em .4em 0; }
main section#topInfoSct .timeBox table tr td.time { font-weight: 700; }
main section#topInfoSct .timeBox table tr td.end2 { padding: .4em 0 .4em .2em; }
main section#topInfoSct .timeBox table tr td .mark { display: block; margin: 0 auto; width: 1em; height: auto; }
main section#topInfoSct .timeBox .atn { padding-left: .8em; }
main section#topInfoSct .timeBox .atn span { display: block; font-size: 95%; letter-spacing: .15em; line-height: 1.3; margin-bottom: .4em; }
main section#topInfoSct .infoBox { width: 50%; padding-left: 3%; margin-bottom: 4em; }
@media screen and (max-width: 599px) { main section#topInfoSct .infoBox { width: 100%; padding-left: 0; } }
main section#topInfoSct .infoBox .ttl { font-size: 200%; font-weight: 700; padding-top: 4em; margin-bottom: .4em; }
main section#topInfoSct .infoBox ul { position: relative; }
main section#topInfoSct .infoBox ul li { display: block; margin-bottom: 1em; }
main section#topInfoSct .infoBox ul li .postB { position: relative; display: block; background: #fff; border-radius: .8em; box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.2); padding: .3em 1em .4em; }
main section#topInfoSct .infoBox ul li .postB::before { display: none; content: ""; position: absolute; z-index: 5; top: 50%; right: 1.5em; transform: translateY(-42%) rotate(45deg); width: .5em; height: .5em; border-top: 2px solid #fff; border-right: 2px solid #fff; }
main section#topInfoSct .infoBox ul li .postB::after { display: none; content: ""; position: absolute; top: 50%; right: 1em; transform: translateY(-45%); background: #113516; border-radius: 50%; width: 1.3em; height: 1.3em; }
main section#topInfoSct .infoBox ul li .postB .day { position: relative; display: inline-block; font-size: 95%; line-height: 1.2; margin-right: 1em; }
main section#topInfoSct .infoBox ul li .postB .day.new { padding-right: 1.3em; }
main section#topInfoSct .infoBox ul li .postB .day.new::after { content: ""; position: absolute; top: .05em; right: 0; width: 1em; height: 1em; background: url("../img/icn_new.svg") no-repeat center center/contain; }
main section#topInfoSct .infoBox ul li .postB .cate { display: inline; font-size: 70%; font-weight: 700; line-height: 1.2; }
main section#topInfoSct .infoBox ul li .postB .cate span { position: relative; top: -.15em; display: inline-block; background: #f0f0f0; border-radius: .2em; padding: .1em .3em; margin-right: .3em; }
main section#topInfoSct .infoBox ul li .postB .head { display: block; font-size: 110%; font-weight: 700; line-height: 1.3; padding-left: .5em; }
main section#topInfoSct .copyBox { width: 100%; text-align: center; }
main section#topInfoSct .copyBox .ttl { display: block; font-size: 240%; font-weight: 700; line-height: 1.2; padding-left: .5em; margin-bottom: 1em; }
main section#topInfoSct .copyBox .txt span { display: block; font-size: 150%; line-height: 1.4; margin-bottom: .8em; }
main section#topDetaileSct { background: url("../img/top_bg3.webp") no-repeat center top/100%; padding: 7.5em 0 6em; top: -8em; margin-bottom: -8em; }
@media screen and (max-width: 599px) { main section#topDetaileSct { padding: .5em 0 6em; background-size: 200%; } }
main section#topDetaileSct .drBox { position: relative; display: flex; align-items: center; padding: 0 3%; }
@media screen and (max-width: 599px) { main section#topDetaileSct .drBox { display: block; margin-bottom: 2em; } }
main section#topDetaileSct .drBox .imgB { width: 67%; }
@media screen and (max-width: 599px) { main section#topDetaileSct .drBox .imgB { width: 100%; } }
main section#topDetaileSct .drBox .imgB img { width: 100%; height: auto; }
main section#topDetaileSct .drBox .txtB { width: 33%; padding-right: 3%; }
@media screen and (max-width: 599px) { main section#topDetaileSct .drBox .txtB { width: 90%; margin: 0 auto; padding-right: 0; } }
main section#topDetaileSct .drBox .txtB .name { display: block; font-size: 170%; font-weight: 700; margin-bottom: .3em; }
@media screen and (max-width: 599px) { main section#topDetaileSct .drBox .txtB .name { font-size: 200%; } }
main section#topDetaileSct .drBox .txtB .txt { display: block; font-size: 95%; letter-spacing: 0; line-height: 1.6; }
@media screen and (max-width: 599px) { main section#topDetaileSct .drBox .txtB .txt { font-size: 120%; } }
main section#topDetaileSct .drBox .txtB .histH { display: block; font-weight: 700; margin-top: 1em; }
@media screen and (max-width: 599px) { main section#topDetaileSct .drBox .txtB .histH { font-size: 180%; } }
main section#topDetaileSct .drBox .txtB .histT { display: block; font-size: 75%; line-height: 1.5; white-space: nowrap; margin-bottom: .5em; }
@media screen and (max-width: 599px) { main section#topDetaileSct .drBox .txtB .histT { font-size: 110%; } }
main section#topDetaileSct .diagnosisBox { position: relative; padding: 0 4%; margin-bottom: 5em; }
@media screen and (max-width: 599px) { main section#topDetaileSct .diagnosisBox { padding: 0 7%; margin-bottom: 6em; } }
main section#topDetaileSct .diagnosisBox .ttl { padding-left: 1em; font-size: 250%; font-weight: 700; letter-spacing: .1em; padding-top: 1.5em; margin-bottom: .1em; }
@media screen and (max-width: 599px) { main section#topDetaileSct .diagnosisBox .ttl { padding-top: 3em; padding-left: .5em; } }
main section#topDetaileSct .diagnosisBox .menuB { position: relative; display: flex; flex-wrap: wrap; justify-content: space-between; }
@media screen and (max-width: 599px) { main section#topDetaileSct .diagnosisBox .menuB { display: block; } }
main section#topDetaileSct .diagnosisBox .menuB li { width: 48.5%; }
@media screen and (max-width: 599px) { main section#topDetaileSct .diagnosisBox .menuB li { width: 100%; } }
main section#topDetaileSct .diagnosisBox .menuB li button:hover { opacity: .6; }
main section#topDetaileSct .diagnosisBox .menuB li a, main section#topDetaileSct .diagnosisBox .menuB li button { position: relative; display: block; width: 100%; cursor: pointer; background: #fff; padding: .5em 1.3em; font-size: 160%; font-weight: 700; border: 2px dotted #113516; border-radius: 1em; margin-bottom: .6em; }
main section#topDetaileSct .diagnosisBox .menuB li a::before, main section#topDetaileSct .diagnosisBox .menuB li button::before { content: ""; position: absolute; z-index: 5; top: 50%; right: 1.7em; transform: translateY(-50%) rotate(45deg); width: .3em; height: .3em; border-top: 2px solid #fff; border-right: 2px solid #fff; }
main section#topDetaileSct .diagnosisBox .menuB li a::after, main section#topDetaileSct .diagnosisBox .menuB li button::after { content: ""; position: absolute; top: 50%; right: 1.4em; transform: translateY(-50%); background: #113516; border-radius: 50%; width: .8em; height: .8em; }
main section#topDetaileSct .diagnosisBox .menuB li:nth-child(1) a p::before, main section#topDetaileSct .diagnosisBox .menuB li:nth-child(1) button p::before { content: ""; position: absolute; top: .1em; right: 2.8em; width: 2.6em; height: 2.6em; background: url("../img/icn_menu1.svg") no-repeat center center/contain; }
main section#topDetaileSct .diagnosisBox .menuB li:nth-child(2) a p::before, main section#topDetaileSct .diagnosisBox .menuB li:nth-child(2) button p::before { content: ""; position: absolute; top: .1em; right: 2.8em; width: 2.6em; height: 2.6em; background: url("../img/icn_menu2.svg") no-repeat center center/contain; }
main section#topDetaileSct .diagnosisBox .menuB li:nth-child(3) a p::before, main section#topDetaileSct .diagnosisBox .menuB li:nth-child(3) button p::before { content: ""; position: absolute; top: .1em; right: 2.2em; width: 6.2em; height: 2.8em; background: url("../img/icn_menu3.svg") no-repeat center center/contain; }
main section#topDetaileSct .diagnosisBox .menuB li:nth-child(4) a p::before, main section#topDetaileSct .diagnosisBox .menuB li:nth-child(4) button p::before { content: ""; position: absolute; top: .3em; right: 2.8em; width: 2.6em; height: 2.3em; background: url("../img/icn_menu4.svg") no-repeat center center/contain; }
main section#topDetaileSct .diagnosisBox .menuB li:nth-child(5) a p::before, main section#topDetaileSct .diagnosisBox .menuB li:nth-child(5) button p::before { content: ""; position: absolute; top: .5em; right: 2.8em; width: 2.1em; height: 2.2em; background: url("../img/icn_menu5.svg") no-repeat center center/contain; }
main section#topDetaileSct .diagnosisBox .menuB li:nth-child(6) a p::before, main section#topDetaileSct .diagnosisBox .menuB li:nth-child(6) button p::before { content: ""; position: absolute; top: .2em; right: 3em; width: 2em; height: 2.5em; background: url("../img/icn_menu6.svg") no-repeat center center/contain; }
main section#topDetaileSct .diagnosisBox .poBox { border: 2px dotted #113516; box-shadow: 2px 2px 10px 2px rgba(0, 0, 0, 0.3); color: #113516; text-align: center; }
main section#topDetaileSct .diagnosisBox .poBox .poTtl { display: block; font-size: 180%; font-weight: 700; margin-bottom: .2em; }
main section#topDetaileSct .diagnosisBox .poBox .poTxt { display: block; font-size: 120; line-height: 1.4; }
main section#topDetaileSct .sliderBox ul.slider li { position: relative; text-align: center; padding: 0 0 .5em; }
@media screen and (max-width: 599px) { main section#topDetaileSct .sliderBox ul.slider li { padding: 0 .5em .5em; } }
main section#topDetaileSct .sliderBox ul.slider li.slick-current img { transform: scale(1); }
main section#topDetaileSct .sliderBox ul.slider li img { position: relative; display: block; overflow: hidden; margin: 0 auto 1.8em; border-radius: 1em; box-shadow: 2px 2px 2px 1px rgba(0, 0, 0, 0.3); width: 100%; height: auto; transform: scale(0.76); transition: transform .4s ease-out .2s; }
main section#topDetaileSct .sliderBox ul.slider li .cap { position: relative; display: inline-block; white-space: nowrap; font-weight: 700; letter-spacing: 0; line-height: 1.2; background: #ceedc6; padding: .3em .6em .3em 1.2em; border-radius: 1.5em; box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.3); }
main section#topDetaileSct .sliderBox ul.slider li .cap::before { content: ""; position: absolute; z-index: 0; top: -.4em; left: 50%; transform: translateX(-50%) rotate(45deg); width: .8em; height: .8em; background: #ceedc6; }
main section#topDetaileSct .sliderBox ul.slider li .cap.of { left: 50%; transform: translateX(-50%); }
main section#topDetaileSct .sliderBox ul.slider li .cap span { position: relative; z-index: 5; }
main section#topDetaileSct .sliderBox ul.slider li .cap.non { opacity: 0; }
@media screen and (max-width: 599px) { main section#topDetaileSct .sliderBox ul.slider li .cap.sp { left: inherit; transform: none; } }
main section#topDetaileSct .sliderBox ul.slider .prev { position: absolute; z-index: 500; left: 8.65%; bottom: 55%; width: 2em; height: 2em; }
main section#topDetaileSct .sliderBox ul.slider .prev img { width: 100%; height: auto; }
main section#topDetaileSct .sliderBox ul.slider .next { position: absolute; z-index: 500; right: 8%; bottom: 55%; width: 2em; height: 2em; }
main section#topDetaileSct .sliderBox ul.slider .next img { width: 100%; height: auto; }
main section#dtl01Sct { z-index: 5; padding: 12em 5% 12em; background: url("../img/dtl_bg1.webp") no-repeat center bottom/100%; }
@media screen and (max-width: 599px) { main section#dtl01Sct { background-size: 190%; } }
main section#dtl01Sct h2 { position: relative; display: block; width: 100%; background: #fff; padding: .5em 1.3em; font-size: 160%; font-weight: 700; border: 2px dotted #113516; border-radius: 1em; margin-bottom: 2em; }
main section#dtl01Sct h2::before { content: ""; position: absolute; top: .1em; right: 1.8em; width: 2.5em; height: 2.5em; background: url("../img/icn_menu1.svg") no-repeat center center/contain; }
main section#dtl02Sct { z-index: 11; padding: 10em 5% 2em; }
main section#dtl02Sct h2 { position: relative; display: block; width: 100%; background: #fff; padding: .5em 1.3em; font-size: 160%; font-weight: 700; border: 2px dotted #113516; border-radius: 1em; margin-bottom: 2em; }
main section#dtl02Sct h2::before { content: ""; position: absolute; top: .1em; right: 1.8em; width: 2.4em; height: 2.4em; background: url("../img/icn_menu2.svg") no-repeat center center/contain; }
main section#dtl03Sct { z-index: 9; padding: 12em 5% 12em; background: url("../img/dtl_bg2.webp") no-repeat center top/100%; }
@media screen and (max-width: 599px) { main section#dtl03Sct { background-size: 218%; } }
main section#dtl03Sct h2 { position: relative; display: block; width: 100%; background: #fff; padding: .5em 1.3em; font-size: 160%; font-weight: 700; border: 2px dotted #113516; border-radius: 1em; margin-bottom: 2em; }
main section#dtl03Sct h2::before { content: ""; position: absolute; top: .1em; right: 1.2em; width: 6.2em; height: 2.6em; background: url("../img/icn_menu3.svg") no-repeat center center/contain; }
main section#dtl04Sct { z-index: 8; top: -9em; margin-bottom: -9em; padding: 12em 5% 12em; background: url("../img/dtl_bg3.webp") no-repeat center bottom/100%; }
@media screen and (max-width: 599px) { main section#dtl04Sct { top: -10em; margin-bottom: -10em; background-size: 150%; } }
main section#dtl04Sct h2 { position: relative; display: block; width: 100%; background: #fff; padding: .5em 1.3em; font-size: 160%; font-weight: 700; border: 2px dotted #113516; border-radius: 1em; margin-bottom: 2em; }
main section#dtl04Sct h2::before { content: ""; position: absolute; top: .3em; right: 1.8em; width: 2.6em; height: 2.3em; background: url("../img/icn_menu4.svg") no-repeat center center/contain; }
main section#dtl05Sct { padding: 10em 5% 2em; }
main section#dtl05Sct h2 { position: relative; display: block; width: 100%; background: #fff; padding: .5em 1.3em; font-size: 160%; font-weight: 700; border: 2px dotted #113516; border-radius: 1em; margin-bottom: 2em; }
main section#dtl05Sct h2::before { content: ""; position: absolute; top: .25em; right: 1.8em; width: 2.1em; height: 2.2em; background: url("../img/icn_menu5.svg") no-repeat center center/contain; }
main section#dtl06Sct { padding: 12em 5% 2em; background: url("../img/dtl_bg4.webp") no-repeat center top/100%; }
@media screen and (max-width: 599px) { main section#dtl06Sct { background-size: 150%; } }
main section#dtl06Sct h2 { position: relative; display: block; width: 100%; background: #fff; padding: .5em 1.3em; font-size: 160%; font-weight: 700; border: 2px dotted #113516; border-radius: 1em; margin-bottom: 2em; }
main section#dtl06Sct h2::before { content: ""; position: absolute; top: .1em; right: 2em; width: 1.9em; height: 2.3em; background: url("../img/icn_menu6.svg") no-repeat center center/contain; }
main section#dtl01Sct h3, main section#dtl02Sct h3, main section#dtl03Sct h3, main section#dtl04Sct h3, main section#dtl05Sct h3 { display: block; font-size: 180%; font-weight: 700; letter-spacing: .1em; padding: 0 2%; margin-bottom: .8em; }
main section#dtl01Sct ul, main section#dtl02Sct ul, main section#dtl03Sct ul, main section#dtl04Sct ul, main section#dtl05Sct ul { padding: 0 2% 0 calc(2% + 2em); margin-bottom: 1em; }
main section#dtl01Sct ul li, main section#dtl02Sct ul li, main section#dtl03Sct ul li, main section#dtl04Sct ul li, main section#dtl05Sct ul li { list-style: disc; line-height: 1.5; padding: .3em 0; }
main section#dtl01Sct .box, main section#dtl02Sct .box, main section#dtl03Sct .box, main section#dtl04Sct .box, main section#dtl05Sct .box { position: relative; padding-bottom: 3em; margin-bottom: 2em; border-bottom: 2px dashed #113516; }
main section#dtl01Sct .box:last-child, main section#dtl02Sct .box:last-child, main section#dtl03Sct .box:last-child, main section#dtl04Sct .box:last-child, main section#dtl05Sct .box:last-child { border-bottom: none; }
main section#dtl01Sct .box h4, main section#dtl02Sct .box h4, main section#dtl03Sct .box h4, main section#dtl04Sct .box h4, main section#dtl05Sct .box h4 { display: block; font-size: 160%; font-weight: 700; letter-spacing: .05em; line-height: 1.4; padding: 0 2%; margin: 3em 0 1.2em .5em; border-left: 5px solid #113516; }
main section#dtl01Sct .box .txt1, main section#dtl02Sct .box .txt1, main section#dtl03Sct .box .txt1, main section#dtl04Sct .box .txt1, main section#dtl05Sct .box .txt1 { display: block; padding: 0 2%; margin-bottom: 1em; }
main section#dtl01Sct .box h5, main section#dtl02Sct .box h5, main section#dtl03Sct .box h5, main section#dtl04Sct .box h5, main section#dtl05Sct .box h5 { display: inline-block; font-size: 140%; font-weight: 700; letter-spacing: .05em; padding: 0 2%; margin: 1em 0 .5em; border-bottom: 1px dotted #113516; }
main section#dtl01Sct .box .txt2, main section#dtl02Sct .box .txt2, main section#dtl03Sct .box .txt2, main section#dtl04Sct .box .txt2, main section#dtl05Sct .box .txt2 { display: block; padding: 0 2%; margin-bottom: 1em; }
main section#dtl01Sct .box .atn, main section#dtl02Sct .box .atn, main section#dtl03Sct .box .atn, main section#dtl04Sct .box .atn, main section#dtl05Sct .box .atn { display: block; padding: 0 2%; margin-bottom: 1em; }
main section#dtl06Sct .sBox1 { position: relative; display: flex; justify-content: space-between; flex-direction: row-reverse; align-items: center; }
@media screen and (max-width: 599px) { main section#dtl06Sct .sBox1 { display: block; } }
main section#dtl06Sct .sBox1 .picB { width: 50%; }
@media screen and (max-width: 599px) { main section#dtl06Sct .sBox1 .picB { width: 100%; padding: 0 8% 1em; } }
main section#dtl06Sct .sBox1 .picB img { width: 100%; height: auto; }
main section#dtl06Sct .sBox1 .txtB { width: 48%; }
@media screen and (max-width: 599px) { main section#dtl06Sct .sBox1 .txtB { width: 100%; padding: 0 5% 3em; } }
main section#dtl06Sct .sBox1 .txtB .name { font-size: 140%; letter-spacing: .05em; margin-bottom: .3em; }
main section#dtl06Sct .sBox1 .txtB .come { margin-bottom: 1em; }
main section#dtl06Sct .sBox2 { position: relative; display: flex; justify-content: space-between; align-items: center; }
@media screen and (max-width: 599px) { main section#dtl06Sct .sBox2 { display: block; } }
main section#dtl06Sct .sBox2 .picB { width: 58%; }
@media screen and (max-width: 599px) { main section#dtl06Sct .sBox2 .picB { width: 100%; padding: 0 5% 1em; } }
main section#dtl06Sct .sBox2 .picB img { width: 100%; height: auto; }
main section#dtl06Sct .sBox2 .txtB { width: 42%; padding-left: 2%; }
@media screen and (max-width: 599px) { main section#dtl06Sct .sBox2 .txtB { width: 100%; padding: 0 5%; } }
main section#dtl06Sct .sBox2 .txtB .name { font-size: 140%; letter-spacing: .05em; margin-bottom: .3em; }
main section#dtl06Sct .sBox2 .txtB .come { margin-bottom: 1em; }

#footer { position: relative; background: url("../img/top_bg4.webp") no-repeat center bottom/100%; padding: 5em 7% 6.8em; }
@media screen and (max-width: 599px) { #footer { background-size: 225%; } }
#footer.detail { background: url("../img/top_bg4.webp") no-repeat center bottom/100%, url("../img/dtl_bg4.webp") no-repeat center bottom/100%; }
@media screen and (max-width: 599px) { #footer.detail { background-size: 225%; } }
#footer .snsB { position: relative; padding: 0 12%; margin-bottom: 10em; }
@media screen and (max-width: 599px) { #footer .snsB { padding: 0 7%; } }
#footer .snsB .ttl { display: block; padding-left: 4em; margin-bottom: .6em; }
@media screen and (max-width: 599px) { #footer .snsB .ttl { padding-left: 2em; } }
#footer .snsB .ttl span { display: block; font-size: 280%; font-weight: 700; line-height: 1; }
#footer .snsB .ttl a { display: inline-block; font-size: 200%; font-weight: 700; line-height: 1.1; letter-spacing: 0; }
#footer .ftInfoB { position: relative; display: flex; justify-content: space-between; margin-bottom: 8em; }
@media screen and (max-width: 599px) { #footer .ftInfoB { display: block; margin-bottom: 5em; } }
#footer .ftInfoB .txtB { width: 50%; color: #fff; padding-top: 1em; }
@media screen and (max-width: 599px) { #footer .ftInfoB .txtB { width: 100%; padding-top: 0; margin-bottom: 3em; } }
#footer .ftInfoB .txtB .logo { display: block; width: 38vw; margin-bottom: .5em; }
@media screen and (max-width: 599px) { #footer .ftInfoB .txtB .logo { width: 76vw; } }
#footer .ftInfoB .txtB .logo img { width: 100%; height: auto; }
#footer .ftInfoB .txtB .add { display: block; padding-left: .4em; font-size: 115%; font-weight: 700; line-height: 1.3; margin-bottom: 1em; }
@media screen and (max-width: 599px) { #footer .ftInfoB .txtB .add { margin-bottom: .2em; } }
#footer .ftInfoB .txtB .tel { display: block; text-align: center; font-size: 300%; font-weight: 700; margin-bottom: .8em; }
@media screen and (max-width: 599px) { #footer .ftInfoB .txtB .tel { margin-bottom: .2em; } }
#footer .ftInfoB .txtB .tel a { color: #fff; }
#footer .ftInfoB .txtB .timeBox { color: #fff; }
#footer .ftInfoB .txtB .timeBox .ttl { font-size: 200%; font-weight: 700; margin-bottom: .2em; }
#footer .ftInfoB .txtB .timeBox table { position: relative; width: 100%; margin-bottom: .8em; }
#footer .ftInfoB .txtB .timeBox table tr { border-bottom: 1px solid #fff; }
#footer .ftInfoB .txtB .timeBox table tr td { vertical-align: middle; text-align: center; font-size: 130%; line-height: 1; padding: .4em 0; }
#footer .ftInfoB .txtB .timeBox table tr td.week { font-weight: 700; padding: .4em .2em; }
#footer .ftInfoB .txtB .timeBox table tr td.week.end { padding: .4em 0 .4em .2em; }
#footer .ftInfoB .txtB .timeBox table tr td.week.t2 { letter-spacing: -.3em; padding: .4em .4em .4em 0; }
#footer .ftInfoB .txtB .timeBox table tr td.time { font-weight: 700; }
#footer .ftInfoB .txtB .timeBox table tr td.end2 { padding: .4em 0 .4em .2em; }
#footer .ftInfoB .txtB .timeBox table tr td .mark { display: block; margin: 0 auto; width: 1em; height: auto; }
#footer .ftInfoB .txtB .timeBox .atn { padding-left: .8em; }
#footer .ftInfoB .txtB .timeBox .atn span { display: block; font-size: 95%; letter-spacing: .15em; line-height: 1.3; margin-bottom: .4em; }
#footer .ftInfoB .mapB { width: 43%; }
@media screen and (max-width: 599px) { #footer .ftInfoB .mapB { width: 90%; margin: 0 auto; } }
#footer .ftInfoB .mapB iframe { width: 100%; height: 36vw; }
@media screen and (max-width: 599px) { #footer .ftInfoB .mapB iframe { height: 40vw; } }
#footer .cpr { display: block; margin: 0 auto; width: 23%; }
@media screen and (max-width: 599px) { #footer .cpr { width: 50%; } }
#footer .cpr img { width: 100%; height: auto; }
