@charset "UTF-8";

/* sass */
a { color: #171D1E; }

body, input, button, textarea, select { font-family: 'Noto Sans JP', sans-serif; }

.font-jp1 { font-family: "Zen Maru Gothic", serif; }

.font-en1 { font-family: "Barlow", sans-serif; }

body { position: relative; color: #171D1E; background-color: #FFEDEC; }

.txt-skip { font-size: 0rem; line-height: 0; }

.wrap-all { display: flex; flex-direction: column; width: 100%; min-height: 100svh; }

.main { position: relative; padding: 0 0 40px; }

.header { width: 100%; z-index: 5; overflow: visible; transition: .3s; }

.header .header-inner { padding: 16px 16px 20px; position: relative; z-index: 4; }

.header .header-logo { font-size: 0rem; line-height: 0; display: inline-block; }

.header .header-logo .inner { display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; }

.header .header-logo img { height: 14px; width: auto; }

.header .header-logo .lang-jp { font-size: 1.2rem; line-height: 1.6; font-family: "Zen Maru Gothic", serif; background-color: #F5FAFB; color: #920021; padding: 5px 10px; border-radius: 30px; margin-top: 8px; font-weight: 500; white-space: nowrap; }

.header .btn-sp-menu { display: flex; height: 48px; width: 48px; margin-left: auto; position: relative; align-items: center; justify-content: center; transition: .4s; line-height: 1; position: absolute; right: 16px; top: 12px; transition: .3s; }

.header .btn-sp-menu .line { height: 4px; width: 18px; transition: 0.3s; position: relative; }

.header .btn-sp-menu .line:before, .header .btn-sp-menu .line:after { content: ""; display: block; height: 2px; position: absolute; width: 100%; background-color: #920021; transition: inherit; }

.header .btn-sp-menu .line:before { top: -2px; }

.header .btn-sp-menu .line:after { top: 2px; }

.header .wrap-nav { position: absolute; top: 0; left: 0; width: 100%; opacity: 0; visibility: hidden; transition: opacity .3s; z-index: -1; margin-top: 0; height: 0; overflow: hidden; border-radius: 24px; background-color: #FFDAD9; padding: 146px 33px 48px; }

.header .nav-items > li { font-size: 2.4rem; line-height: 1.6; margin-top: 32px; font-family: "Barlow", serif; font-style: normal; font-weight: 500; display: flex; flex-direction: column; text-align: center; }

.header .nav-items > li:first-child { margin-top: 0; }

.header .nav-items > li > a, .header .nav-items > li > button { font-size: 2.4rem; line-height: 1.6; display: inline-block; color: #920021; font-weight: 500; }

.header .nav-items > li .lang-jp { display: block; font-size: 1.2rem; font-family: "Zen Maru Gothic", serif; color: #3F484A; }

.header .nav-items > li .link-icon { display: none; }

.header .wrap-btn { position: relative; }

.header .wrap-btn .btn-type1, .header .wrap-btn .btn-img1 { margin-top: 126px; display: block; }

.header .wrap-btn .img { text-align: center; }

.header .wrap-btn .img img { width: 100%; height: auto; max-width: 280px; }

.menu-open { overflow: hidden; position: relative; }

.menu-open .header { position: fixed; top: 0; bottom: 0; overflow: auto; }

.menu-open .header:after { content: ""; display: block; position: fixed; top: 0; bottom: 0; width: 100%; background-color: #FFEDEC; }

.menu-open .header .btn-sp-menu { position: fixed; z-index: 2; }

.menu-open .header .btn-sp-menu .line { background-color: transparent; }

.menu-open .header .btn-sp-menu .line::before { top: 0; -webkit-transform: rotate(45deg); transform: rotate(45deg); }

.menu-open .header .btn-sp-menu .line::after { top: 0; -webkit-transform: rotate(-45deg); transform: rotate(-45deg); }

.menu-open .header .btn-sp-menu .text { font-size: 0rem; }

.menu-open .header .btn-sp-menu .text::before { content: attr(data-text) ""; font-family: 'Inter', sans-serif; text-align: center; font-size: 1.1rem; font-weight: 600; display: block; color: #FFEDEC; }

.menu-open .header .wrap-nav { position: relative; opacity: 1; visibility: visible; z-index: 1; margin-top: 21px; overflow: auto; height: auto; }

.menu-open .header .wrap-nav:before { content: ""; display: block; width: 64px; height: 27px; background: transparent url(shonan_menu_ill01.webp) no-repeat 0 0; background-size: cover; position: absolute; right: 58px; top: 32px; -webkit-transform: rotate(-3deg); transform: rotate(-3deg); }

.menu-open .header .wrap-nav:after { content: ""; display: block; width: 64px; height: 76px; background: transparent url(shonan_menu_ill06.webp) no-repeat 0 0; background-size: cover; position: absolute; left: 38px; bottom: 148px; }

.menu-open .header .header-nav { position: relative; }

.menu-open .header .header-nav:before, .menu-open .header .header-nav:after { content: ""; display: block; background: transparent no-repeat 0 0; background-size: cover; position: absolute; }

.menu-open .header .header-nav:before { width: 42px; height: 84px; background-image: url(shonan_menu_ill02.webp); left: -19px; top: -80px; }

.menu-open .header .header-nav:after { width: 60px; height: 54px; background-image: url(shonan_menu_ill04.webp); left: 7px; top: 30px; }

.menu-open .header .nav-items { position: relative; }

.menu-open .header .nav-items:before, .menu-open .header .nav-items:after { content: ""; display: block; background: transparent no-repeat 0 0; background-size: cover; position: absolute; }

.menu-open .header .nav-items:before { width: 64px; height: 86px; background-image: url(shonan_menu_ill03.webp); right: 5px; top: -52px; }

.menu-open .header .nav-items:after { width: 26px; height: 81px; background-image: url(shonan_menu_ill05.webp); right: 10px; bottom: 34px; }

.menu-open .header .wrap-btn:after { content: ""; display: block; width: 95px; height: 68px; background: transparent url(shonan_menu_ill07.webp) no-repeat 0 0; background-size: cover; position: absolute; top: -100px; right: 0; }

.menu-open .footer { visibility: hidden; opacity: 0; }

.menu-open.top-page .header .wrap-nav { margin-top: 58px; }

.footer { width: 100%; position: relative; background-color: #FFDAD9; padding: 48px 24px 32px; margin-top: auto; transition: opacity .3s; opacity: 1; }

.footer .footer-logo { font-size: 0rem; line-height: 0; text-align: center; }

.footer .footer-logo .inner { display: inline-block; }

.footer .footer-logo img { height: 23px; width: auto; display: block; }

.footer .footer-logo .lang-jp { font-size: 1.2rem; line-height: 1.6; font-family: "Zen Maru Gothic", serif; background-color: #F5FAFB; color: #920021; padding: 5px 12px; border-radius: 30px; margin-top: 16px; letter-spacing: -0.05em; display: inline-block; font-weight: 500; }

.footer .txt-logo { text-align: center; margin-top: 12px; font-size: 1.2rem; line-height: 1.5; }

.footer .txt-logo + .copyright { margin-top: 16px; }

.footer .copyright { text-align: center; margin-top: 24px; }

.footer .copyright small { font-size: 1.0rem; line-height: 1.4; }

.top-page .header { min-height: 72px; }

.top-page .header .header-inner { padding: 21.5px 16px; }

.top-page .header .header-logo { padding: 24px 24px 24px 18px; background-color: #FFEDEC; position: absolute; left: 0; top: 0; z-index: 4; border-radius: 0 0 40px 0; }

.top-page .header .header-logo .inner { flex-direction: column; justify-content: flex-start; align-items: flex-start; }

.top-page .header .header-logo .lang-jp { margin: 12px 0 0; }

.txt-st { font-size: 1.4rem; line-height: 1.8; }

.txt-st + .txt-st { margin-top: 16px; }

.txt-st + .txt-st.ft-l { font-size: 1.8rem; }

.txt-st + .txt-st.ft-s { font-size: 1.2rem; }

.link-icon { font-size: 0rem; line-height: 0; }

.link-txt { color: #015F2C; font-weight: 500; position: relative; }

.link-txt:before { content: ""; position: absolute; bottom: -1px; left: 0; width: 100%; height: 1px; background-color: #FFEDEC; -webkit-transform: scaleX(1); transform: scaleX(1); }

.link-txt.blank:before, .link-txt.pdf:before { width: calc(100% - 22px); }

.link-txt.blank .link-icon, .link-txt.pdf .link-icon { font-size: 0rem; line-height: 0; position: relative; padding: 0 5px; }

.link-txt.blank .link-icon:after, .link-txt.pdf .link-icon:after { content: ""; display: inline-block; width: 12px; height: 12px; background: transparent url(/common/image/icon-blank.svg) no-repeat center center; background-size: contain; }

.link-txt.pdf .link-icon:after { background-image: url(/common/image/icon-pdf.svg); }

.link-txt.col-black { color: #BE022F; }

.link-txt.col-black:before { background-color: #BE022F; }

.bold { font-weight: 800; }

.hdg-lv1 { letter-spacing: 0; font-weight: 500; font-size: 3.2rem; line-height: 1.5; margin-bottom: 50px; }

.hdg-lv1.lang-ver1 { font-weight: 500; }

.hdg-lv1 .lang-ver1 { display: block; margin-top: 8px; font-size: 1.3rem; color: #FFEDEC; font-weight: 600; }

.hdg-lv2 { letter-spacing: 0; font-weight: 500; font-size: 1.8rem; line-height: 1.5; margin-top: 50px; margin-bottom: 40px; }

.hdg-lv3 { letter-spacing: 0; font-weight: 500; font-size: 1.6rem; line-height: 1.5; margin-top: 40px; margin-bottom: 24px; }

.wrap-btn .btn-type1 { display: block; background-color: #BE022F; color: #FFFFFF; text-align: center; font-family: "Zen Maru Gothic", serif; -webkit-font-feature-settings: "palt" 1; font-feature-settings: "palt" 1; letter-spacing: 0; text-align: center; border-radius: 30px; padding: 12px 16px; font-size: 1.6rem; line-height: 1.5; font-weight: 700; }

.top-page .main { padding: 0 0 40px; }

.top-page .wrap-speech-bubble { display: none; }

.top-page .bg-dark { display: none; }

.top-page .btn-mode-change { display: inline-block; font-size: 0rem; background: transparent url(shonan_index_btn_search01.webp) no-repeat center center; background-size: contain; position: absolute; }

.top-page .btn-mode-change img { position: absolute; left: 0; top: 0; }

.top-page.search-mode .btn-mode-change { background-image: url(shonan_index_btn_search02.webp); }

.top-page.search-mode .wrap-map .icon.search-y { cursor: pointer; pointer-events: auto; }

.top-page.search-mode .wrap-map .icon.search-y.found:after { opacity: 1; }

.top-page.search-mode .wrap-map .pointer { pointer-events: none; }

.top-page.search-mode .wrap-map .pointer:after { opacity: 0; }

.top-page.search-mode .wrap-map .link .inner-txt { opacity: 0; }

.top-page.search-mode .wrap-counter { opacity: 1; z-index: 1; }

.wrap-map { overflow: scroll; border-radius: 20px; position: relative; height: 674px; width: calc(100vw - 30px); margin: auto; }

.wrap-map .wrap-map-inner { width: 600px; height: 674px; margin: auto; position: relative; overflow: hidden; }

.wrap-map .all-bg img { border-radius: 20px; }

.wrap-map img { width: 100%; height: 100%; vertical-align: middle; }

.wrap-map .icon { display: inline-block; position: absolute; }

.wrap-map .icon img { position: absolute; left: 0; top: 0; }

.wrap-map .icon.search-y { cursor: default; pointer-events: none; }

.wrap-map .icon.search-y:after { content: ""; display: flex; flex-direction: column; margin: auto; width: 9vw; height: 9vw; background: url(shonan_index_correct.webp) no-repeat 0 0; background-size: contain; position: relative; opacity: 0; transition: .3s; pointer-events: none; }

.wrap-map .link { display: block; text-align: center; }

.wrap-map .link img { transition: .2s ease-in-out; }

.wrap-map .link .inner-txt { display: inline-block; background-color: #BE012F; color: #FFFFFF; font-family: "Zen Maru Gothic", serif; padding: 12px 24px; line-height: 1.5; font-size: 1.6rem; font-weight: 700; border-radius: 40px; position: relative; margin: 8vw auto; transition: .2s ease-in-out; transition: .3s; white-space: nowrap; }

.wrap-map .link:hover img { -webkit-transform: scale(1.05); transform: scale(1.05); }

.wrap-map .link:hover .inner-txt { -webkit-transform: scale(1.05); transform: scale(1.05); }

@-webkit-keyframes link { from { opacity: 0;
    -webkit-transform: translateY(50px);
    transform: translateY(50px); }
  to { opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0); } }

@keyframes link { from { opacity: 0;
    -webkit-transform: translateY(50px);
    transform: translateY(50px); }
  to { opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0); } }

.wrap-map .pointer { display: block; }

.wrap-map .pointer:after { content: ""; display: block; width: 6vw; height: 6vw; position: absolute; background: transparent url(shonan_icon_location.webp) no-repeat; background-size: contain; -webkit-animation: pointer 1s alternate infinite linear; animation: pointer 1s alternate infinite linear; transition: .3s; }

.wrap-map .pointer.building02:after { width: 7vw; height: 7vw; background-image: url(shonan_icon_location_outline.webp); }

@-webkit-keyframes pointer { from { -webkit-transform: translateY(0); transform: translateY(0); }
  to { -webkit-transform: translateY(30%); transform: translateY(30%); } }

@keyframes pointer { from { -webkit-transform: translateY(0); transform: translateY(0); }
  to { -webkit-transform: translateY(30%); transform: translateY(30%); } }

@-webkit-keyframes pointer-rotate { from { -webkit-transform: translateY(0); transform: translateY(0); }
  to { -webkit-transform: translateY(30%) rotateY(180deg); transform: translateY(30%) rotateY(180deg); } }

@keyframes pointer-rotate { from { -webkit-transform: translateY(0); transform: translateY(0); }
  to { -webkit-transform: translateY(30%) rotateY(180deg); transform: translateY(30%) rotateY(180deg); } }

.wrap-map .ocan { position: absolute; top: 26%; left: -35px; width: 64vw; height: 64vw; }

.wrap-map .ocan img { -webkit-animation: ocan 8s alternate infinite; animation: ocan 8s alternate infinite; -webkit-transform-origin: 0 50%; transform-origin: 0 50%; }

@-webkit-keyframes ocan { 0% { -webkit-transform: scale(1); transform: scale(1); }
  25% { -webkit-transform: scale(0.94); transform: scale(0.94); }
  50% { -webkit-transform: scale(1); transform: scale(1); }
  75% { -webkit-transform: scale(0.95); transform: scale(0.95); }
  100% { -webkit-transform: scale(1); transform: scale(1); } }

@keyframes ocan { 0% { -webkit-transform: scale(1); transform: scale(1); }
  25% { -webkit-transform: scale(0.94); transform: scale(0.94); }
  50% { -webkit-transform: scale(1); transform: scale(1); }
  75% { -webkit-transform: scale(0.95); transform: scale(0.95); }
  100% { -webkit-transform: scale(1); transform: scale(1); } }

.wrap-map .enoshima { top: 41%; left: 12%; width: 32.7vw; height: 32.7vw; }

.wrap-map .cloud01 { top: 43%; left: 14.6%; width: 6vw; height: 6vw; -webkit-animation: cloud01 4s alternate infinite linear; animation: cloud01 4s alternate infinite linear; }

@-webkit-keyframes cloud01 { from { top: 43%;
    -webkit-transform: scale(0.9);
    transform: scale(0.9); }
  to { top: 44%;
    -webkit-transform: scale(1.2);
    transform: scale(1.2); } }

@keyframes cloud01 { from { top: 43%;
    -webkit-transform: scale(0.9);
    transform: scale(0.9); }
  to { top: 44%;
    -webkit-transform: scale(1.2);
    transform: scale(1.2); } }

.wrap-map .cloud02 { top: 40%; left: 17.6%; width: 5vw; height: 5vw; -webkit-animation: cloud02 6s alternate infinite linear; animation: cloud02 6s alternate infinite linear; }

@-webkit-keyframes cloud02 { from { top: 40%;
    left: 20.6%;
    -webkit-transform: scale(0.9);
    transform: scale(0.9); }
  to { top: 42%;
    left: 21.6%;
    -webkit-transform: scale(1.1);
    transform: scale(1.1); } }

@keyframes cloud02 { from { top: 40%;
    left: 20.6%;
    -webkit-transform: scale(0.9);
    transform: scale(0.9); }
  to { top: 42%;
    left: 21.6%;
    -webkit-transform: scale(1.1);
    transform: scale(1.1); } }

.wrap-map .cloud03 { top: 44%; left: 33.6%; width: 7vw; height: 7vw; -webkit-animation: cloud03 8s alternate infinite linear; animation: cloud03 8s alternate infinite linear; }

@-webkit-keyframes cloud03 { from { -webkit-transform: scale(0.8); transform: scale(0.8); }
  to { -webkit-transform: scale(1.1); transform: scale(1.1); } }

@keyframes cloud03 { from { -webkit-transform: scale(0.8); transform: scale(0.8); }
  to { -webkit-transform: scale(1.1); transform: scale(1.1); } }

.wrap-map .bird01 { top: 49.5%; left: 37%; width: 3vw; height: 3vw; -webkit-animation: bird01 2s alternate infinite ease-in; animation: bird01 2s alternate infinite ease-in; }

@-webkit-keyframes bird01 { 0% { -webkit-transform: translate(2%, 3%) rotate(-10deg); transform: translate(2%, 3%) rotate(-10deg); }
  100% { -webkit-transform: translate(-15%, -10%) rotate(10deg); transform: translate(-15%, -10%) rotate(10deg); } }

@keyframes bird01 { 0% { -webkit-transform: translate(2%, 3%) rotate(-10deg); transform: translate(2%, 3%) rotate(-10deg); }
  100% { -webkit-transform: translate(-15%, -10%) rotate(10deg); transform: translate(-15%, -10%) rotate(10deg); } }

.wrap-map .bird02 { top: 45.5%; left: 22%; width: 1.5vw; height: 1.5vw; -webkit-animation: bird02 3s alternate infinite ease-in-out; animation: bird02 3s alternate infinite ease-in-out; -webkit-animation-delay: 0.4s; animation-delay: 0.4s; }

@-webkit-keyframes bird02 { 0% { -webkit-transform: translate(2%, 10%) rotate(-10deg) scale(0.9); transform: translate(2%, 10%) rotate(-10deg) scale(0.9); }
  100% { -webkit-transform: translate(-15%, -20%) rotate(10deg) scale(1.2); transform: translate(-15%, -20%) rotate(10deg) scale(1.2); } }

@keyframes bird02 { 0% { -webkit-transform: translate(2%, 10%) rotate(-10deg) scale(0.9); transform: translate(2%, 10%) rotate(-10deg) scale(0.9); }
  100% { -webkit-transform: translate(-15%, -20%) rotate(10deg) scale(1.2); transform: translate(-15%, -20%) rotate(10deg) scale(1.2); } }

.wrap-map .bird03 { top: 49.5%; left: 16%; width: 1.5vw; height: 1.5vw; -webkit-animation: bird03 3s alternate infinite ease-in-out; animation: bird03 3s alternate infinite ease-in-out; -webkit-animation-delay: 0.2s; animation-delay: 0.2s; }

@-webkit-keyframes bird03 { 0% { -webkit-transform: translate(10%, 10%) rotate(-20deg) scale(0.9); transform: translate(10%, 10%) rotate(-20deg) scale(0.9); }
  100% { -webkit-transform: translate(-10%, -10%) rotate(20deg) scale(1); transform: translate(-10%, -10%) rotate(20deg) scale(1); } }

@keyframes bird03 { 0% { -webkit-transform: translate(10%, 10%) rotate(-20deg) scale(0.9); transform: translate(10%, 10%) rotate(-20deg) scale(0.9); }
  100% { -webkit-transform: translate(-10%, -10%) rotate(20deg) scale(1); transform: translate(-10%, -10%) rotate(20deg) scale(1); } }

.wrap-map .balloon { top: 3.4%; left: 60.6%; -webkit-animation: balloon 4s alternate infinite linear; animation: balloon 4s alternate infinite linear; width: 12vw; height: 12vw; }

.wrap-map .balloon.search-y:after { margin-top: 5vw; }

@-webkit-keyframes balloon { from { top: 7.4%; }
  to { top: 1.4%; } }

@keyframes balloon { from { top: 7.4%; }
  to { top: 1.4%; } }

.wrap-map .seagull01 { top: 7.4%; right: -15%; width: 5vw; height: 5vw; -webkit-animation: seagull01 20s infinite linear; animation: seagull01 20s infinite linear; }

@-webkit-keyframes seagull01 { 0% { top: 7.4%;
    right: -15%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  30% { top: 2%;
    right: 105%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  50% { top: 2%;
    right: 105%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  51% { top: 2%;
    right: 105%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  99% { top: 7.4%;
    right: -15%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 7.4%;
    right: -15%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); } }

@keyframes seagull01 { 0% { top: 7.4%;
    right: -15%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  30% { top: 2%;
    right: 105%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  50% { top: 2%;
    right: 105%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  51% { top: 2%;
    right: 105%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  99% { top: 7.4%;
    right: -15%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 7.4%;
    right: -15%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); } }

.wrap-map .seagull02 { top: 4%; right: -15%; width: 8vw; height: 8vw; -webkit-animation: seagull02 25s infinite linear; animation: seagull02 25s infinite linear; -webkit-animation-delay: 4s; animation-delay: 4s; }

@-webkit-keyframes seagull02 { 0% { top: 4%;
    right: -15%; }
  30% { top: 8%;
    right: 105%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  31% { top: 2%;
    right: 105%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  41% { top: 2%;
    right: 105%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 7.4%;
    right: -15%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); } }

@keyframes seagull02 { 0% { top: 4%;
    right: -15%; }
  30% { top: 8%;
    right: 105%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  31% { top: 2%;
    right: 105%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  41% { top: 2%;
    right: 105%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 7.4%;
    right: -15%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); } }

.wrap-map .building01 { top: 8.5%; left: 21.5%; width: 25vw; height: 25vw; -webkit-animation: link 1s forwards; animation: link 1s forwards; -webkit-animation-delay: 1s; animation-delay: 1s; opacity: 0; }

.wrap-map .building01.pointer:after { top: -3%; left: 42%; }

.wrap-map .building02 { top: 17.5%; left: 42%; width: 33vw; height: 33vw; -webkit-animation: link 1s forwards; animation: link 1s forwards; -webkit-animation-delay: 1s; animation-delay: 1s; opacity: 0; }

.wrap-map .building02.pointer:after { top: 14%; left: 59%; -webkit-animation: pointer-rotate 1s alternate infinite linear; animation: pointer-rotate 1s alternate infinite linear; background-position: center center; }

.wrap-map .building02 .inner-txt { margin: 15vw 0 0 12vw; }

.wrap-map .building03 { top: 37%; left: 56.8%; width: 21vw; height: 21vw; -webkit-animation: link 1s forwards; animation: link 1s forwards; -webkit-animation-delay: 1s; animation-delay: 1s; opacity: 0; }

.wrap-map .building03.pointer:after { top: 5%; left: 21%; }

.wrap-map .building03 .inner-txt { margin: 3vw 0 0 -7vw; white-space: nowrap; }

.wrap-map .building04 { top: 67.4%; left: 22.3%; width: 21vw; height: 21vw; -webkit-animation: link 1s forwards; animation: link 1s forwards; -webkit-animation-delay: 1s; animation-delay: 1s; opacity: 0; }

.wrap-map .building04.pointer:after { top: 0%; left: 55%; }

.wrap-map .building04 .inner-txt { margin: 9vw 0 0 7vw; }

.wrap-map .building04.no-link { -webkit-animation: none; animation: none; opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

.wrap-map .per1 { top: 34%; left: 35%; width: 5vw; height: 5vw; -webkit-animation: per1 14s infinite; animation: per1 14s infinite; pointer-events: none; }

@-webkit-keyframes per1 { 0% { top: 26%;
    left: 38%; }
  50% { top: 32%;
    left: 28%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  51% { top: 32%;
    left: 28%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  54% { top: 32%;
    left: 28%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  55% { top: 32%;
    left: 28%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  98% { top: 24%;
    left: 38%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 26%;
    left: 38%; } }

@keyframes per1 { 0% { top: 26%;
    left: 38%; }
  50% { top: 32%;
    left: 28%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  51% { top: 32%;
    left: 28%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  54% { top: 32%;
    left: 28%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  55% { top: 32%;
    left: 28%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  98% { top: 24%;
    left: 38%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 26%;
    left: 38%; } }

.wrap-map .per2 { top: 30%; left: 32%; width: 6vw; height: 6vw; -webkit-animation: per2 10s infinite; animation: per2 10s infinite; }

@-webkit-keyframes per2 { 0% { top: 30%;
    left: 32%; }
  50% { top: 31%;
    left: 37%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  51% { top: 31%;
    left: 37%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  54% { top: 31%;
    left: 37%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  55% { top: 31%;
    left: 37%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  98% { top: 30%;
    left: 32%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 30%;
    left: 32%; } }

@keyframes per2 { 0% { top: 30%;
    left: 32%; }
  50% { top: 31%;
    left: 37%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  51% { top: 31%;
    left: 37%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  54% { top: 31%;
    left: 37%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  55% { top: 31%;
    left: 37%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  98% { top: 30%;
    left: 32%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 30%;
    left: 32%; } }

.wrap-map .per3 { top: 36%; left: 46%; width: 9vw; height: 9vw; -webkit-animation: per3 20s infinite; animation: per3 20s infinite; pointer-events: none; }

@-webkit-keyframes per3 { 0% { top: 38%;
    left: 46%; }
  29% { top: 40%;
    left: 56%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  30% { top: 40%;
    left: 56%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  60% { top: 41%;
    left: 52%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  61% { top: 42%;
    left: 52%;
    -webkit-transform: scale(1, -1) rotate(160deg);
    transform: scale(1, -1) rotate(160deg); }
  99% { top: 38%;
    left: 38%;
    -webkit-transform: scale(1, -1) rotate(160deg);
    transform: scale(1, -1) rotate(160deg); }
  100% { top: 38%;
    left: 38%;
    -webkit-transform: scale(1, -1) rotate(160deg);
    transform: scale(1, -1) rotate(160deg); } }

@keyframes per3 { 0% { top: 38%;
    left: 46%; }
  29% { top: 40%;
    left: 56%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  30% { top: 40%;
    left: 56%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  60% { top: 41%;
    left: 52%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  61% { top: 42%;
    left: 52%;
    -webkit-transform: scale(1, -1) rotate(160deg);
    transform: scale(1, -1) rotate(160deg); }
  99% { top: 38%;
    left: 38%;
    -webkit-transform: scale(1, -1) rotate(160deg);
    transform: scale(1, -1) rotate(160deg); }
  100% { top: 38%;
    left: 38%;
    -webkit-transform: scale(1, -1) rotate(160deg);
    transform: scale(1, -1) rotate(160deg); } }

.wrap-map .per4 { top: 55%; left: 70%; width: 5vw; height: 5vw; pointer-events: none; }

.wrap-map .per5 { top: 83%; left: 22%; width: 4vw; height: 4vw; -webkit-animation: per5 14s infinite; animation: per5 14s infinite; pointer-events: none; }

@-webkit-keyframes per5 { 0% { top: 82%;
    left: 22%; }
  50% { top: 84%;
    left: 21%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  51% { top: 84%;
    left: 21%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  54% { top: 84%;
    left: 21%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  55% { top: 84%;
    left: 21%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  98% { top: 82%;
    left: 22%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 82%;
    left: 22%; } }

@keyframes per5 { 0% { top: 82%;
    left: 22%; }
  50% { top: 84%;
    left: 21%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  51% { top: 84%;
    left: 21%;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1); }
  54% { top: 84%;
    left: 21%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  55% { top: 84%;
    left: 21%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  98% { top: 82%;
    left: 22%;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1); }
  100% { top: 82%;
    left: 22%; } }

.wrap-map .per6 { top: 85%; left: 54%; width: 3vw; height: 3vw; -webkit-animation: per6 3s alternate infinite ease-in-out; animation: per6 3s alternate infinite ease-in-out; }

@-webkit-keyframes per6 { 0% { -webkit-transform: translate(-20%, -20%) rotate(-2deg); transform: translate(-20%, -20%) rotate(-2deg); }
  90% { -webkit-transform: translate(10%, 10%) rotate(2deg); transform: translate(10%, 10%) rotate(2deg); }
  100% { -webkit-transform: translate(10%, 10%) rotate(0deg); transform: translate(10%, 10%) rotate(0deg); } }

@keyframes per6 { 0% { -webkit-transform: translate(-20%, -20%) rotate(-2deg); transform: translate(-20%, -20%) rotate(-2deg); }
  90% { -webkit-transform: translate(10%, 10%) rotate(2deg); transform: translate(10%, 10%) rotate(2deg); }
  100% { -webkit-transform: translate(10%, 10%) rotate(0deg); transform: translate(10%, 10%) rotate(0deg); } }

.wrap-map .per7 { top: 94.5%; left: 54.5%; width: 5vw; height: 5vw; -webkit-animation: per7 14s infinite; animation: per7 14s infinite; pointer-events: none; }

@-webkit-keyframes per7 { 0% { top: 94.5%;
    left: 54.5%; }
  10% { top: 94.5%;
    left: 54.5%; }
  50% { top: 100%;
    left: 45.5%; }
  90% { top: 94.5%;
    left: 54.5%; }
  100% { top: 94.5%;
    left: 54.5%; } }

@keyframes per7 { 0% { top: 94.5%;
    left: 54.5%; }
  10% { top: 94.5%;
    left: 54.5%; }
  50% { top: 100%;
    left: 45.5%; }
  90% { top: 94.5%;
    left: 54.5%; }
  100% { top: 94.5%;
    left: 54.5%; } }

.wrap-map .per8 { top: 70.5%; left: 60%; width: 5.5vw; height: 5.5vw; -webkit-animation: per8 20s infinite; animation: per8 20s infinite; pointer-events: none; }

@-webkit-keyframes per8 { 0% { top: 70.5%;
    left: 60%; }
  70% { top: 103.5%;
    left: -20%; }
  100% { top: 96.5%;
    left: -6%; } }

@keyframes per8 { 0% { top: 70.5%;
    left: 60%; }
  70% { top: 103.5%;
    left: -20%; }
  100% { top: 96.5%;
    left: -6%; } }

.wrap-map .land-bg1 { top: 27.5%; left: 38%; width: 5vw; height: 5vw; }

.wrap-map .land-bg2 { top: 33.5%; left: 71%; width: 16vw; height: 16vw; pointer-events: none; }

.wrap-map .land-bg3 { top: 74%; left: 82%; width: 16vw; height: 16vw; pointer-events: none; }

.wrap-map .land-bg4 { top: 77.2%; left: 14.5%; width: 10vw; height: 10vw; }

.wrap-map .land-bg4.search-y:after { margin-top: 0; z-index: 2; }

.wrap-map .land-bg5 { top: 75.2%; left: 0; width: 19vw; height: 19vw; pointer-events: none; }

.wrap-map .land-bg6 { top: 89.4%; left: 51%; width: 6.5vw; height: 6.5vw; }

.wrap-map .land-bg6.search-y:after { margin-top: -1vw; margin-left: -1.5vw; z-index: 2; }

.wrap-map .land-bg7 { top: 91.8%; left: 56%; width: 6vw; height: 6vw; pointer-events: none; }

.wrap-map .land-bg8 { top: 93.2%; left: 47%; width: 15vw; height: 15vw; pointer-events: none; }

.wrap-map .land-bg9 { top: 70.1%; left: 55%; width: 16vw; height: 16vw; pointer-events: none; }

.wrap-map .enoden { top: 57%; left: 55.5%; -webkit-animation: enoden 16s infinite linear; animation: enoden 16s infinite linear; width: 19vw; height: 19vw; }

@-webkit-keyframes enoden { 0% { top: 57%;
    left: 55.5%; }
  10% { top: 57%;
    left: 55.5%; }
  50% { top: 79.2%;
    left: 100%; }
  60% { top: 79.2%;
    left: 100%; }
  100% { top: 57%;
    left: 55.5%; } }

@keyframes enoden { 0% { top: 57%;
    left: 55.5%; }
  10% { top: 57%;
    left: 55.5%; }
  50% { top: 79.2%;
    left: 100%; }
  60% { top: 79.2%;
    left: 100%; }
  100% { top: 57%;
    left: 55.5%; } }

.wrap-map .sea-per1 { top: 68.5%; left: 17.5%; width: 6.5vw; height: 6.5vw; -webkit-animation: sea-per1 5s infinite; animation: sea-per1 5s infinite; }

@-webkit-keyframes sea-per1 { 96% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); }
  97% { -webkit-transform: translate(2px, 2px) rotateZ(1deg); transform: translate(2px, 2px) rotateZ(1deg); }
  98% { -webkit-transform: translate(0px, 2px) rotateZ(0deg); transform: translate(0px, 2px) rotateZ(0deg); }
  99% { -webkit-transform: translate(2px, 0px) rotateZ(-1deg); transform: translate(2px, 0px) rotateZ(-1deg); }
  100% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); } }

@keyframes sea-per1 { 96% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); }
  97% { -webkit-transform: translate(2px, 2px) rotateZ(1deg); transform: translate(2px, 2px) rotateZ(1deg); }
  98% { -webkit-transform: translate(0px, 2px) rotateZ(0deg); transform: translate(0px, 2px) rotateZ(0deg); }
  99% { -webkit-transform: translate(2px, 0px) rotateZ(-1deg); transform: translate(2px, 0px) rotateZ(-1deg); }
  100% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); } }

.wrap-map .sea-per2 { top: 50%; left: -8%; width: 5vw; height: 5vw; -webkit-transform: scale(-1, 1); transform: scale(-1, 1); -webkit-animation: sea-per2 4s alternate infinite ease-in-out; animation: sea-per2 4s alternate infinite ease-in-out; }

@-webkit-keyframes sea-per2 { from { top: 50%;
    left: -8%;
    -webkit-transform: rotate(-10deg) scale(-1, 1);
    transform: rotate(-10deg) scale(-1, 1); }
  to { top: 67%;
    left: 10%;
    -webkit-transform: rotate(0deg) scale(-1, 1);
    transform: rotate(0deg) scale(-1, 1); } }

@keyframes sea-per2 { from { top: 50%;
    left: -8%;
    -webkit-transform: rotate(-10deg) scale(-1, 1);
    transform: rotate(-10deg) scale(-1, 1); }
  to { top: 67%;
    left: 10%;
    -webkit-transform: rotate(0deg) scale(-1, 1);
    transform: rotate(0deg) scale(-1, 1); } }

.wrap-map .sea-per3 { top: 57.5%; left: 42%; width: 5vw; height: 5vw; -webkit-animation: sea-per3 4s alternate infinite ease-in-out; animation: sea-per3 4s alternate infinite ease-in-out; }

@-webkit-keyframes sea-per3 { from { top: 58%;
    left: 42%; }
  to { top: 58.5%;
    left: 44%; } }

@keyframes sea-per3 { from { top: 58%;
    left: 42%; }
  to { top: 58.5%;
    left: 44%; } }

.wrap-map .sea-per4 { top: 28%; left: 16%; width: 10vw; height: 10vw; -webkit-animation: sea-per4 4s alternate infinite ease-in-out; animation: sea-per4 4s alternate infinite ease-in-out; }

@-webkit-keyframes sea-per4 { 0% { -webkit-transform: translate(-10%, -10%) rotate(-2deg); transform: translate(-10%, -10%) rotate(-2deg); }
  90% { -webkit-transform: translate(10%, 10%) rotate(2deg); transform: translate(10%, 10%) rotate(2deg); }
  100% { -webkit-transform: translate(10%, -10%) rotate(0deg); transform: translate(10%, -10%) rotate(0deg); } }

@keyframes sea-per4 { 0% { -webkit-transform: translate(-10%, -10%) rotate(-2deg); transform: translate(-10%, -10%) rotate(-2deg); }
  90% { -webkit-transform: translate(10%, 10%) rotate(2deg); transform: translate(10%, 10%) rotate(2deg); }
  100% { -webkit-transform: translate(10%, -10%) rotate(0deg); transform: translate(10%, -10%) rotate(0deg); } }

.wrap-map .sea-per5-1 { top: 56.5%; left: 50%; width: 5vw; height: 5vw; -webkit-animation: sea-per5 5s alternate infinite ease-in-out; animation: sea-per5 5s alternate infinite ease-in-out; }

.wrap-map .sea-per5-2 { top: 58.5%; left: 47%; width: 3.5vw; height: 3.5vw; -webkit-animation: sea-per5 5s alternate infinite ease-in-out; animation: sea-per5 5s alternate infinite ease-in-out; -webkit-animation-delay: 0.5s; animation-delay: 0.5s; }

@-webkit-keyframes sea-per5 { 0% { -webkit-transform: rotate(-4deg); transform: rotate(-4deg); }
  97% { -webkit-transform: rotate(4deg); transform: rotate(4deg); }
  100% { -webkit-transform: translateY(-10%) rotate(-12deg); transform: translateY(-10%) rotate(-12deg); } }

@keyframes sea-per5 { 0% { -webkit-transform: rotate(-4deg); transform: rotate(-4deg); }
  97% { -webkit-transform: rotate(4deg); transform: rotate(4deg); }
  100% { -webkit-transform: translateY(-10%) rotate(-12deg); transform: translateY(-10%) rotate(-12deg); } }

.wrap-map .sea-per6 { top: 35%; left: 24.5%; width: 8vw; height: 8vw; }

.wrap-map .sea-per7 { top: 52%; left: 47.8%; width: 5.2vw; height: 5.2vw; }

.wrap-map .sea-per7.search-y:after { margin-top: -2vw; margin-left: -2.2vw; }

.wrap-map .sea-bg1 { top: 48.5%; left: 48%; width: 5.5vw; height: 5.5vw; -webkit-animation: sea-bg1 5s alternate infinite ease-in-out; animation: sea-bg1 5s alternate infinite ease-in-out; }

@-webkit-keyframes sea-bg1 { 0% { -webkit-transform: rotate(-10deg); transform: rotate(-10deg); }
  100% { -webkit-transform: rotate(10deg); transform: rotate(10deg); } }

@keyframes sea-bg1 { 0% { -webkit-transform: rotate(-10deg); transform: rotate(-10deg); }
  100% { -webkit-transform: rotate(10deg); transform: rotate(10deg); } }

.wrap-map .sea-bg2 { top: 46%; left: 43.5%; width: 6.2vw; height: 6.2vw; }

.wrap-map .sea-dolphin { top: 42%; left: 36.5%; width: 8.5vw; height: 8.5vw; -webkit-animation: sea-dolphin 5s alternate infinite ease-in-out; animation: sea-dolphin 5s alternate infinite ease-in-out; }

@-webkit-keyframes sea-dolphin { 0% { opacity: 0; }
  85% { opacity: 0; }
  90% { opacity: 1;
    -webkit-transform: translateY(30px) rotate(-5deg);
    transform: translateY(30px) rotate(-5deg); } }

@keyframes sea-dolphin { 0% { opacity: 0; }
  85% { opacity: 0; }
  90% { opacity: 1;
    -webkit-transform: translateY(30px) rotate(-5deg);
    transform: translateY(30px) rotate(-5deg); } }

.wrap-map .sea-dolphin-splash { top: 48.5%; left: 35%; width: 6.5vw; height: 6.5vw; -webkit-animation: sea-dolphin-splash 5s alternate infinite ease-in-out; animation: sea-dolphin-splash 5s alternate infinite ease-in-out; -webkit-animation-delay: 0.6s; animation-delay: 0.6s; }

@-webkit-keyframes sea-dolphin-splash { 0% { opacity: 0; }
  85% { opacity: 0; }
  90% { opacity: 1;
    -webkit-transform: scale(1.2);
    transform: scale(1.2); } }

@keyframes sea-dolphin-splash { 0% { opacity: 0; }
  85% { opacity: 0; }
  90% { opacity: 1;
    -webkit-transform: scale(1.2);
    transform: scale(1.2); } }

.wrap-map .sea-ship1 { top: 49%; left: 9.8%; width: 5.2vw; height: 5.2vw; -webkit-animation: sea-ship1 5s alternate infinite ease-in-out; animation: sea-ship1 5s alternate infinite ease-in-out; }

.wrap-map .sea-ship1.search-y:after { margin-top: -2vw; margin-left: -2vw; }

@-webkit-keyframes sea-ship1 { 0% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); }
  50% { -webkit-transform: translate(-70%, -10px); transform: translate(-70%, -10px); }
  100% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); } }

@keyframes sea-ship1 { 0% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); }
  50% { -webkit-transform: translate(-70%, -10px); transform: translate(-70%, -10px); }
  100% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); } }

.wrap-map .sea-ship2 { top: 36%; left: 12.8%; width: 4.2vw; height: 4.2vw; -webkit-animation: sea-ship2 8s alternate infinite ease-in-out; animation: sea-ship2 8s alternate infinite ease-in-out; }

@-webkit-keyframes sea-ship2 { 0% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); }
  50% { -webkit-transform: translate(-80%, 10px); transform: translate(-80%, 10px); }
  100% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); } }

@keyframes sea-ship2 { 0% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); }
  50% { -webkit-transform: translate(-80%, 10px); transform: translate(-80%, 10px); }
  100% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); } }

.wrap-map .sea-ship3 { top: 35%; left: 3%; width: 2.8vw; height: 2.8vw; -webkit-animation: sea-ship3 3s alternate infinite ease-in-out; animation: sea-ship3 3s alternate infinite ease-in-out; }

@-webkit-keyframes sea-ship3 { 0% { -webkit-transform: translate(10%, 0); transform: translate(10%, 0); }
  50% { -webkit-transform: translate(20%, 5px); transform: translate(20%, 5px); }
  100% { -webkit-transform: translate(10%, 0); transform: translate(10%, 0); } }

@keyframes sea-ship3 { 0% { -webkit-transform: translate(10%, 0); transform: translate(10%, 0); }
  50% { -webkit-transform: translate(20%, 5px); transform: translate(20%, 5px); }
  100% { -webkit-transform: translate(10%, 0); transform: translate(10%, 0); } }

.wrap-map .sea-ship4 { top: 59%; left: 7%; width: 2.8vw; height: 2.8vw; -webkit-animation: sea-ship3 3s alternate infinite ease-in-out; animation: sea-ship3 3s alternate infinite ease-in-out; -webkit-animation-delay: 2s; animation-delay: 2s; }

.wrap-map .sea-ship5 { top: 71%; left: 3%; width: 2.8vw; height: 2.8vw; -webkit-animation: sea-ship3 3s alternate infinite ease-in-out; animation: sea-ship3 3s alternate infinite ease-in-out; -webkit-animation-delay: 1s; animation-delay: 1s; }

.wrap-counter { position: absolute; right: 45px; top: 30px; display: flex; opacity: 0; z-index: -1; transition: opacity .3s; background-color: #fff; box-shadow: 0px 0px 15px -5px rgba(0, 0, 0, 0.5); border-radius: 10px; justify-content: center; }

.wrap-counter > div { display: flex; padding: 5px 20px; font-size: 1.6rem; line-height: 1.6; font-family: "Barlow", serif; min-width: 80px; justify-content: center; }

.wrap-factory { width: calc(100vw - 30px); background-color: #F5FAFB; border-radius: 24px; margin: auto; }

.wrap-factory .wrap-bg { margin: 0 -10px 0 -5px; position: relative; }

.wrap-factory .wrap-bg img { width: 100%; height: auto; }

.wrap-factory .wrap-bg img.pc { display: none; }

.wrap-factory .wrap-hdg { padding: 32px 24px 17px; }

.wrap-factory .h1-factory { font-weight: 400; font-size: 4.0rem; line-height: 1.5; color: #920021; font-family: "Zen Maru Gothic", serif; }

.wrap-factory .txt-lead { font-size: 1.6rem; margin-top: 12px; line-height: 1.6; color: #3F484A; font-family: "Zen Maru Gothic", serif; font-weight: 500; }

.wrap-factory .link-btn { display: flex; font-size: 1.6rem; line-height: 1.5; z-index: 2; position: absolute; }

.wrap-factory .link-btn > a, .wrap-factory .link-btn > button { background-color: #BE012F; color: #FFFFFF; border-radius: 30px; padding: 10px 24px; transition: opacity .3s; position: relative; font-family: "Zen Maru Gothic", serif; font-weight: 600; }

.wrap-factory .item { display: inline-block; position: absolute; }

.wrap-factory .item img { position: absolute; left: 0; top: 0; }

.wrap-factory .content1 .link-btn { right: 26px; top: 4%; }

.wrap-factory .content1-parts1 { width: 2vw; height: auto; left: 49%; top: 13.1%; -webkit-animation: arms1 3s ease-in-out infinite alternate; animation: arms1 3s ease-in-out infinite alternate; }

@-webkit-keyframes arms1 { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
  40% { -webkit-transform: translateY(-8px); transform: translateY(-8px); }
  100% { -webkit-transform: translateY(-8px); transform: translateY(-8px); } }

@keyframes arms1 { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
  40% { -webkit-transform: translateY(-8px); transform: translateY(-8px); }
  100% { -webkit-transform: translateY(-8px); transform: translateY(-8px); } }

.wrap-factory .content1-parts2 { width: 5.5vw; height: auto; left: 68.5%; top: 18.5%; -webkit-animation: arms2 8s ease-in-out infinite; animation: arms2 8s ease-in-out infinite; }

@-webkit-keyframes arms2 { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
  15% { -webkit-transform: translateY(30px); transform: translateY(30px); }
  30% { -webkit-transform: translateY(30px); transform: translateY(30px); }
  45% { -webkit-transform: translateY(0); transform: translateY(0); }
  100% { -webkit-transform: translateY(0); transform: translateY(0); } }

@keyframes arms2 { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
  15% { -webkit-transform: translateY(30px); transform: translateY(30px); }
  30% { -webkit-transform: translateY(30px); transform: translateY(30px); }
  45% { -webkit-transform: translateY(0); transform: translateY(0); }
  100% { -webkit-transform: translateY(0); transform: translateY(0); } }

.wrap-factory .wrap-belt1 { width: 10.7vw; height: 9vw; left: 55.3%; top: 5.2%; overflow: hidden; -webkit-clip-path: polygon(45% 0, 100% 0, 100% 100%, 68% 100%, 0 100%, 0 34%); clip-path: polygon(45% 0, 100% 0, 100% 100%, 68% 100%, 0 100%, 0 34%); -webkit-transform: rotate(-1.5deg); transform: rotate(-1.5deg); }

.wrap-factory .wrap-belt1 img { width: 200vw; animation: moveConveyor 90s linear infinite reverse; }

@-webkit-keyframes moveConveyor { 0% { -webkit-transform: translate(-1060px, -628px); transform: translate(-1060px, -628px); }
  100% { -webkit-transform: translate(0, 0); transform: translate(0, 0); } }

@keyframes moveConveyor { 0% { -webkit-transform: translate(-1060px, -628px); transform: translate(-1060px, -628px); }
  100% { -webkit-transform: translate(0, 0); transform: translate(0, 0); } }

.wrap-factory .wrap-belt2 { width: 37vw; height: 30vw; left: 57.5%; top: 13.5%; overflow: hidden; -webkit-clip-path: polygon(16% 0, 100% 0, 100% 77%, 68% 100%, 0 100%, 0 13%); clip-path: polygon(16% 0, 100% 0, 100% 77%, 68% 100%, 0 100%, 0 13%); -webkit-transform: rotate(-1.1deg); transform: rotate(-1.1deg); }

.wrap-factory .wrap-belt2 img { width: 200vw; animation: moveConveyor 90s linear infinite reverse; }

@keyframes moveConveyor { 0% { -webkit-transform: translate(-1060px, -628px); transform: translate(-1060px, -628px); }
  100% { -webkit-transform: translate(0, 0); transform: translate(0, 0); } }

.wrap-factory .content1-bg1 { width: 12.5vw; height: auto; left: 57%; top: 18%; }

.wrap-factory .content1-bg2 { width: 8.5vw; height: auto; left: 66.5%; top: 27%; }

.wrap-factory .content1-bg3 { width: 14vw; height: auto; left: 73%; top: 23.1%; }

.wrap-factory .content1-bg4 { width: 6vw; height: auto; left: 52%; top: 29%; }

.wrap-factory .content1-bg5 { width: 2.5vw; height: auto; left: 63%; top: 38%; }

.wrap-factory .content2 .link-btn { right: 30px; top: 35%; }

.wrap-factory .content2-parts1 { width: 1.6vw; height: auto; left: 53%; top: 72.1%; -webkit-animation: flash 4s ease-in-out infinite alternate; animation: flash 4s ease-in-out infinite alternate; }

@-webkit-keyframes flash { from { -webkit-filter: brightness(100%); filter: brightness(100%); }
  to { -webkit-filter: blur(10px) brightness(130%); filter: blur(10px) brightness(130%); } }

@keyframes flash { from { -webkit-filter: brightness(100%); filter: brightness(100%); }
  to { -webkit-filter: blur(10px) brightness(130%); filter: blur(10px) brightness(130%); } }

.wrap-factory .content2-parts2 { width: 3.4vw; height: auto; left: 56%; top: 39%; -webkit-animation: fac-per1 5s infinite; animation: fac-per1 5s infinite; }

@-webkit-keyframes fac-per1 { 92% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); }
  93% { -webkit-transform: translate(2px, 2px) rotateZ(1deg); transform: translate(2px, 2px) rotateZ(1deg); }
  94% { -webkit-transform: translate(0px, 2px) rotateZ(0deg); transform: translate(0px, 2px) rotateZ(0deg); }
  95% { -webkit-transform: translate(2px, 0px) rotateZ(-1deg); transform: translate(2px, 0px) rotateZ(-1deg); }
  96% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); }
  97% { -webkit-transform: translate(2px, 2px) rotateZ(1deg); transform: translate(2px, 2px) rotateZ(1deg); }
  98% { -webkit-transform: translate(0px, 2px) rotateZ(0deg); transform: translate(0px, 2px) rotateZ(0deg); }
  99% { -webkit-transform: translate(2px, 0px) rotateZ(-1deg); transform: translate(2px, 0px) rotateZ(-1deg); }
  100% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); } }

@keyframes fac-per1 { 92% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); }
  93% { -webkit-transform: translate(2px, 2px) rotateZ(1deg); transform: translate(2px, 2px) rotateZ(1deg); }
  94% { -webkit-transform: translate(0px, 2px) rotateZ(0deg); transform: translate(0px, 2px) rotateZ(0deg); }
  95% { -webkit-transform: translate(2px, 0px) rotateZ(-1deg); transform: translate(2px, 0px) rotateZ(-1deg); }
  96% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); }
  97% { -webkit-transform: translate(2px, 2px) rotateZ(1deg); transform: translate(2px, 2px) rotateZ(1deg); }
  98% { -webkit-transform: translate(0px, 2px) rotateZ(0deg); transform: translate(0px, 2px) rotateZ(0deg); }
  99% { -webkit-transform: translate(2px, 0px) rotateZ(-1deg); transform: translate(2px, 0px) rotateZ(-1deg); }
  100% { -webkit-transform: translate(0px, 0px) rotateZ(0deg); transform: translate(0px, 0px) rotateZ(0deg); } }

.wrap-factory .content3 .link-btn { left: 30px; top: 48%; }

.wrap-factory .content3-parts1 { width: 3.5vw; height: auto; left: 33.2%; top: 18.1%; -webkit-transform-origin: center center; transform-origin: center center; -webkit-animation: tv 5s ease-in-out infinite; animation: tv 5s ease-in-out infinite; }

@-webkit-keyframes tv { 0% { -webkit-transform: scale(0.8) translate(-3px, -2px); transform: scale(0.8) translate(-3px, -2px); }
  25% { -webkit-transform: scale(1) translate(0, 3px); transform: scale(1) translate(0, 3px); }
  50% { -webkit-transform: scale(1) rotate(-5deg); transform: scale(1) rotate(-5deg); }
  100% { -webkit-transform: scale(0.8) rotate(10deg); transform: scale(0.8) rotate(10deg); } }

@keyframes tv { 0% { -webkit-transform: scale(0.8) translate(-3px, -2px); transform: scale(0.8) translate(-3px, -2px); }
  25% { -webkit-transform: scale(1) translate(0, 3px); transform: scale(1) translate(0, 3px); }
  50% { -webkit-transform: scale(1) rotate(-5deg); transform: scale(1) rotate(-5deg); }
  100% { -webkit-transform: scale(0.8) rotate(10deg); transform: scale(0.8) rotate(10deg); } }

.wrap-factory .content3-parts2 { width: 3vw; height: auto; left: 27.8%; top: 18.1%; -webkit-transform-origin: left center; transform-origin: left center; -webkit-animation: stick 10s ease-in-out infinite; animation: stick 10s ease-in-out infinite; }

@-webkit-keyframes stick { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  50% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  51% { -webkit-transform: rotate(-15deg); transform: rotate(-15deg); }
  100% { -webkit-transform: rotate(-15deg); transform: rotate(-15deg); } }

@keyframes stick { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  50% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  51% { -webkit-transform: rotate(-15deg); transform: rotate(-15deg); }
  100% { -webkit-transform: rotate(-15deg); transform: rotate(-15deg); } }

.wrap-factory .content4 .link-btn { position: absolute; left: 34px; bottom: 48px; }

.wrap-factory .content4 .link-btn a:before, .wrap-factory .content4 .link-btn button:before { position: absolute; content: ""; display: block; width: 102px; height: 57.5px; background: transparent url(shonan_factory_drone.webp) no-repeat 0 0; background-size: contain; left: -10px; top: -47px; -webkit-animation: float 3s ease-in-out infinite; animation: float 3s ease-in-out infinite; }

@-webkit-keyframes float { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
  50% { -webkit-transform: translateY(-20px); transform: translateY(-20px); }
  100% { -webkit-transform: translateY(0); transform: translateY(0); } }

@keyframes float { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
  50% { -webkit-transform: translateY(-20px); transform: translateY(-20px); }
  100% { -webkit-transform: translateY(0); transform: translateY(0); } }

.wrap-factory .content4-parts1 { width: 9.5vw; height: auto; left: 74.8%; top: 78%; -webkit-transform-origin: right top; transform-origin: right top; -webkit-animation: rotate 2s ease-in-out infinite alternate; animation: rotate 2s ease-in-out infinite alternate; }

@-webkit-keyframes rotate { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  100% { -webkit-transform: rotate(5deg); transform: rotate(5deg); } }

@keyframes rotate { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  100% { -webkit-transform: rotate(5deg); transform: rotate(5deg); } }

.wrap-factory .content4-parts2 { width: 16.5vw; height: auto; left: 75.2%; top: 61.2%; }

.school .main, .laboratory .main { padding-bottom: 0; }

.wrap-school { overflow: hidden; }

.wrap-school .wrap-hdg { width: calc(100% - 15px); margin: 0 0 0 auto; }

.wrap-school .wrap-hdg .wrap-txt { padding: 40px 24px; background-color: #FDFDF2; border-radius: 24px 0 0; }

.wrap-school .wrap-hdg .wrap-img { margin-top: -7%; }

.wrap-school .wrap-hdg .wrap-img img { max-width: 100%; height: auto; }

.wrap-school .wrap-hdg .h1-school { font-family: "Zen Maru Gothic", serif; font-weight: 500; font-size: 4.0rem; line-height: 1.5; color: #920021; }

.wrap-school .wrap-hdg .txt-lead { font-family: "Zen Kaku Gothic New", serif; font-weight: 500; font-size: 1.6rem; line-height: 1.6; color: #3F484A; margin-top: 12px; }

.wrap-school .list-page-anchor { margin: 57px 24px 0; }

.wrap-school .list-page-anchor > li { margin-top: 32px; }

.wrap-school .list-page-anchor a { display: block; position: relative; background-color: #F5FAFB; border-radius: 24px; }

.wrap-school .list-page-anchor a:after { content: ""; display: block; width: 24px; height: 24px; background: transparent url(shonan_beautyschool_icon_anchor.png) no-repeat center center; background-size: contain; position: absolute; right: 12px; bottom: 24px; }

.wrap-school .list-page-anchor a.icon1::before { content: ""; display: block; width: 38px; height: 68px; background: transparent url(shonan_beautyschool_img02.webp) no-repeat center center; background-size: contain; position: absolute; right: 32px; top: -38px; }

.wrap-school .list-page-anchor a.icon2::before { content: ""; display: block; width: 76px; height: 46px; background: transparent url(shonan_beautyschool_img03.webp) no-repeat center center; background-size: contain; position: absolute; right: 24px; top: -7px; }

.wrap-school .list-page-anchor .no { font-weight: 900; font-family: "Zen Maru Gothic", serif; color: #920021; font-size: 1.4rem; position: absolute; left: 24px; top: -20px; z-index: 1; pointer-events: none; }

.wrap-school .list-page-anchor .no span { font-family: "Barlow", serif; font-size: 4.6rem; font-weight: 400; padding-right: 5px; }

.wrap-school .list-page-anchor .txt { font-size: 1.6rem; font-weight: 500; line-height: 1.5; position: relative; }

.wrap-school .list-page-anchor .inner { padding: 38px 40px 24px 24px; position: relative; overflow: hidden; border-radius: 24px; pointer-events: none; }

.wrap-school .list-page-anchor .inner:before { content: ""; display: block; width: 120px; height: 120px; background-color: #FFDAD9; position: absolute; left: -24px; top: -24px; border-radius: 50%; z-index: 0; -webkit-filter: blur(15px); filter: blur(15px); }

.wrap-school .hdg-period { margin: 0 24px 0 0; background: linear-gradient(90deg, #ffdad9 0%, #ffdad9 49%, #ffb4ab 90%, #ffb4ab 100%); border-radius: 0 200px 200px 0; font-weight: 400; font-family: "Zen Maru Gothic", serif; font-size: 2.4rem; line-height: 1.5; }

.wrap-school .hdg-period .inner { display: block; padding: 48px 24px 40px; position: relative; }

.wrap-school .hdg-period .txt-period { font-weight: 900; font-size: 1.4rem; display: block; color: #920021; }

.wrap-school .hdg-period.inview.pt1 .inner:before, .wrap-school .hdg-period.inview.pt2 .inner:before, .wrap-school .hdg-period.inview.pt3 .inner:before { -webkit-transform: translateX(0); transform: translateX(0); }

.wrap-school .hdg-period.inview.pt1 .inner:after, .wrap-school .hdg-period.inview.pt2 .inner:after, .wrap-school .hdg-period.inview.pt3 .inner:after { -webkit-transform: translateX(0); transform: translateX(0); }

.wrap-school .hdg-period.pt1 .inner:before { content: ""; display: block; width: 64px; height: 68px; position: absolute; left: 16px; top: -28px; background: transparent url(shonan_beautyschool_img04.webp) no-repeat center center; background-size: contain; transition: 1.5s; -webkit-transform: translateX(-100px); transform: translateX(-100px); }

.wrap-school .hdg-period.pt1 .inner:after { content: ""; display: block; width: 144px; height: 74px; position: absolute; right: -16px; bottom: -30px; background: transparent url(shonan_beautyschool_img05.webp) no-repeat center center; background-size: contain; transition: 1.5s; transition-delay: .3s; -webkit-transform: translateX(50px); transform: translateX(50px); }

.wrap-school .hdg-period.pt2 .inner:before { content: ""; display: block; width: 64px; height: 68px; position: absolute; left: 16px; top: -28px; background: transparent url(shonan_beautyschool_img06.webp) no-repeat center center; background-size: contain; transition: 1.5s; -webkit-transform: translateX(-100px); transform: translateX(-100px); }

.wrap-school .hdg-period.pt2 .inner:after { content: ""; display: block; width: 144px; height: 74px; position: absolute; right: -16px; bottom: -30px; background: transparent url(shonan_beautyschool_img07.webp) no-repeat center center; background-size: contain; transition: 1.5s; transition-delay: .3s; -webkit-transform: translateX(50px); transform: translateX(50px); }

.wrap-school .hdg-period.pt3 .inner:before { content: ""; display: block; width: 64px; height: 68px; position: absolute; left: 16px; top: -28px; background: transparent url(shonan_laboratory_person07.webp) no-repeat center center; background-size: contain; transition: 1.5s; -webkit-transform: translateX(-100px); transform: translateX(-100px); }

.wrap-school .hdg-period.pt3 .inner:after { content: ""; display: block; width: 144px; height: 74px; position: absolute; right: -16px; bottom: -30px; background: transparent url(shonan_laboratory_person08.webp) no-repeat center center; background-size: contain; transition: 1.5s; transition-delay: .3s; -webkit-transform: translateX(50px); transform: translateX(50px); }

.wrap-school .wrap-qa { margin-top: 80px; padding: 0 24px; }

.wrap-school .wrap-qa .txt { font-size: 1.6rem; }

.wrap-school .wrap-qa .txt-add { font-size: 1.4rem; color: #3F484A; line-height: 1.6; margin-top: 16px; }

.wrap-school .wrap-qa .wrap-q, .wrap-school .wrap-qa .wrap-a { margin-top: 48px; display: flex; opacity: 0; -webkit-transform: translateY(40px); transform: translateY(40px); transition: 1.2s; }

.wrap-school .wrap-qa .wrap-q .inner, .wrap-school .wrap-qa .wrap-a .inner { width: calc(100% - 80px); }

.wrap-school .wrap-qa .wrap-q .inner .wrap-txt, .wrap-school .wrap-qa .wrap-a .inner .wrap-txt { background-color: #FFFFFF; padding: 24px 20px 24px 24px; border-radius: 24px; position: relative; }

.wrap-school .wrap-qa .wrap-q .inner .wrap-txt:has(.txt-q), .wrap-school .wrap-qa .wrap-q .inner .wrap-txt:has(.txt-a), .wrap-school .wrap-qa .wrap-a .inner .wrap-txt:has(.txt-q), .wrap-school .wrap-qa .wrap-a .inner .wrap-txt:has(.txt-a) { padding-top: 32px; }

.wrap-school .wrap-qa .wrap-q .inner .wrap-txt:before, .wrap-school .wrap-qa .wrap-a .inner .wrap-txt:before { content: ""; width: 0; height: 0; border-style: solid; border-width: 0 24px 41.6px 24px; border-color: transparent transparent #FFFFFF transparent; position: absolute; right: -11px; top: -10px; -webkit-transform: rotate(60deg); transform: rotate(60deg); }

.wrap-school .wrap-qa .wrap-q .inner .wrap-txt + .wrap-txt, .wrap-school .wrap-qa .wrap-a .inner .wrap-txt + .wrap-txt { margin-top: 48px; }

.wrap-school .wrap-qa .wrap-q .wrap-img, .wrap-school .wrap-qa .wrap-a .wrap-img { width: 80px; padding: 0 0 0 17px; }

.wrap-school .wrap-qa .wrap-q .wrap-img img, .wrap-school .wrap-qa .wrap-a .wrap-img img { width: 100%; }

.wrap-school .wrap-qa .wrap-q .txt-q, .wrap-school .wrap-qa .wrap-q .txt-a, .wrap-school .wrap-qa .wrap-a .txt-q, .wrap-school .wrap-qa .wrap-a .txt-a { position: absolute; left: 24px; top: -26px; font-family: "Barlow", serif; font-size: 4.8rem; font-weight: 500; color: #3F484A; line-height: 1; }

.wrap-school .wrap-qa .wrap-q .txt-a, .wrap-school .wrap-qa .wrap-a .txt-a { color: #BE012F; }

.wrap-school .wrap-qa .wrap-q.inview, .wrap-school .wrap-qa .wrap-a.inview { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

.wrap-school .wrap-qa .wrap-a { flex-direction: row-reverse; }

.wrap-school .wrap-qa .wrap-a .inner .wrap-txt:before { right: auto; left: -16px; -webkit-transform: scale(-1, 1) rotate(60deg); transform: scale(-1, 1) rotate(60deg); }

.wrap-school .wrap-qa .wrap-a .wrap-img { padding: 0 17px 0 0; }

.wrap-school .hr-pt1, .wrap-school .hr-pt2 { padding-top: 72px; position: relative; background-color: #FFEDEC; }

.wrap-school .hr-pt1:after, .wrap-school .hr-pt2:after { content: ""; display: block; height: 100px; background: #FFEDEC url(shonan_beautyschool_hr.png) no-repeat center bottom; background-size: 820px 100%; -webkit-filter: blur(5px); filter: blur(5px); z-index: -1; overflow: hidden; }

.wrap-school .hr-pt1 + .hr-pt2, .wrap-school .hr-pt2 + .hr-pt1 { margin-top: -10px; }

.wrap-school .hr-pt2 + .hr-pt2 { margin-top: -100px; }

.wrap-school .hr-pt2 + .hr-pt2:after { display: none; }

.wrap-school .hr-pt2 { background-color: #f5fafb; }

.wrap-school .hr-pt2:after { -webkit-transform: scale(1, -1); transform: scale(1, -1); }

.wrap-school .hr-pt2 .wrap-qa .wrap-q .inner .wrap-txt, .wrap-school .hr-pt2 .wrap-qa .wrap-a .inner .wrap-txt { background-color: #FFEDEC; }

.wrap-school .hr-pt2 .wrap-qa .wrap-q .inner .wrap-txt:before, .wrap-school .hr-pt2 .wrap-qa .wrap-a .inner .wrap-txt:before { border-color: transparent transparent #FFEDEC transparent; }

.wrap-school .link-btn { padding: 48px 24px 80px; font-size: 1.8rem; line-height: 1.5; font-weight: 700; font-family: "Zen Maru Gothic", serif; }

.wrap-school .link-btn a { display: block; padding: 19px; text-align: center; color: #FFFFFF; background-color: #BE012F; border-radius: 60px; }

.quiz .main { container-type: inline-size; }

.wrap-quiz { margin-top: 0; width: calc(100vw - 30px); padding: 24px 33px; margin: auto; border-radius: 16px; position: relative; background-color: #93DDC3; }

.wrap-quiz input { -webkit-appearance: auto; -moz-appearance: auto; appearance: auto; }

.wrap-quiz .txt-q1 { font-family: "Barlow", serif; font-size: 4.0rem; font-weight: 500; color: #BE012F; line-height: 1; }

.wrap-quiz .txt-q2 { font-family: "Zen Kaku Gothic New", serif; font-weight: 500; font-size: 1.8rem; line-height: 1.6; color: #171D1E; margin-top: 20px; }

.wrap-slider-quiz .splide__track { width: 100vw; width: 100cqw; -webkit-transform: translateX(-50%); transform: translateX(-50%); left: 50%; padding-bottom: 14px; }

.wrap-slider-quiz .splide__slide { padding: 0; height: 100%; width: calc( 100% - 96px); display: flex; flex-wrap: wrap; background-color: #fff; border-radius: 24px; box-shadow: 0px 4px 12px 0px rgba(0, 0, 0, 0.12); }

.wrap-slider-quiz .wrap-quiz-txt { padding: 32px; border-radius: 24px 20px 0 0; width: 100%; min-height: 208px; display: flex; align-items: center; justify-content: center; }

.wrap-slider-quiz .wrap-quiz-btn { width: 100%; padding: 8px 24px; border-radius: 0 0 24px 24px; background-color: #FFDAD9; margin-top: auto; }

.wrap-slider-quiz .wrap-quiz-btn label { display: flex; align-items: center; justify-content: center; border-radius: 24px; height: 64px; background-color: #FDFDF2; font-size: 0; color: transparent; margin: 16px 0; position: relative; cursor: pointer; }

.wrap-slider-quiz .wrap-quiz-btn label:after { content: ""; display: block; width: 48px; height: 48px; background: transparent no-repeat center center; background-size: 48px 48px; }

.wrap-slider-quiz .wrap-quiz-btn label input { display: none; }

.wrap-slider-quiz .wrap-quiz-btn label span { display: block; width: 24px; height: 24px; position: absolute; right: 12px; top: 50%; margin-top: -12px; background: transparent url(shonan_quiz_check.webp) no-repeat 0 0; background-size: contain; }

.wrap-slider-quiz .wrap-quiz-btn label input:checked + span { background-image: url(shonan_quiz_checked.webp); }

.wrap-slider-quiz .wrap-quiz-btn label.yes:after { background-image: url(shonan_quiz_yes.webp); }

.wrap-slider-quiz .wrap-quiz-btn label.no:after { background-image: url(shonan_quiz_no.webp); }

.wrap-slider-quiz .wrap-quiz-btn label:has(input:checked) { background-color: #BF002E; }

.wrap-slider-quiz .wrap-quiz-btn label:has(input:checked):after { -webkit-filter: brightness(0) saturate(100%) invert(96%) sepia(98%) saturate(16%) hue-rotate(319deg) brightness(105%) contrast(100%); filter: brightness(0) saturate(100%) invert(96%) sepia(98%) saturate(16%) hue-rotate(319deg) brightness(105%) contrast(100%); }

.wrap-slider-quiz .slider-controls { justify-content: space-between; margin: 12px -32px 0; padding: 0 24px; max-width: 1092px; position: relative; overflow: hidden; }

.wrap-slider-quiz .slider-controls .splide__arrows { display: flex; justify-content: space-between; width: 112px; }

.wrap-slider-quiz .slider-controls .splide__arrows .splide__arrow { width: 48px; height: 48px; background: #fff url(shonan_quiz_arrow.webp) no-repeat no-repeat 40% center; background-size: 24px 24px; border-radius: 50%; font-size: 0; }

.wrap-slider-quiz .slider-controls .splide__arrows .splide__arrow.splide__arrow--next { -webkit-transform: scale(-1, 1); transform: scale(-1, 1); }

.wrap-slider-quiz .slider-controls .txt-slider-current { position: absolute; right: 32px; top: 14px; text-align: right; font-family: "Barlow", serif; font-size: 1.6rem; font-weight: 700; color: #920021; line-height: 1; }

.wrap-slider-quiz .slider-controls .btn-scoring button { text-align: center; padding: 18px; display: block; width: 100%; font-size: 1.8rem; font-weight: 700; line-height: 1.6; font-family: "Zen Maru Gothic", serif; border-radius: 32px; background-color: #BE012F; color: #fff; }

.wrap-slider-quiz .slider-controls .btn-scoring button:disabled { background-color: #C8C6C5; color: #6F797A; cursor: auto; }

.wrap-slider-quiz .wrap-splide__pagination { margin: 28px 0; text-align: center; overflow: auto; }

.wrap-slider-quiz .splide__pagination { display: inline-block; white-space: nowrap; }

.wrap-slider-quiz .splide__pagination > li { margin-right: 30px; position: relative; font-size: 0; }

.wrap-slider-quiz .splide__pagination > li:last-child { margin-right: 0; }

.wrap-slider-quiz .splide__pagination > li::before { content: ''; display: block; width: 40px; border-top: 6px solid #fff; position: absolute; left: 90%; top: 50%; -webkit-transform: translateY(-50%); transform: translateY(-50%); }

.wrap-slider-quiz .splide__pagination > li:last-child::before { display: none; }

.wrap-slider-quiz .splide__pagination > li.viewed:before { border-top: 6px solid #BF002E; }

.wrap-slider-quiz .splide__pagination__page { width: 20px; height: 20px; background-color: #fff; border-radius: 50%; position: relative; z-index: 1; }

.wrap-slider-quiz .answered .splide__pagination__page { background-color: #BF002E; background-image: url(shonan_quiz_answerd.webp); background-repeat: no-repeat; background-position: center center; background-size: 12px 8px; }

.wrap-slider-quiz .splide__pagination__page { width: 20px; height: 20px; background-color: #fff; border-radius: 50%; position: relative; z-index: 1; width: 20px; height: 20px; background-color: #fff; border-radius: 50%; }

.wrap-slider-quiz .splide__pagination__page.is-active { background-color: #000; }

.wrap-passed { overflow: hidden; }

.wrap-passed .hdg-quiz-result { font-size: 2.4rem; line-height: 1.6; font-family: "Zen Maru Gothic", serif; font-weight: 400; }

.wrap-passed .wrap-bg { margin-top: 0; padding: 230px 24px 64px; margin: auto; border-radius: 16px; background-color: #fff; }

.wrap-passed .list-answer > li { padding: 24px 0; border-bottom: 2px solid #C9C6C5; font-size: 1.6rem; color: #3F484A; line-height: 1.6; }

.wrap-passed .list-answer .wrap-question-txt { font-size: 2.0rem; color: #3F484A; font-weight: 800; line-height: 1.5; }

.wrap-passed .list-answer .wrap-question-txt .no { display: block; font-weight: 600; color: #171D1E; font-family: "Barlow", serif; }

.wrap-passed .list-answer .wrap-description-content { display: flex; margin-top: 24px; }

.wrap-passed .list-answer .wrap-answer { width: 64px; }

.wrap-passed .list-answer .wrap-answer::before { content: ""; display: block; width: 64px; height: 64px; background: #FFDAD9 no-repeat center center; background-size: 48px 48px; border-radius: 8px; }

.wrap-passed .list-answer .wrap-answer.true::before { background-image: url(shonan_quiz_yes.webp); }

.wrap-passed .list-answer .wrap-answer.false::before { background-image: url(shonan_quiz_no.webp); }

.wrap-passed .list-answer .true-answer { font-weight: 800; font-size: 1.8rem; margin-bottom: 10px; }

.wrap-passed .list-answer .wrap-description { width: calc(100% - 64px); padding-left: 24px; }

.wrap-passed .comment { white-space: pre-wrap; }

.wrap-passed .wrap-bg .wrap-btn { margin-top: 48px; }

.wrap-passed .wrap-bg .wrap-btn > li { margin-top: 16px; font-size: 1.6rem; font-family: "Zen Maru Gothic", serif; line-height: 1.5; }

.wrap-passed .wrap-bg .wrap-btn a { display: block; border-radius: 24px; text-align: center; padding: 12px; color: #171D1E; font-weight: 600; }

.wrap-passed .wrap-bg .wrap-btn a.btn-pt1 { background-color: #FFB4AA; border: 2px solid #FFB4AA; }

.wrap-passed .wrap-bg .wrap-btn a.btn-pt2 { background-color: #fff; border: 2px solid #C8C6C5; }

.wrap-passed .result-inner { position: relative; margin-bottom: -170px; z-index: 2; }

.wrap-passed .result-inner:before { content: ""; display: block; position: absolute; width: 400px; height: 400px; background-color: #FDFDF2; border-radius: 50%; -webkit-filter: blur(40px); filter: blur(40px); position: absolute; margin: auto; top: 40%; left: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }

.wrap-passed .inner { position: relative; }

.wrap-passed .hdg-result { text-align: center; font-size: 2.0rem; color: #3F484A; line-height: 1.6; font-family: "Zen Kaku Gothic New", serif; font-weight: 600; padding-top: 30px; }

.wrap-passed .txt-congratulations { text-align: center; position: relative; color: #BF002E; font-size: 7.2rem; font-weight: 800; display: flex; justify-content: center; padding: 60px 0 30px; position: relative; z-index: 2; }

.wrap-passed .txt-score { text-align: center; font-size: 2.0rem; color: #3F484A; line-height: 1.6; font-family: "Barlow",'Noto Sans JP', sans-serif; font-weight: 600; padding-bottom: 30px; }

.wrap-passed .txt-score span { font-size: 4.8rem; }

.wrap-passed .wrap-congratulations { background-color: #FFDAD9; padding: 48px 24px; border-radius: 24px; position: relative; margin: 0 24px; }

.wrap-passed .wrap-congratulations:after { content: ""; display: block; height: 360px; position: absolute; right: -24px; left: -32px; top: -320px; background: transparent url(shonan_index_all_correct_sp.webp) no-repeat top center; background-size: contain; }

.wrap-passed .wrap-congratulations .wrap-txt { position: relative; }

.wrap-passed .wrap-congratulations .wrap-txt::before { content: ""; display: block; width: 56px; height: 56px; background: url(shonan_quiz_bg01.webp) no-repeat center center; background-size: contain; position: absolute; right: 20px; top: -20px; }

.wrap-passed .wrap-congratulations .wrap-txt::after { content: ""; display: block; width: 52px; height: 52px; background: url(shonan_quiz_bg02.webp) no-repeat center center; background-size: contain; position: absolute; left: 20px; bottom: 0; z-index: 0; }

.wrap-passed .wrap-congratulations .wrap-txt p { text-align: center; font-size: 1.8rem; line-height: 1.6; font-weight: 500; font-family: "Zen Kaku Gothic New", serif; position: relative; z-index: 1; }

.wrap-passed .wrap-congratulations .wrap-btn1 { margin-top: 30px; }

.wrap-passed .wrap-congratulations .wrap-btn1 a { display: block; border-radius: 32px; background-color: #FDFDF2; text-align: center; color: #171D1E; font-family: "Zen Maru Gothic", serif; font-size: 1.6rem; line-height: 1.5; font-weight: 700; padding: 18px 10px; }

.wrap-passed .wrap-congratulations .wrap-btn1 + .wrap-btn2 { margin-top: 16px; }

.wrap-passed .wrap-congratulations .wrap-btn2 { margin-top: 30px; }

.wrap-passed .wrap-congratulations .wrap-btn2 a { display: block; border-radius: 32px; background-color: #BE012F; text-align: center; color: #FFFFFF; font-family: "Zen Maru Gothic", serif; font-size: 1.8rem; line-height: 1.5; font-weight: 700; padding: 18px 10px; }

.wrap-passed .result-inner.failed:before { background-color: #F5FAFB; }

.wrap-passed .result-inner.failed .txt-congratulations { color: #3F484A; }

.wrap-passed .result-inner.failed .wrap-congratulations:after { display: none; }

.wrap-passed .result-inner.failed .wrap-txt::before, .wrap-passed .result-inner.failed .wrap-txt::after { display: none; }

.dialog { display: block; padding: 0; position: fixed; inset-inline: 0; inset-block: 0; border-radius: 24px; z-index: 9999; border: none; -webkit-animation-name: fadeOut-dialog; animation-name: fadeOut-dialog; -webkit-animation-fill-mode: forwards; animation-fill-mode: forwards; -webkit-animation-duration: 200ms; animation-duration: 200ms; -webkit-animation-timing-function: ease-out; animation-timing-function: ease-out; width: calc(100vw - 32px); color: #3F484A; }

.dialog::-webkit-backdrop { background-color: #000; opacity: 0.4; }

.dialog::backdrop { background-color: #000; opacity: 0.4; }

.dialog[open] { -webkit-animation-name: fadeIn-dialog; animation-name: fadeIn-dialog; -webkit-animation-fill-mode: forwards; animation-fill-mode: forwards; -webkit-animation-duration: 200ms; animation-duration: 200ms; -webkit-animation-timing-function: ease-out; animation-timing-function: ease-out; }

.dialog .dialog-inner { padding: 76px 24px 56px; position: relative; }

.dialog .btn-close { position: absolute; right: 12px; top: 12px; width: 48px; height: 48px; font-size: 0; z-index: 3; }

.dialog .btn-close::before, .dialog .btn-close::after { content: ""; display: block; height: 2px; position: absolute; width: 100%; background-color: #920021; width: 18px; left: 50%; margin-left: -9px; }

.dialog .btn-close::before { -webkit-transform: rotate(45deg); transform: rotate(45deg); }

.dialog .btn-close::after { -webkit-transform: rotate(-45deg); transform: rotate(-45deg); }

.dialog .txt-hdg { line-height: 1.5; color: #3F484A; font-size: 1.8rem; }

.dialog .txt-hdg a { color: #3F484A; text-decoration: underline; }

.dialog .txt-hdg.ver-soon { font-size: 2.2rem; }

.dialog .txt-add { margin-top: 16px; line-height: 1.5; color: #3F484A; font-size: 1.4rem; }

.dialog .txt-add a { color: #3F484A; text-decoration: underline; }

.dialog .movie { width: 100%; height: auto; margin-bottom: 16px; }

.dialog.all-questions-correct { background-color: #FFEDEC; overflow: hidden; }

.dialog.all-questions-correct .dialog-inner { position: relative; min-height: 340px; }

.dialog.all-questions-correct .dialog-inner:before { content: ""; display: block; position: absolute; width: 400px; height: 400px; background-color: #FDFDF2; border-radius: 50%; -webkit-filter: blur(40px); filter: blur(40px); position: absolute; margin: auto; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }

.dialog.all-questions-correct .inner { position: relative; }

.dialog.all-questions-correct .txt-congratulations { text-align: center; position: relative; color: #BF002E; font-size: 4.0rem; font-weight: 800; display: flex; justify-content: center; padding: 85px 0; position: relative; z-index: 2; }

.dialog.all-questions-correct .wrap-congratulations { background-color: #FFDAD9; padding: 24px; border-radius: 24px; position: relative; }

.dialog.all-questions-correct .wrap-congratulations:after { content: ""; display: block; height: 360px; position: absolute; right: -18px; left: -28px; top: -242px; background: transparent url(shonan_index_all_correct_sp.webp) no-repeat top center; background-size: contain; }

.dialog.all-questions-correct .wrap-congratulations p { text-align: center; font-size: 1.6rem; font-weight: 500; line-height: 1.6; font-family: "Zen Kaku Gothic New", serif; }

@-webkit-keyframes fadeIn-dialog { from { opacity: 0; }
  to { opacity: 1; } }

@keyframes fadeIn-dialog { from { opacity: 0; }
  to { opacity: 1; } }

@-webkit-keyframes fadeOut-dialog { from { opacity: 1; }
  to { opacity: 0; } }

@keyframes fadeOut-dialog { from { opacity: 1; }
  to { opacity: 0; } }

.clip-area { -webkit-clip-path: url(#clip-path); clip-path: url(#clip-path); }

#clip-path path { -webkit-transform-origin: center; transform-origin: center; -webkit-transform: scale(0); transform: scale(0); }

.factory { min-height: 100svh; overflow: hidden; }

.wrap-opening { position: absolute; top: 0; left: 0; bottom: 0; width: 100%; height: 100svh; z-index: 6; transition: opacity .1s; background-color: #000; }

.wrap-opening .wrap-video { overflow: hidden; position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }

.wrap-opening .wrap-video video { position: absolute; top: 50%; left: 50%; display: block; width: auto; height: auto; min-width: 100%; min-height: 100%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }

.wrap-opening .wrap-video .btn-skip { background-color: #BE022F; color: #FFFFFF; text-align: center; font-family: "Zen Maru Gothic", serif; -webkit-font-feature-settings: "palt" 1; font-feature-settings: "palt" 1; letter-spacing: 0; text-align: center; border-radius: 30px; padding: 12px 16px; font-size: 1.6rem; line-height: 1.5; font-weight: 700; position: absolute; bottom: 80px; right: 20px; min-width: 140px; }

.wrap-opening .wrap-video .btn-skip.ver2 { bottom: 20px; }

.wrap-opening .wrap-video.ver2 { position: relative; width: 100%; }

.wrap-opening .wrap-video.ver2 video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; -webkit-transform: none; transform: none; }

.factory.opening-end { min-height: 100svh; overflow: visible; }

.factory.opening-end .wrap-opening { -webkit-animation: fadeout-movie 2s forwards; animation: fadeout-movie 2s forwards; pointer-events: none; }

@-webkit-keyframes fadeout-movie { 0% { opacity: 1; }
  100% { opacity: 0; } }

@keyframes fadeout-movie { 0% { opacity: 1; }
  100% { opacity: 0; } }

.laboratory .wrap-school.ver-lab .wrap-hdg .wrap-txt { padding-bottom: 0; }

.laboratory .wrap-school.ver-lab .wrap-hdg .wrap-img { padding: 0 24px; background-color: #FDFDF2; border-radius: 0 0 0 24px; margin-top: 0; }

.laboratory .wrap-school.ver-lab .wrap-hdg .wrap-img img { margin: 0 0 -10%; }

.laboratory .wrap-school.ver-lab .wrap-qa { margin-top: 48px; }

.laboratory .wrap-school.ver-lab .wrap-qa .wrap-q, .laboratory .wrap-school.ver-lab .wrap-qa .wrap-a { margin-top: 32px; }

.laboratory .wrap-school.ver-lab .wrap-qa .wrap-a .wrap-txt + .wrap-txt { margin-top: 16px; }

.laboratory .wrap-school.ver-lab .wrap-qa .txt.ft-l { font-size: 2.0rem; }

.laboratory .wrap-school.ver-lab .wrap-qa .wrap-normal-txt { padding: 0; }

.laboratory .wrap-school.ver-lab .hr-pt1.end, .laboratory .wrap-school.ver-lab .hr-pt2.end { padding-bottom: 76px; }

.laboratory .wrap-school.ver-lab .hr-pt1.end::after, .laboratory .wrap-school.ver-lab .hr-pt2.end::after { display: none; }

.laboratory .wrap-school.ver-lab .hr-pt1.end:before, .laboratory .wrap-school.ver-lab .hr-pt2.end:before { content: ""; display: block; width: 34px; height: 106px; background: transparent url(shonan_laboratory_footer_add01.webp) no-repeat 0 0; background-size: contain; position: absolute; left: 10px; bottom: -36px; }

.laboratory .wrap-school.ver-lab .hr-pt1.end:after, .laboratory .wrap-school.ver-lab .hr-pt2.end:after { content: ""; display: block; width: 80px; height: 106px; background: transparent url(shonan_laboratory_footer_add02.webp) no-repeat 0 0; background-size: contain; position: absolute; right: 10px; bottom: -30px; z-index: 1; -webkit-transform: none; transform: none; -webkit-filter: none; filter: none; }

.laboratory .wrap-school.ver-lab .wrap-pic-ver1 { -webkit-transform: translateY(40px); transform: translateY(40px); transition: 1.2s; opacity: 0; position: relative; margin-top: 32px; }

.laboratory .wrap-school.ver-lab .wrap-pic-ver1::after { content: ""; display: block; width: 40px; height: 77px; background: transparent url(shonan_laboratory_person04.webp) no-repeat 0 0; background-size: contain; position: absolute; left: -10px; bottom: -20px; }

.laboratory .wrap-school.ver-lab .wrap-pic-ver1 img { width: 100%; height: auto; }

.laboratory .wrap-school.ver-lab .wrap-pic-ver1.inview { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

.laboratory .wrap-school.ver-lab .wrap-movie { margin-top: 48px; aspect-ratio: 16 / 9; }

.laboratory .wrap-school.ver-lab .wrap-movie iframe { width: 100%; height: 100%; }

.laboratory .wrap-school.ver-lab .list-lab-flow > li { margin-top: 36px; -webkit-transform: translateY(40px); transform: translateY(40px); opacity: 0; transition: 1.2s; }

.laboratory .wrap-school.ver-lab .list-lab-flow > li.inview { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-img img { max-width: 100%; height: auto; }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt { margin-top: 16px; }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg { display: flex; align-items: center; font-size: 1.6rem; font-weight: 700; line-height: 1.6; width: 100%; padding-right: 32px; position: relative; color: #171D1E; }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg::before, .laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg::after { content: ""; width: 18px; height: 2px; background-color: #BE012F; position: absolute; display: block; border-radius: 2px; right: 3px; top: 50%; margin-top: -1px; transition: .3s; }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg::after { -webkit-transform: rotate(90deg); transform: rotate(90deg); }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg span { min-width: 32px; height: 32px; background-color: #920021; border-radius: 50%; display: flex; align-items: center; justify-content: center; line-height: 1; font-family: "Barlow", serif; color: #fff; font-weight: bold; margin-right: 16px; }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg.accordionActive::after { -webkit-transform: rotate(0deg); transform: rotate(0deg); }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt dd { display: none; padding-left: 48px; }

.laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt dd.accordionActive { display: block; }

.laboratory .wrap-school.ver-lab .list-lab-flow .txt { margin-top: 16px; font-size: 1.4rem; line-height: 1.6; }

.laboratory .wrap-school.ver-lab .wrap-normal-txt { -webkit-transform: translateY(40px); transform: translateY(40px); transition: 1.2s; opacity: 0; margin-top: 32px; padding: 0 24px; }

.laboratory .wrap-school.ver-lab .wrap-normal-txt .txt { font-size: 1.4rem; line-height: 1.8; margin-top: 32px; color: #3F484A; }

.laboratory .wrap-school.ver-lab .wrap-normal-txt.inview { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

.laboratory .wrap-school.ver-lab .wrap-pic-ver2 { -webkit-transform: translateY(40px); transform: translateY(40px); transition: 1.2s; opacity: 0; margin-top: 48px; padding: 0 24px; }

.laboratory .wrap-school.ver-lab .wrap-pic-ver2.inview { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

.laboratory .wrap-school.ver-lab .wrap-pic-ver2 dt { font-size: 1.6rem; line-height: 1.8; color: #3F484A; font-weight: 700; }

.laboratory .wrap-school.ver-lab .wrap-pic-ver2 dd { margin-top: 16px; font-size: 1.4rem; line-height: 1.8; }

.laboratory .wrap-school.ver-lab .wrap-pic-ver2 .wrap-img { margin: 32px -18px 0; }

.laboratory .wrap-school.ver-lab .wrap-pic-ver2 .wrap-img img { max-width: 100%; }

.laboratory .wrap-school.ver-lab .wrap-finish { margin-top: 48px; padding: 64px 0 48px; min-height: 686px; background: transparent url(shonan_laboratory_bg01_sp.webp) no-repeat center top; background-size: cover; -webkit-transform: translateY(40px); transform: translateY(40px); transition: 1.2s; opacity: 0; }

.laboratory .wrap-school.ver-lab .wrap-finish .txt-finish { text-align: center; padding: 0 24px; font-family: "Zen Maru Gothic", serif; font-size: 2.4rem; line-height: 1.6; color: #BE012F; }

.laboratory .wrap-school.ver-lab .wrap-finish .wrap-product { text-align: center; margin-top: 64px; }

.laboratory .wrap-school.ver-lab .wrap-finish .wrap-product img { width: 100%; max-width: 280px; }

.laboratory .wrap-school.ver-lab .wrap-finish .wrap-qa { margin-top: 84px; }

.laboratory .wrap-school.ver-lab .wrap-finish.inview { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

.laboratory .wrap-school .wrap-slider-laboratory { margin: 16px -8px 48px; position: relative; -webkit-transform: translateY(40px); transform: translateY(40px); transition: 1.2s; opacity: 0; }

.laboratory .wrap-school .wrap-slider-laboratory.inview { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

.laboratory .wrap-school .wrap-slider-laboratory::before { content: ""; display: block; width: 36px; height: 99px; background: transparent url(shonan_laboratory_person05.webp) no-repeat 0 0; background-size: contain; position: absolute; left: -5px; bottom: -38px; z-index: 1; }

.laboratory .wrap-school .wrap-slider-laboratory::after { content: ""; display: block; width: 56px; height: 80px; background: transparent url(shonan_laboratory_person06.webp) no-repeat 0 0; background-size: contain; position: absolute; right: -5px; bottom: -38px; z-index: 1; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__track { margin: 32px 0 0; background: transparent url(shonan_laboratory_slide_bg_sp.webp) no-repeat center top; background-size: 100% 100%; border-radius: 24px; min-height: 754px; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__slide { width: 100%; padding: 32px; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__slide img { width: 100%; }

.laboratory .wrap-school .wrap-slider-laboratory .wrap-img img { display: block; }

.laboratory .wrap-school .wrap-slider-laboratory .wrap-img img + img { margin-top: 12px; }

.laboratory .wrap-school .wrap-slider-laboratory .wrap-txt { margin-top: 16px; }

.laboratory .wrap-school .wrap-slider-laboratory .wrap-txt dt { font-family: "Zen Maru Gothic", serif; font-size: 2.4rem; line-height: 1.6; color: #920021; font-weight: 700; display: flex; justify-content: space-between; align-items: flex-end; }

.laboratory .wrap-school .wrap-slider-laboratory .wrap-txt dt span { font-size: 1.2rem; color: #3F484A; font-family: 'Noto Sans JP', sans-serif; font-weight: 400; }

.laboratory .wrap-school .wrap-slider-laboratory .wrap-txt dd { margin-top: 16px; font-size: 1.4rem; line-height: 1.8; color: #3F484A; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__arrows { position: absolute; display: flex; justify-content: space-between; top: 57%; -webkit-transform: translateY(-50%); transform: translateY(-50%); width: 100%; pointer-events: none; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__arrow { position: relative; width: 48px; height: 48px; background: transparent url(shonan_laboratory_slide_arrow02.webp) no-repeat 0 0; background-size: contain; font-size: 0; pointer-events: auto; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__arrow--prev { left: -24px; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__arrow--next { right: -24px; -webkit-transform: scale(-1, 1); transform: scale(-1, 1); }

.laboratory .wrap-school .wrap-slider-laboratory .splide__pagination { display: flex; flex-wrap: wrap; margin: 0; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li { width: 50%; text-align: center; padding: 0 8px; margin-top: 16px; height: 156px; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li button { display: block; width: 100%; height: 100%; position: relative; background: center center/contain no-repeat; }

.laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li button:after { display: block; content: ""; position: absolute; width: 32px; height: 32px; right: 0; bottom: 0; background: url(shonan_laboratory_slide_arrow01.webp) no-repeat 0 0; background-size: contain; -webkit-transform: rotate(90deg); transform: rotate(90deg); }

.laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li:nth-child(1) button { background-image: url(shonan_laboratory_slide_btn01.webp); }

.laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li:nth-child(2) button { background-image: url(shonan_laboratory_slide_btn02.webp); }

.laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li:nth-child(3) button { background-image: url(shonan_laboratory_slide_btn03.webp); }

.laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li:nth-child(4) button { background-image: url(shonan_laboratory_slide_btn04.webp); }

.laboratory .footer { position: relative; z-index: 1; }

.map .main { padding-bottom: 80px; }

.map .wrap-school .wrap-hdg .wrap-img { margin-top: -14%; }

.map .wrap-school .wrap-hdg .h1-school { font-weight: 400; }

.map .wrap-school .wrap-hdg .wrap-txt { padding-bottom: 50px; }

.map .wrap-school .no-hr { padding-top: 10px; margin-top: -10px; position: relative; background-color: #FFEDEC; }

.map .wrap-school .hdg-period .txt-period { font-weight: 400; color: #171D1E; }

.map .wrap-school .hdg-period.pt1 .inner:before { width: 81px; height: 59px; background-image: url(shonan_map_img02.webp); background-size: contain; }

.map .wrap-school .hdg-period.pt1 .inner:after { width: 159px; height: 106px; right: -10px; bottom: -42px; background-image: url(shonan_map_img03.webp); background-size: contain; }

.map .wrap-school .hdg-period.pt2 .inner:before { content: ""; display: block; width: 64px; height: 68px; position: absolute; left: 16px; top: -28px; background: transparent url(shonan_beautyschool_img06.webp) no-repeat center center; background-size: contain; transition: 1.5s; -webkit-transform: translateX(-100px); transform: translateX(-100px); }

.map .wrap-school .hdg-period.pt2 .inner:after { content: ""; display: block; width: 144px; height: 74px; position: absolute; right: -16px; bottom: -30px; background: transparent url(shonan_beautyschool_img07.webp) no-repeat center center; background-size: contain; transition: 1.5s; transition-delay: .3s; -webkit-transform: translateX(50px); transform: translateX(50px); }

.map .wrap-school .hdg-period.pt3 .inner:before { content: ""; display: block; width: 64px; height: 68px; position: absolute; left: 16px; top: -28px; background: transparent url(shonan_laboratory_person07.webp) no-repeat center center; background-size: contain; transition: 1.5s; -webkit-transform: translateX(-100px); transform: translateX(-100px); }

.map .wrap-school .hdg-period.pt3 .inner:after { content: ""; display: block; width: 144px; height: 74px; position: absolute; right: -6px; bottom: 3px; background: transparent url(shonan_laboratory_person08.webp) no-repeat center center; background-size: contain; transition: 1.5s; transition-delay: .3s; -webkit-transform: translateX(50px); transform: translateX(50px); }

.map .wrap-school .hdg-period.inview.pt1 .inner:before, .map .wrap-school .hdg-period.inview.pt2 .inner:before, .map .wrap-school .hdg-period.inview.pt3 .inner:before { -webkit-transform: translateX(0); transform: translateX(0); }

.map .wrap-school .hdg-period.inview.pt1 .inner:after, .map .wrap-school .hdg-period.inview.pt2 .inner:after, .map .wrap-school .hdg-period.inview.pt3 .inner:after { -webkit-transform: translateX(0); transform: translateX(0); }

.map .wrap-school .hdg-period .wrap-qa { margin-top: 32px; }

.map .wrap-school .hdg-period .wrap-qa .txt-st { font-size: 1.6rem; line-height: 1.6; }

.map .wrap-school .wrap-qa { margin-top: 32px; }

.map .wrap-school .wrap-qa .txt-st { font-size: 1.6rem; line-height: 1.6; font-family: "Zen Maru Gothic", serif; font-weight: 500; }

.map .wrap-school .wrap-qa .txt-st.ver-s { margin-top: 16px; font-size: 1.4rem; }

.map .wrap-school .wrap-qa .wrap-a { margin-top: 32px; }

.map .wrap-school .wrap-qa .wrap-txt + .wrap-txt.inner-img1 { margin-top: 20px; }

.map .wrap-school .wrap-qa .wrap-txt + .wrap-txt.inner-img1 .txt { position: relative; }

.map .wrap-school .wrap-qa .wrap-txt + .wrap-txt.inner-img1 .txt:after { content: ""; display: block; margin: 20px auto 0; width: 120px; height: 120px; background: url(shonan_map_img11.webp) no-repeat 0 0; background-size: contain; }

.map .wrap-school .wrap-qa .wrap-txt.inner-img2:after { content: ""; display: block; margin: 0; width: 84px; height: 78px; background: url(shonan_map_img12.webp) no-repeat 0 0; background-size: contain; position: absolute; right: 0; bottom: -30px; }

.map .wrap-recommend-content { margin-top: 70px; }

.map .wrap-recommend-content .list-tab { display: flex; }

.map .wrap-recommend-content .list-tab > li { width: 50%; display: flex; }

.map .wrap-recommend-content .list-tab > li .course1, .map .wrap-recommend-content .list-tab > li .course2 { padding: 16px; text-align: center; font-family: "Zen Maru Gothic", serif; font-size: 1.6rem; width: 100%; color: #171D1E; }

.map .wrap-recommend-content .list-tab > li .course1 span, .map .wrap-recommend-content .list-tab > li .course2 span { padding: 0 30px; position: relative; }

.map .wrap-recommend-content .list-tab > li .course1.tabActive span::before, .map .wrap-recommend-content .list-tab > li .course2.tabActive span::before { content: ""; display: block; width: 24px; height: 24px; background: transparent url(shonan_map_icon01.webp) no-repeat center center; background-size: contain; position: absolute; left: 0; top: 0; }

.map .wrap-recommend-content .list-tab > li .course1 { border-radius: 0 24px 0 0; background-color: #5CC4B0; }

.map .wrap-recommend-content .list-tab > li .course2 { border-radius: 24px 0 0 0; background-color: #FFD675; }

.map .wrap-recommend-content .wrap-recommend-detail { display: none; }

.map .wrap-recommend-content .wrap-recommend-detail.tabActive { display: block; }

.map .wrap-recommend-content .wrap-recommend-detail.no-tab { display: block; }

.map .wrap-recommend-content .inner { padding: 32px 20px 46px; border-radius: 0 0 32px 32px; }

.map .wrap-recommend-content .inner::after { content: ""; display: block; width: 54px; height: 54px; background: transparent url(shonan_index_land_person01.webp) no-repeat 0 0; background-size: contain; z-index: 2; position: absolute; right: 10px; bottom: 82px; }

.map .wrap-recommend-content .inner.bg1 { background-color: #E3FFEE; }

.map .wrap-recommend-content .inner.bg1 .list-shop::after { content: ""; display: block; width: 115px; height: 84px; background: transparent url(shonan_map_img05.webp) no-repeat 0 0; background-size: contain; margin: -64px 50px -90px auto; z-index: 2; position: relative; }

.map .wrap-recommend-content .inner.bg1 .txt-st { margin-top: 94px; }

.map .wrap-recommend-content .inner.bg2 { background-color: #FDFDF2; }

.map .wrap-recommend-content .inner.bg2 .list-shop::after { content: ""; display: block; width: 169px; height: 79px; background: transparent url(shonan_map_img06.webp) no-repeat 0 0; background-size: contain; margin: -28px 26px -90px auto; z-index: 2; position: relative; -webkit-transform: translateY(-35px); transform: translateY(-35px); }

.map .wrap-recommend-content .inner.bg2 .txt-st { margin-top: 63px; }

.map .wrap-recommend-content .inner.bg3 { padding: 0 20px; }

.map .wrap-recommend-content .inner.bg3::after { display: none; }

.map .wrap-recommend-content .inner.bg3 .wrap-img { margin-top: -40px; }

.map .wrap-recommend-content .inner .txt-st { margin-top: 10px; line-height: 1.6; font-family: "Zen Maru Gothic", serif; font-weight: 500; }

.map .wrap-recommend-content .inner .txt-st.ver-s { font-size: 1.4rem; }

.map .wrap-recommend-content .wrap-process { display: flex; flex-direction: column; }

.map .wrap-recommend-content .wrap-process .wrap { margin: auto; }

.map .wrap-recommend-content .hdg { font-family: "Zen Maru Gothic", serif; font-size: 1.8rem; font-weight: 700; color: #920021; }

.map .wrap-recommend-content .list-process { margin-top: 16px; }

.map .wrap-recommend-content .list-process > li .txt-process { display: flex; align-items: flex-start; padding-top: 12px; }

.map .wrap-recommend-content .list-process > li:first-child .txt-process { padding-top: 0; }

.map .wrap-recommend-content .list-process > li:first-child .wrap-step::before { display: none; }

.map .wrap-recommend-content .list-process > li:first-child .txt-step { background-color: #FFB4AB; color: #920021; }

.map .wrap-recommend-content .list-process .wrap-step { display: flex; justify-content: center; width: 114px; position: relative; z-index: 2; }

.map .wrap-recommend-content .list-process .wrap-step::before { content: ""; display: block; background-color: #FFB4AB; width: 6px; position: absolute; top: -12px; left: 50%; margin-left: -3px; height: 100%; z-index: 0; bottom: 0; }

.map .wrap-recommend-content .list-process .txt-step { font-family: "Barlow", serif; display: flex; background-color: #920021; border-radius: 100px; padding: 8px; font-weight: bold; font-size: 1.4rem; color: #fff; min-width: 32px; min-height: 32px; justify-content: center; align-items: center; position: relative; z-index: 2; }

.map .wrap-recommend-content .list-process .txt-step.wide { width: 100%; }

.map .wrap-recommend-content .list-process .txt-detail { font-size: 1.4rem; padding: 4px 0 0 27px; line-height: 1.6; width: calc(100% - 114px); }

.map .wrap-recommend-content .wrap-img { padding: 0; margin-top: 32px; }

.map .wrap-recommend-content .wrap-img img { width: 100%; height: auto; }

.map .list-shop { counter-reset: number; }

.map .list-shop > li { margin-top: 16px; }

.map .list-shop > li .txt-shop-name { display: flex; font-size: 1.8rem; line-height: 1.2; font-weight: 500; }

.map .list-shop > li .txt-shop-name::before { counter-increment: number; content: counter(number); display: inline-flex; justify-content: center; align-items: center; vertical-align: top; width: 32px; height: 32px; flex-shrink: 0; background-color: #920021; color: #fff; border-radius: 50%; line-height: 1; font-size: 1.8rem; font-weight: bold; font-family: "Barlow", serif; margin-right: 10px; flex-shrink: 0; }

.map .list-shop > li .txt-shop-name .categoy { display: inline-block; vertical-align: middle; font-size: 1.0rem; list-style: 1; background: #fff; border: 2px solid #920021; border-radius: 20px; color: #920021; padding: 1px 6px 2px; margin-top: -5px; }

.map .list-shop > li .txt-shop-name .txt { padding-right: 6px; }

.map .list-shop > li .txt-desc { font-size: 1.6rem; line-height: 1.6; margin-top: 24px; }

.map .list-shop > li .txt-address { margin-top: 16px; padding-left: 28px; position: relative; font-size: 1.4rem; line-height: 1.6; }

.map .list-shop > li .txt-address::before { content: ""; display: block; width: 24px; height: 24px; background: transparent url(shonan_map_icon02.webp) no-repeat 0 0; background-size: contain; position: absolute; left: 0; top: 0; }

.map .list-shop > li .txt-link { margin-top: 12px; font-size: 1.6rem; line-height: 1.6; }

.map .list-shop > li .txt-link a { color: #BE012F; text-decoration: underline; }

.map .list-shop .wrap-detail { background: #FFDAD9; border-radius: 24px; padding: 32px; width: 100%; }

.map .hdg-lv3-map { letter-spacing: 0; font-weight: 400; font-size: 1.6rem; line-height: 1.5; margin-top: 60px; margin-bottom: 32px; border-radius: 100px; text-align: center; padding: 12px 12px 13px; position: relative; background: linear-gradient(90deg, #ffdad9 0%, #ffdad9 49%, #FDFDF2 90%, #FDFDF2 100%); color: #920021; font-family: "Zen Maru Gothic", serif; }

.map .hdg-lv3-map::before { content: ""; display: block; width: 42px; height: 54px; position: absolute; left: 3px; top: -38px; background: transparent url(shonan_map_img07.webp) no-repeat 0 0; background-size: contain; }

.map .hdg-lv3-map::after { content: ""; display: block; width: 42px; height: 30px; position: absolute; right: 10px; top: -15px; background: transparent url(shonan_map_img08.webp) no-repeat 0 0; background-size: contain; }

.map .hdg-lv3-map.normal::before, .map .hdg-lv3-map.normal::after { display: none; }

.map .wrap-column-row2 .inner { margin-top: 32px; }

.map .wrap-column-row2 .txt-st { font-weight: 500; }

.map .wrap-column-row2 .txt-st.add { margin-top: 16px; font-weight: 400; line-height: 1.6; }

.map .wrap-column-row2 .wrap-img { margin-top: 16px; }

.map .wrap-column-row2 .wrap-img img { width: 100%; border-radius: 24px; }

.map .txt.hint { text-align: center; margin: 48px 0; font-size: 1.6rem !important; }

.map .txt.hint a { color: #920021; font-weight: 500; }

.map .wrap-ans { margin: 52px -24px 0; padding: 27px 24px; position: relative; overflow: hidden; }

.map .wrap-ans .hdg-lv3-map { margin: 0; padding: 24px; }

.map .wrap-ans:after { content: ""; width: 100%; display: block; position: absolute; top: 0; bottom: 0; left: -15px; right: -50px; background: transparent url(shonan_map_bg01.webp) no-repeat 0 0; background-size: 120% auto; z-index: 2; }

.map .wrap-img.inner-map img { width: 100%; }

.map .wrap-btn-sp1 { margin-top: 74px; margin-bottom: 10px; }

.map .wrap-btn-sp1 a { display: block; padding: 32px; text-align: center; background-color: #005CA8; border-radius: 24px; color: #fff; font-family: "Zen Maru Gothic", serif; position: relative; }

.map .wrap-btn-sp1 a:before, .map .wrap-btn-sp1 a:after { content: ""; display: block; width: 97px; height: 40px; background: transparent url(shonan_map_img13.webp) no-repeat 0 0; background-size: contain; position: absolute; top: -10px; pointer-events: none; }

.map .wrap-btn-sp1 a:before { left: 20px; }

.map .wrap-btn-sp1 a:after { right: 20px; -webkit-transform: scale(-1, 1); transform: scale(-1, 1); }

.map .hdg-lv3-map, .map .wrap-column-row2, .map .wrap-ans, .map .wrap-img.inner-map, .map .wrap-btn-sp1 { -webkit-transform: translateY(40px); transform: translateY(40px); transition: 1.2s; opacity: 0; }

.map .hdg-lv3-map.inview, .map .wrap-column-row2.inview, .map .wrap-ans.inview, .map .wrap-img.inner-map.inview, .map .wrap-btn-sp1.inview { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

@media print, all and (min-width: 768px) { body { font-size: 1.8rem; } .main { padding: 0 0 96px; } .wrap-contents-pt1 { max-width: 1090px; margin: auto; } .wrap-contents-pt2 { max-width: 910px; margin: auto; } .footer { padding: 64px 32px 32px; }
  .footer .footer-logo img { height: 30px; }
  .footer .footer-logo .lang-jp { font-size: 1.6rem; padding: 12px 16px; border-radius: 40px; }
  .footer .copyright { margin-top: 32px; } .top-page .header { min-height: 96px; } .txt-st { font-size: 1.5rem; }
  .txt-st.ft-l { font-size: 2.4rem; }
  .txt-st.ft-s { font-size: 1.3rem; }
  .txt-st + .txt-st { margin-top: 16px; } .hdg-lv1 { font-size: 6rem; margin-bottom: 85px; }
  .hdg-lv1 .lang-ver1 { font-size: 2.4rem; } .wrap-btn .btn-type1 { padding: 12px 30px; opacity: 1; transition: opacity .3s; }
  .wrap-btn .btn-type1:hover { opacity: .7; } .top-page:has(.building01:hover) .bg-dark, .top-page:has(.building02:hover) .bg-dark, .top-page:has(.building03:hover) .bg-dark, .top-page:has(.building04:hover) .bg-dark { opacity: 1; z-index: 5; }
  .top-page:has(.building01:hover) .header, .top-page:has(.building02:hover) .header, .top-page:has(.building03:hover) .header, .top-page:has(.building04:hover) .header { z-index: 10; position: relative; }
  .top-page:has(.building01:hover) .building01 { z-index: 6; }
  .top-page:has(.building02:hover) .building02 { z-index: 6; }
  .top-page:has(.building03:hover) .building03 { z-index: 6; }
  .top-page:has(.building04:hover) .building04 { z-index: 6; }
  .top-page .main { padding: 16px 40px 100px; position: relative; }
  .top-page .wrap-speech-bubble { position: absolute; display: block; text-align: center; z-index: 4; width: 100%; opacity: 0; transition: .8s; -webkit-transform: translateY(10px); transform: translateY(10px); }
  .top-page .wrap-speech-bubble.ver-school { top: 8.5%; left: 0; }
  .top-page .wrap-speech-bubble.ver-factory { top: 26.5%; left: 18%; }
  .top-page .wrap-speech-bubble.ver-shopping { top: 19.5%; left: -18%; }
  .top-page .wrap-speech-bubble.ver-map { top: 6.5%; left: 12%; }
  .top-page .wrap-speech-bubble .speech-bubble { position: relative; display: inline-block; margin-bottom: 20px; padding: 16px 16px; border: 3px solid #000000; border-radius: 9999px; background-color: #ffffff; font-family: "Zen Maru Gothic", serif; padding: 12px 24px; line-height: 1.5; font-size: 1.6rem; font-weight: 500; color: #000000; white-space: nowrap; }
  .top-page .wrap-speech-bubble .speech-bubble::before { content: ""; position: absolute; bottom: 0; left: 50%; border-style: solid; border-width: 20px 10px 0 10px; border-color: #000000 transparent transparent; translate: -50% 100%; }
  .top-page .wrap-speech-bubble .speech-bubble::after { content: ""; position: absolute; bottom: 0; left: 50%; border-style: solid; border-width: 13.3px 6.6px 0 6.6px; border-color: #ffffff transparent transparent; translate: -50% 100%; }
  .top-page .pointer:hover .wrap-speech-bubble { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); z-index: 20; }
  .top-page .pointer:hover:after { opacity: 0; }
  .top-page .bg-dark { background: rgba(0, 0, 0, 0.4); top: 0; bottom: 0; display: block; width: 100%; position: absolute; opacity: 0; pointer-events: none; transition: .8s; } .top-page .btn-mode-change { position: absolute; top: 4.4%; left: 80%; width: 8vw; height: 8vw; transition: .5s; }
  .top-page .btn-mode-change:hover { -webkit-transform: scale(1.3); transform: scale(1.3); } .wrap-map { overflow: hidden; border-radius: 32px; height: auto; width: calc(100vw - 80px); }
  .wrap-map .wrap-map-inner { position: static; width: 100%; height: 100%; overflow: hidden; }
  .wrap-map .all-bg { width: 100%; height: 100%; -webkit-transform: none; transform: none; }
  .wrap-map .all-bg img { width: 100%; height: 100%; } .wrap-counter { right: 5%; top: 3%; width: 6em; }
  .wrap-counter > div { font-size: 2rem; min-width: 80px; } .wrap-factory { margin-top: 0; width: calc(100vw - 80px); padding: 0; border-radius: 32px; overflow: hidden; position: relative; } .wrap-factory .wrap-bg img.pc { display: block; }
  .wrap-factory .wrap-bg img.sp { display: none; } .wrap-factory .h1-factory { font-size: 4.8rem; } .wrap-factory .txt-lead { margin-top: 24px; } .wrap-factory .wrap-hdg { position: absolute; z-index: 4; bottom: 9%; left: 10%; width: 380px; padding: 0; }
  .wrap-factory .wrap-hdg .h1-factory, .wrap-factory .wrap-hdg .txt-lead { position: relative; } .wrap-factory .link-btn > a:hover, .wrap-factory .link-btn > button:hover { opacity: .7; }
  .wrap-factory .link-btn > a:hover:before, .wrap-factory .link-btn > button:hover:before { opacity: none; } .wrap-factory .content1 .link-btn { right: 12%; top: 12%; } .wrap-factory .content2 .link-btn { right: 30.5%; top: 80%; } .wrap-factory .content3 .link-btn { left: 27.5%; top: 38%; } .wrap-factory .content4 .link-btn { left: 8.5%; bottom: auto; top: 7%; }
  .wrap-factory .content4 .link-btn a, .wrap-factory .content4 .link-btn button { padding-left: 40px; }
  .wrap-factory .content4 .link-btn a:before, .wrap-factory .content4 .link-btn button:before { width: 148px; height: 83px; left: -50px; top: 16px; } .school, .laboratory { min-width: 1240px; } .wrap-school { padding-top: 26px; } .wrap-school .wrap-hdg { width: calc(100% - 40px); margin: 0 0 56px auto; display: flex; justify-content: space-between; background-color: #FDFDF2; border-radius: 24px 0 0 24px; }
  .wrap-school .wrap-hdg .wrap-txt { padding: 20px 24px 20px 98px; width: calc(100% - 670px); border-radius: 24px 0 0 24px; display: flex; align-items: center; }
  .wrap-school .wrap-hdg .wrap-img { width: 670px; margin: -45px 0 -56px; position: relative; }
  .wrap-school .wrap-hdg .wrap-img:after { content: ""; display: block; position: absolute; left: 0; top: 45px; bottom: 56px; width: 162px; background: linear-gradient(90deg, #fdfdf2 0%, #fdfdf2 23%, rgba(9, 9, 121, 0) 63%, rgba(0, 0, 0, 0) 100%); }
  .wrap-school .wrap-hdg .h1-school { font-size: 4.8rem; } .wrap-school .list-page-anchor { margin: 0 auto; padding-top: 64px; max-width: 1090px; display: flex; justify-content: space-between; position: relative; z-index: 2; }
  .wrap-school .list-page-anchor > li { display: flex; margin-top: 0; width: 18.3%; }
  .wrap-school .list-page-anchor a { display: flex; border-radius: 24px; width: 100%; transition: .3s; }
  .wrap-school .list-page-anchor a:after { right: 16px; bottom: 16px; }
  .wrap-school .list-page-anchor a.icon1::before { width: 48px; height: 86px; right: 23px; top: -48px; }
  .wrap-school .list-page-anchor a.icon2::before { width: 104px; height: 63px; right: -38px; top: -32px; }
  .wrap-school .list-page-anchor a:hover { -webkit-transform: translateY(5px); transform: translateY(5px); }
  .wrap-school .list-page-anchor .no { font-size: 1.6rem; top: -26px; }
  .wrap-school .list-page-anchor .no span { font-size: 6.4rem; }
  .wrap-school .list-page-anchor .inner { padding: 58px 24px 48px 24px; width: 100%; }
  .wrap-school .list-page-anchor .inner:before { -webkit-filter: blur(18px); filter: blur(18px); } .wrap-school .hdg-period { flex: 1; margin-left: calc(50% - 50vw); margin-right: 0; font-size: 3.2rem; }
  .wrap-school .hdg-period .inner { max-width: 910px; display: block; margin-left: auto; padding: 48px 0; }
  .wrap-school .hdg-period .txt-period { font-size: 1.6rem; }
  .wrap-school .hdg-period.pt1 .inner:before { width: 120px; height: 128px; left: -166px; top: -35px; }
  .wrap-school .hdg-period.pt1 .inner:after { width: 232px; height: 120px; right: -143px; bottom: -30px; }
  .wrap-school .hdg-period.pt2 .inner:before { width: 120px; height: 128px; left: -166px; top: -35px; }
  .wrap-school .hdg-period.pt2 .inner:after { width: 232px; height: 120px; right: -143px; bottom: -30px; }
  .wrap-school .hdg-period.pt3 .inner:before { width: 120px; height: 128px; left: -166px; top: -35px; }
  .wrap-school .hdg-period.pt3 .inner:after { width: 232px; height: 120px; right: -143px; bottom: -30px; } .wrap-school .wrap-qa { margin-top: 110px; padding: 0; }
  .wrap-school .wrap-qa .txt { font-size: 1.8rem; }
  .wrap-school .wrap-qa .wrap-q, .wrap-school .wrap-qa .wrap-a { margin-top: 80px; }
  .wrap-school .wrap-qa .wrap-q .inner, .wrap-school .wrap-qa .wrap-a .inner { width: calc(100% - 186px); }
  .wrap-school .wrap-qa .wrap-q .inner .wrap-txt, .wrap-school .wrap-qa .wrap-a .inner .wrap-txt { padding: 32px 20px 32px 32px; }
  .wrap-school .wrap-qa .wrap-q .inner .wrap-txt:has(.txt-q), .wrap-school .wrap-qa .wrap-q .inner .wrap-txt:has(.txt-a), .wrap-school .wrap-qa .wrap-a .inner .wrap-txt:has(.txt-q), .wrap-school .wrap-qa .wrap-a .inner .wrap-txt:has(.txt-a) { padding-top: 40px; }
  .wrap-school .wrap-qa .wrap-q .inner .wrap-txt:before, .wrap-school .wrap-qa .wrap-a .inner .wrap-txt:before { right: -27px; }
  .wrap-school .wrap-qa .wrap-q .inner .wrap-txt + .wrap-txt, .wrap-school .wrap-qa .wrap-a .inner .wrap-txt + .wrap-txt { margin-top: 64px; }
  .wrap-school .wrap-qa .wrap-q .wrap-img, .wrap-school .wrap-qa .wrap-a .wrap-img { width: 186px; padding: 0 0 0 50px; }
  .wrap-school .wrap-qa .wrap-q .wrap-img img, .wrap-school .wrap-qa .wrap-a .wrap-img img { width: 100%; }
  .wrap-school .wrap-qa .wrap-q .txt-q, .wrap-school .wrap-qa .wrap-q .txt-a, .wrap-school .wrap-qa .wrap-a .txt-q, .wrap-school .wrap-qa .wrap-a .txt-a { left: 32px; top: -40px; font-size: 6.4rem; }
  .wrap-school .wrap-qa .wrap-a .inner .wrap-txt:before { left: -27px; }
  .wrap-school .wrap-qa .wrap-a .wrap-img { padding: 0 50px 0 0; } .wrap-school .hr-pt1, .wrap-school .hr-pt2 { padding-top: 84px; }
  .wrap-school .hr-pt1:after, .wrap-school .hr-pt2:after { height: 180px; background-size: 100% 180px; } .wrap-school .hr-pt1 + .hr-pt2, .wrap-school .hr-pt2 + .hr-pt1 { margin-top: -50px; } .wrap-school .hr-pt2 + .hr-pt2 { margin-top: -130px; }
  .wrap-school .hr-pt2 + .hr-pt2 .wrap-qa { margin-top: 0; }
  .wrap-school .hr-pt2 + .hr-pt2 .wrap-q { margin-top: 64px; } .wrap-school .link-btn { padding: 64px 0 96px; font-size: 2.0rem; }
  .wrap-school .link-btn a { margin: auto; padding: 18px; max-width: 348px; opacity: 1; transition: opacity .3s; }
  .wrap-school .link-btn a:hover { opacity: .7; } .wrap-quiz { width: calc(100vw - 80px); padding: 40px 40px 48px; border-radius: 24px; }
  .wrap-quiz .txt-q1 { font-size: 6.4rem; }
  .wrap-quiz .txt-q2 { font-size: 2.4rem; } .wrap-slider-quiz .splide__slide { border-radius: 32px; }
  .wrap-slider-quiz .wrap-quiz-txt { padding: 32px 32px 32px 64px; border-radius: 32px 0 0 32px; width: 50%; min-height: 432px; }
  .wrap-slider-quiz .wrap-quiz-btn { width: 50%; padding: 60px; border-radius: 0 32px 32px 0; margin: 0; display: flex; align-items: center; justify-content: center; }
  .wrap-slider-quiz .wrap-quiz-btn .inner { width: 100%; display: flex; justify-content: space-between; }
  .wrap-slider-quiz .wrap-quiz-btn label { width: 185px; height: 185px; margin: 0 4px; }
  .wrap-slider-quiz .wrap-quiz-btn label:after { width: 96px; height: 96px; background-size: contain; }
  .wrap-slider-quiz .wrap-quiz-btn label span { right: 12px; top: auto; bottom: 12px; margin-top: -12px; }
  .wrap-slider-quiz .wrap-quiz-btn label input:checked + span { background-image: url(shonan_quiz_checked.webp); }
  .wrap-slider-quiz .wrap-quiz-btn label.yes:after { background-image: url(shonan_quiz_yes.webp); }
  .wrap-slider-quiz .wrap-quiz-btn label.no:after { background-image: url(shonan_quiz_no.webp); }
  .wrap-slider-quiz .wrap-quiz-btn label:has(input:checked) { background-color: #BF002E; }
  .wrap-slider-quiz .wrap-quiz-btn label:has(input:checked):after { -webkit-filter: brightness(0) saturate(100%) invert(96%) sepia(98%) saturate(16%) hue-rotate(319deg) brightness(105%) contrast(100%); filter: brightness(0) saturate(100%) invert(96%) sepia(98%) saturate(16%) hue-rotate(319deg) brightness(105%) contrast(100%); }
  .wrap-slider-quiz .slider-controls { display: flex; justify-content: space-between; align-items: center; margin: 32px auto 0; padding: 0; max-width: 1092px; }
  .wrap-slider-quiz .slider-controls > .inner { display: flex; align-items: center; width: calc(100% - 260px); }
  .wrap-slider-quiz .slider-controls .splide__arrows { width: 144px; }
  .wrap-slider-quiz .slider-controls .splide__arrows .splide__arrow { width: 64px; height: 64px; opacity: 1; transition: opacity .3s; }
  .wrap-slider-quiz .slider-controls .splide__arrows .splide__arrow:hover { opacity: .7; }
  .wrap-slider-quiz .slider-controls .txt-slider-current { position: static; margin: 0; }
  .wrap-slider-quiz .slider-controls .btn-scoring { width: 255px; }
  .wrap-slider-quiz .slider-controls .btn-scoring button { opacity: 1; -webkit-transform: opacity .3s; transform: opacity .3s; }
  .wrap-slider-quiz .slider-controls .btn-scoring button:not(:disabled):hover { opacity: .7; }
  .wrap-slider-quiz .wrap-splide__pagination { margin: auto 36px auto 54px; text-align: center; }
  .wrap-slider-quiz .splide__pagination { display: inline-block; white-space: nowrap; }
  .wrap-slider-quiz .splide__pagination > li { margin-right: 40px; position: relative; }
  .wrap-slider-quiz .splide__pagination > li:last-child { margin-right: 0; }
  .wrap-slider-quiz .splide__pagination > li::before { content: ''; display: block; width: 50px; border-top: 6px solid #fff; position: absolute; left: 90%; top: 50%; -webkit-transform: translateY(-50%); transform: translateY(-50%); }
  .wrap-slider-quiz .splide__pagination > li:last-child::before { display: none; }
  .wrap-slider-quiz .splide__pagination > li.viewed:before { border-top: 6px solid #BF002E; }
  .wrap-slider-quiz .splide__pagination__page { width: 20px; height: 20px; background-color: #fff; border-radius: 50%; position: relative; z-index: 1; }
  .wrap-slider-quiz .answered .splide__pagination__page { background-color: #BF002E; background-image: url(shonan_quiz_answerd.webp); background-repeat: no-repeat; background-position: center center; background-size: 12px 8px; }
  .wrap-slider-quiz .splide__pagination__page { width: 20px; height: 20px; background-color: #fff; border-radius: 50%; position: relative; z-index: 1; width: 20px; height: 20px; background-color: #fff; border-radius: 50%; }
  .wrap-slider-quiz .splide__pagination__page.is-active { background-color: #000; } .wrap-slider-quiz .splide__slide { max-width: 1092px; width: 90%; } .wrap-passed { overflow: hidden; padding: 0 40px; }
  .wrap-passed .hdg-quiz-result { font-size: 3.2rem; }
  .wrap-passed .wrap-bg { padding: 330px 40px 80px; border-radius: 24px; }
  .wrap-passed .list-answer > li { padding: 48px 0 30px; font-size: 1.8rem; }
  .wrap-passed .list-answer .wrap-question-txt { font-size: 2.0rem; color: #3F484A; font-weight: 800; line-height: 1.5; display: flex; }
  .wrap-passed .list-answer .wrap-question-txt .no { font-size: 2.4rem; width: 56px; }
  .wrap-passed .list-answer .wrap-question-txt .txt { width: calc(100% - 56px); }
  .wrap-passed .list-answer .wrap-description-content { padding-left: 56px; }
  .wrap-passed .wrap-bg .wrap-btn { margin-top: 64px; display: flex; justify-content: center; }
  .wrap-passed .wrap-bg .wrap-btn > li { margin: 0 12px; width: 255px; }
  .wrap-passed .wrap-bg .wrap-btn a { border-radius: 32px; opacity: 1; transition: opacity .3s; }
  .wrap-passed .wrap-bg .wrap-btn a:hover { opacity: .7; }
  .wrap-passed .result-inner { margin-bottom: -240px; }
  .wrap-passed .wrap-congratulations { padding: 64px 24px; border-radius: 32px; margin: auto; max-width: 1090px; }
  .wrap-passed .wrap-congratulations:after { height: 360px; position: absolute; right: -24px; left: -32px; top: -320px; background: transparent url(shonan_index_all_correct_pc.webp) no-repeat top center; background-size: contain; }
  .wrap-passed .wrap-congratulations .wrap-txt { position: relative; max-width: 720px; margin-left: auto; margin-right: auto; }
  .wrap-passed .wrap-congratulations .wrap-txt::before { content: ""; display: block; width: 56px; height: 56px; background: url(shonan_quiz_bg01.webp) no-repeat center center; background-size: contain; position: absolute; right: 20px; top: -20px; }
  .wrap-passed .wrap-congratulations .wrap-txt::after { content: ""; display: block; width: 52px; height: 52px; background: url(shonan_quiz_bg02.webp) no-repeat center center; background-size: contain; position: absolute; left: 20px; bottom: 0; z-index: 0; }
  .wrap-passed .wrap-congratulations .wrap-txt p { font-size: 2.0rem; }
  .wrap-passed .wrap-congratulations .wrap-btn1, .wrap-passed .wrap-congratulations .wrap-btn2 { max-width: 440px; margin-left: auto; margin-right: auto; }
  .wrap-passed .wrap-congratulations .wrap-btn1 a, .wrap-passed .wrap-congratulations .wrap-btn2 a { border-radius: 40px; font-size: 1.6rem; min-height: 80px; display: flex; align-items: center; justify-content: center; opacity: 1; transition: opacity .3s; }
  .wrap-passed .wrap-congratulations .wrap-btn1 a:hover, .wrap-passed .wrap-congratulations .wrap-btn2 a:hover { opacity: .7; }
  .wrap-passed .wrap-congratulations .wrap-btn2 a { color: #fff; background-color: #BE012F; font-size: 2.4rem; }
  .wrap-passed .txt-score { padding-bottom: 50px; } .dialog .movie { margin-bottom: 24px; } .dialog { max-width: 900px; }
  .dialog .dialog-inner { padding: 64px 140px 48px; }
  .dialog .btn-close { opacity: 1; transition: opacity .3s; }
  .dialog .btn-close:hover { opacity: .7; }
  .dialog .txt-hdg { font-size: 2.0rem; }
  .dialog .txt-hdg.ver-soon { font-size: 3.2rem; padding-top: 30px; padding-bottom: 30px; }
  .dialog .txt-add { font-size: 1.6rem; }
  .dialog.all-questions-correct .txt-congratulations { font-size: 7.2rem; }
  .dialog.all-questions-correct .wrap-congratulations { padding: 36px; }
  .dialog.all-questions-correct .wrap-congratulations:after { background-image: url(shonan_index_all_correct_pc.webp); }
  .dialog.all-questions-correct .wrap-congratulations p { font-size: 1.8rem; } .wrap-opening .wrap-video .btn-skip { bottom: 10px; } .wrap-opening .wrap-video.ver2 .btn-skip { bottom: 100px; right: 40px; }
  .wrap-opening .wrap-video.ver2 .btn-skip.ver2 { bottom: 40px; } .laboratory .wrap-school.ver-lab .wrap-hdg .wrap-txt { padding-bottom: 0; width: calc(100% - 552px); }
  .laboratory .wrap-school.ver-lab .wrap-hdg .wrap-img { width: 552px; padding: 0 48px 0 0; background-color: transparent; border-radius: 0; margin-top: 0; margin: -15px 0 -40px; }
  .laboratory .wrap-school.ver-lab .wrap-hdg .wrap-img img { margin: 0; }
  .laboratory .wrap-school.ver-lab .wrap-hdg .wrap-img::after { display: none; }
  .laboratory .wrap-school.ver-lab .wrap-qa { margin-top: 64px; }
  .laboratory .wrap-school.ver-lab .wrap-qa .wrap-q, .laboratory .wrap-school.ver-lab .wrap-qa .wrap-a { margin-top: 48px; }
  .laboratory .wrap-school.ver-lab .wrap-qa .wrap-a .wrap-txt + .wrap-txt { margin-top: 24px; }
  .laboratory .wrap-school.ver-lab .wrap-qa .txt.ft-l { font-size: 2.4rem; }
  .laboratory .wrap-school.ver-lab .hr-pt1.end, .laboratory .wrap-school.ver-lab .hr-pt2.end { padding-bottom: 112px; }
  .laboratory .wrap-school.ver-lab .hr-pt1.end:before, .laboratory .wrap-school.ver-lab .hr-pt2.end:before { width: 72px; height: 224px; left: calc(50% - 510px); -webkit-transform: translateX(-50%); transform: translateX(-50%); bottom: -112px; }
  .laboratory .wrap-school.ver-lab .hr-pt1.end:after, .laboratory .wrap-school.ver-lab .hr-pt2.end:after { width: 160px; height: 214px; right: calc(50% - 660px); -webkit-transform: translateX(-50%); transform: translateX(-50%); bottom: -88px; }
  .laboratory .wrap-school.ver-lab .wrap-pic-ver1 { margin-top: 48px; }
  .laboratory .wrap-school.ver-lab .wrap-pic-ver1::after { width: 80px; height: 154px; left: -62px; bottom: -28px; }
  .laboratory .wrap-school.ver-lab .list-lab-flow > li { margin-top: 40px; display: flex; justify-content: space-between; }
  .laboratory .wrap-school.ver-lab .list-lab-flow .wrap-img { width: 255px; }
  .laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt { margin-top: 0; width: 627px; }
  .laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg { font-size: 1.6rem; padding-right: 0; cursor: default; }
  .laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg::before, .laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt .hdg::after { display: none; }
  .laboratory .wrap-school.ver-lab .list-lab-flow .wrap-txt dd { display: block; padding-left: 0; }
  .laboratory .wrap-school.ver-lab .list-lab-flow .txt { margin-top: 16px; font-size: 1.4rem; line-height: 1.6; }
  .laboratory .wrap-school.ver-lab .wrap-normal-txt { margin-top: 48px; padding: 0; }
  .laboratory .wrap-school.ver-lab .wrap-normal-txt .txt { font-size: 1.6rem; }
  .laboratory .wrap-school.ver-lab .wrap-pic-ver2 { padding: 0; }
  .laboratory .wrap-school.ver-lab .wrap-pic-ver2 dt { font-size: 1.6rem; }
  .laboratory .wrap-school.ver-lab .wrap-pic-ver2 dd { font-size: 1.6rem; }
  .laboratory .wrap-school.ver-lab .wrap-pic-ver2 .wrap-img { margin: 16px -38px 0; }
  .laboratory .wrap-school.ver-lab .wrap-finish { margin: 64px -165px 0; padding: 58px 0 48px; min-height: 750px; background-image: url(shonan_laboratory_bg01_pc.webp); background-size: contain; }
  .laboratory .wrap-school.ver-lab .wrap-finish .txt-finish { padding: 0; font-size: 3.2rem; }
  .laboratory .wrap-school.ver-lab .wrap-finish .wrap-product { margin-top: 42px; }
  .laboratory .wrap-school.ver-lab .wrap-finish .wrap-product img { width: 100%; max-width: 500px; }
  .laboratory .wrap-school.ver-lab .wrap-finish .wrap-qa { margin: 90px auto 0; max-width: 910px; } .laboratory .wrap-school .wrap-slider-laboratory { margin: 60px -95px 80px; }
  .laboratory .wrap-school .wrap-slider-laboratory::before { width: 70px; height: 195px; left: 27px; bottom: -55px; }
  .laboratory .wrap-school .wrap-slider-laboratory::after { width: 112px; height: 160px; right: 54px; bottom: -55px; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__track { margin: -80px 0 0; background-image: url(shonan_laboratory_slide_bg_pc.webp); min-height: 590px; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__slide { width: 100%; padding: 130px 190px 64px; }
  .laboratory .wrap-school .wrap-slider-laboratory .wrap-img { display: flex; justify-content: space-between; }
  .laboratory .wrap-school .wrap-slider-laboratory .wrap-img img { max-width: 336px; }
  .laboratory .wrap-school .wrap-slider-laboratory .wrap-img img + img { margin-top: 0; }
  .laboratory .wrap-school .wrap-slider-laboratory .wrap-txt { margin-top: 32px; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__arrows { top: 312px; -webkit-transform: none; transform: none; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__arrow { width: 64px; height: 64px; transition: .3s; opacity: 1; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__arrow:hover { opacity: .7; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__arrow--prev { left: 97px; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__arrow--next { right: 97px; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__pagination { display: flex; flex-wrap: wrap; margin: 0; position: relative; z-index: 1; justify-content: space-between; padding: 0 97px; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li { width: 162px; height: 162px; padding: 0; margin-top: 0; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li button { transition: .3s; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li button:after { right: 8px; bottom: 8px; -webkit-transform: none; transform: none; }
  .laboratory .wrap-school .wrap-slider-laboratory .splide__pagination li button:hover { -webkit-transform: scale(1.05); transform: scale(1.05); } .map { min-width: 1366px; } .map .wrap-school .wrap-hdg .wrap-img { margin: -13px 0 -77px; position: relative; }
  .map .wrap-school .wrap-hdg .wrap-img:after { display: none; } .map .wrap-school .list-page-anchor { justify-content: center; }
  .map .wrap-school .list-page-anchor > li { margin: 0 12px; } .map .wrap-school .hdg-period .txt-period { font-size: 2.4rem; }
  .map .wrap-school .hdg-period.pt1 .inner:before { width: 139px; height: 101px; left: -105px; top: -31px; }
  .map .wrap-school .hdg-period.pt1 .inner:after { width: 310px; height: 205px; right: -95px; bottom: -12px; }
  .map .wrap-school .hdg-period.pt2 .inner:before { width: 120px; height: 128px; left: -166px; top: -35px; }
  .map .wrap-school .hdg-period.pt2 .inner:after { width: 232px; height: 120px; right: -143px; bottom: -30px; }
  .map .wrap-school .hdg-period.pt3 .inner:before { width: 120px; height: 128px; left: -166px; top: -35px; }
  .map .wrap-school .hdg-period.pt3 .inner:after { width: 232px; height: 120px; right: -143px; bottom: -30px; } .map .wrap-school .wrap-qa { margin-top: 64px; }
  .map .wrap-school .wrap-qa .wrap-a { margin-top: 64px; }
  .map .wrap-school .wrap-qa .wrap-a:has(.inner-img2) + .wrap-q { margin-top: 32px; }
  .map .wrap-school .wrap-qa .wrap-txt + .wrap-txt.inner-img1 { margin-top: 24px !important; margin-bottom: 50px; }
  .map .wrap-school .wrap-qa .wrap-txt + .wrap-txt.inner-img1:after { content: ""; display: block; margin: 0; width: 178px; height: 178px; background: url(shonan_map_img11.webp) no-repeat 0 0; background-size: contain; position: absolute; right: 42px; bottom: -58px; }
  .map .wrap-school .wrap-qa .wrap-txt + .wrap-txt.inner-img1 .txt:after { display: none; }
  .map .wrap-school .wrap-qa .wrap-txt.inner-img2:after { width: 130px; height: 122px; right: 140px; top: -24px; bottom: auto; } .map .wrap-recommend-content { margin-top: 64px; }
  .map .wrap-recommend-content.irr1 { padding-top: 215px; margin-top: 0; }
  .map .wrap-recommend-content .list-tab > li .course1, .map .wrap-recommend-content .list-tab > li .course2 { padding: 20px; font-size: 2.0rem; }
  .map .wrap-recommend-content .list-tab > li .course1.tabActive span::before, .map .wrap-recommend-content .list-tab > li .course2.tabActive span::before { top: 2px; }
  .map .wrap-recommend-content .list-tab > li .course1 { border-radius: 0 40px 0 0; }
  .map .wrap-recommend-content .list-tab > li .course2 { border-radius: 40px 0 0 0; }
  .map .wrap-recommend-content .inner { padding: 60px 87px; border-radius: 0 0 40px 40px; }
  .map .wrap-recommend-content .inner::before { content: ""; display: block; width: 45px; height: 112px; background: transparent url(shonan_map_img14.webp) no-repeat 0 0; background-size: contain; z-index: 2; position: absolute; left: 50%; -webkit-transform: translateX(-516px); transform: translateX(-516px); bottom: 157px; }
  .map .wrap-recommend-content .inner::after { content: ""; display: block; width: 120px; height: 120px; right: 50%; -webkit-transform: translateX(608px); transform: translateX(608px); bottom: 360px; }
  .map .wrap-recommend-content .inner.bg1 .list-shop { margin-top: 24px; }
  .map .wrap-recommend-content .inner.bg1 .list-shop::after { width: 400px; height: 292px; margin: 24px 0 0 auto; }
  .map .wrap-recommend-content .inner.bg1 .list-shop > li:nth-child(5) { margin-top: 0; }
  .map .wrap-recommend-content .inner.bg1 .txt-st { margin-top: 10px; }
  .map .wrap-recommend-content .inner.bg2 .wrap-process { position: relative; }
  .map .wrap-recommend-content .inner.bg2 .wrap-process::before { content: ""; display: block; width: 330px; height: 248px; background: transparent url(shonan_map_img04.webp) no-repeat 0 0; background-size: contain; position: absolute; left: 0; bottom: 0; }
  .map .wrap-recommend-content .inner.bg2 .list-shop { margin-top: 24px; }
  .map .wrap-recommend-content .inner.bg2 .list-shop::after { width: 440px; height: 215px; margin: 16px 0 0 auto; -webkit-transform: none; transform: none; }
  .map .wrap-recommend-content .inner.bg2 .txt-st { margin-top: 0px; }
  .map .wrap-recommend-content .inner.bg3 { padding: 60px 87px 32px; background-color: #F5FAFB; border-radius: 24px; }
  .map .wrap-recommend-content .inner.bg3 .wrap-img { margin-top: -215px; text-align: center; width: 100%; }
  .map .wrap-recommend-content .inner.bg3 .wrap-img img { width: 756px; }
  .map .wrap-recommend-content .inner.bg3::before { display: none; }
  .map .wrap-recommend-content .inner.bg3 .wrap-list-shop { margin-top: 48px; }
  .map .wrap-recommend-content .inner.bg3 .wrap-list-shop .list-shop > li { width: 100%; }
  .map .wrap-recommend-content .inner.bg3 .wrap-list-shop .list-shop > li:first-child { margin-top: 0; }
  .map .wrap-recommend-content .wrap-process { flex-direction: row; }
  .map .wrap-recommend-content .wrap-process .wrap { margin: 0; width: 340px; }
  .map .wrap-recommend-content .hdg { font-size: 3.0rem; }
  .map .wrap-recommend-content .list-process { margin-top: 50px; }
  .map .wrap-recommend-content .list-process .txt-step { padding: 6px 8px 8px; font-size: 1.8rem; }
  .map .wrap-recommend-content .wrap-img { width: calc(100% - 340px); padding: 0; margin-top: -30px; margin-right: -191px; }
  .map .wrap-recommend-content .wrap-img img { width: 751px; height: auto; } .map .list-shop { -webkit-column-count: 2; column-count: 2; }
  .map .list-shop > li { -webkit-column-break-inside: avoid; break-inside: avoid-column; margin-top: 24px; display: flex; width: 100%; max-width: 446px; }
  .map .list-shop > li .txt-link a:hover { text-decoration: none; }
  .map .list-shop > li:first-child { margin-top: 0; } .map .hdg-lv3-map { font-size: 2.6rem; margin-top: 120px; margin-bottom: 48px; padding: 30px; }
  .map .hdg-lv3-map::before { width: 76px; height: 98px; left: 110px; top: -20px; }
  .map .hdg-lv3-map::after { width: 116px; height: 79px; right: 90px; top: auto; bottom: -13px; } .map .wrap-column-row2 { width: 720px; margin: auto; display: flex; justify-content: space-between; }
  .map .wrap-column-row2 .inner { width: 342px; }
  .map .wrap-column-row2 .txt-st { font-size: 2.4rem !important; }
  .map .wrap-column-row2 .txt-st.add { font-size: 1.6rem !important; } .map .wrap-ans { margin: 120px -90px 0; padding: 71px 92px; background: transparent url(shonan_map_bg02.webp) no-repeat center center; background-size: contain; }
  .map .wrap-ans .hdg-lv3-map { padding: 30px; }
  .map .wrap-ans:after { display: none; } .map .wrap-img.inner-map { margin-top: -10px; margin-left: -60px; margin-right: -60px; }
  .map .wrap-img.inner-map img { width: 100%; }
  .map .wrap-img.inner-map + .wrap-a { margin-top: 48px !important; }
  .map .wrap-img.inner-map + .wrap-a + .wrap-q { margin-top: 32px !important; } .map .wrap-btn-sp1 { margin-top: 100px; }
  .map .wrap-btn-sp1 a { padding: 62px 32px; border-radius: 34px; margin: auto; max-width: 740px; font-size: 2.6rem; opacity: 1; transition: .3s; }
  .map .wrap-btn-sp1 a:hover { opacity: .9; }
  .map .wrap-btn-sp1 a:before, .map .wrap-btn-sp1 a:after { width: 198px; height: 80px; top: 10px; pointer-events: none; }
  .map .wrap-btn-sp1 a:before { left: 40px; }
  .map .wrap-btn-sp1 a:after { right: 40px; } }

@media print, all and (min-width: 1320px) { .header { margin: 0 auto; }
  .header .header-inner { padding: 24px 40px 24px 48px; }
  .header .header-body { display: flex; justify-content: space-between; align-items: center; }
  .header .header-logo .inner { opacity: 1; transition: opacity .3s; }
  .header .header-logo .inner:hover { opacity: .7; }
  .header .header-logo img { height: 17.7px; }
  .header .header-logo .lang-jp { font-size: 1.4rem; padding: 6px 12px; margin-top: 10px; }
  .header .btn-sp-menu { display: none; }
  .header .wrap-nav { position: static; opacity: 1; visibility: visible; z-index: 1; margin-top: 0; border-radius: 0; background-color: transparent; padding: 0; display: flex; justify-content: flex-end; align-items: center; height: auto; }
  .header .nav-items { display: flex; align-items: center; }
  .header .nav-items > li { font-size: 2.0rem; line-height: 1.6; margin: 0 0 0 20px; font-weight: 500; display: flex; flex-direction: column; text-align: center; }
  .header .nav-items > li:first-child { margin: 0; }
  .header .nav-items > li > a, .header .nav-items > li > button { font-size: 2.0rem; padding: 0 15px; opacity: 1; transition: opacity .3s; }
  .header .nav-items > li > a:hover, .header .nav-items > li > button:hover { opacity: .7; }
  .header .wrap-btn .btn-type1, .header .wrap-btn .btn-img1 { margin: 0 0 0 15px; }
  .header .wrap-btn .img img { max-width: 320px; }
  .header .wrap-btn .btn-img1 img { opacity: 1; transition: opacity .3s; }
  .header .wrap-btn .btn-img1:hover img { opacity: .7; } .top-page .header { min-height: 96px; }
  .top-page .header .header-body { justify-content: flex-end; }
  .top-page .header .header-inner { padding: 24px 40px; }
  .top-page .header .header-logo { padding: 48px 40px 33px; }
  .top-page .header .header-logo img { height: 34px; }
  .top-page .header .header-logo .inner { justify-content: center; align-items: center; }
  .top-page .header .header-logo .lang-jp { margin: 24px 0 0; padding: 10px 16px; font-size: 2.0rem; } }

@media print, all and (min-width: 768px) and (max-width: 1230px) { .top-page .header { min-height: 72px; } }

@media print, all and (max-width: 1230px) { .top-page .main { padding-top: 0; } }

@media print, all and (max-width: 767px) { .top-page .btn-mode-change { width: 96px; height: 102px; right: 35px; bottom: 80px; } .top-page.search-mode .wrap-map .per4, .top-page.search-mode .wrap-map .per8, .top-page.search-mode .wrap-map .sea-bg1, .top-page.search-mode .wrap-map .sea-per7, .top-page.search-mode .wrap-map .sea-per5-1, .top-page.search-mode .wrap-map .sea-per5-2 { opacity: 1; } .wrap-map .icon.search-y:after { width: 60px; height: 60px; } .wrap-map .pointer:after { width: 34px; height: 34px; }
  .wrap-map .pointer.building02:after { width: 38px; height: 38px; } .wrap-map .ocan { top: 144px; left: -55px; width: 460px; height: 460px; } .wrap-map .enoshima { top: 280px; left: 84px; width: 195px; height: 195px; } .wrap-map .cloud01 { left: 14.6%; width: 40px; height: 40px; } .wrap-map .cloud02 { width: 34px; height: 34px; }
  @-webkit-keyframes cloud02 { from { top: 40%;
      left: 21.6%;
      -webkit-transform: scale(0.9);
      transform: scale(0.9); }
    to { top: 42%;
      left: 22.6%;
      -webkit-transform: scale(1.1);
      transform: scale(1.1); } }
  @keyframes cloud02 { from { top: 40%;
      left: 21.6%;
      -webkit-transform: scale(0.9);
      transform: scale(0.9); }
    to { top: 42%;
      left: 22.6%;
      -webkit-transform: scale(1.1);
      transform: scale(1.1); } } .wrap-map .cloud03 { width: 48px; height: 48px; } .wrap-map .bird01 { width: 14px; height: 14px; } .wrap-map .bird02 { width: 9px; height: 9px; top: 46.5%; left: 23%; } .wrap-map .bird03 { width: 8px; height: 8px; } .wrap-map .balloon { width: 80px; height: 80px; }
  .wrap-map .balloon.search-y:after { margin-top: 30px; } .wrap-map .seagull01 { width: 30px; height: 30px; } .wrap-map .seagull02 { width: 50px; height: 50px; } .wrap-map .building01 { width: 170px; height: 170px; }
  .wrap-map .building01.pointer:after { top: 10px; }
  .wrap-map .building01 .inner-txt { margin-top: 65px; } .wrap-map .building02 { width: 210px; height: 210px; top: 17.5%; left: 43%; }
  .wrap-map .building02.pointer:after { top: 25px; }
  .wrap-map .building02 .inner-txt { margin: 80px 0 0 65px; } .wrap-map .building03 { width: 140px; height: 140px; top: 37%; left: 56.8%; }
  .wrap-map .building03.pointer:after { top: 38%; }
  .wrap-map .building03 .inner-txt { margin: 105px 0 0 -67px; } .wrap-map .building04 { width: 136px; height: 136px; }
  .wrap-map .building04.pointer:after { top: 23%; left: 66%; }
  .wrap-map .building04 .inner-txt { margin: 82px 0 0 24px; } .wrap-map .per1 { width: 32px; height: 32px; } .wrap-map .per2 { width: 40px; height: 40px; }
  @-webkit-keyframes per2 { 0% { top: 32%;
      left: 32%; }
    50% { top: 33%;
      left: 37%;
      -webkit-transform: scale(1, 1);
      transform: scale(1, 1); }
    51% { top: 33%;
      left: 37%;
      -webkit-transform: scale(1, 1);
      transform: scale(1, 1); }
    54% { top: 33%;
      left: 37%;
      -webkit-transform: scale(-1, 1);
      transform: scale(-1, 1); }
    55% { top: 33%;
      left: 37%;
      -webkit-transform: scale(-1, 1);
      transform: scale(-1, 1); }
    98% { top: 32%;
      left: 32%;
      -webkit-transform: scale(-1, 1);
      transform: scale(-1, 1); }
    100% { top: 32%;
      left: 32%; } }
  @keyframes per2 { 0% { top: 32%;
      left: 32%; }
    50% { top: 33%;
      left: 37%;
      -webkit-transform: scale(1, 1);
      transform: scale(1, 1); }
    51% { top: 33%;
      left: 37%;
      -webkit-transform: scale(1, 1);
      transform: scale(1, 1); }
    54% { top: 33%;
      left: 37%;
      -webkit-transform: scale(-1, 1);
      transform: scale(-1, 1); }
    55% { top: 33%;
      left: 37%;
      -webkit-transform: scale(-1, 1);
      transform: scale(-1, 1); }
    98% { top: 32%;
      left: 32%;
      -webkit-transform: scale(-1, 1);
      transform: scale(-1, 1); }
    100% { top: 32%;
      left: 32%; } } .wrap-map .per3 { width: 60px; height: 60px; } .wrap-map .per4 { opacity: 0; } .wrap-map .per4 { width: 34px; height: 34px; } .wrap-map .per5 { width: 27px; height: 27px; } .wrap-map .per6 { width: 20px; height: 20px; } .wrap-map .per7 { width: 26px; height: 26px; } .wrap-map .per8 { width: 37px; height: 37px; opacity: 0; } .wrap-map .land-bg1 { top: 28.5%; left: 39%; width: 35px; height: 35px; } .wrap-map .land-bg2 { top: 33.5%; left: 69.5%; width: 110px; height: 110px; } .wrap-map .land-bg3 { top: 72%; left: 79%; width: 120px; height: 120px; } .wrap-map .land-bg4 { width: 65px; height: 65px; } .wrap-map .land-bg5 { width: 125px; height: 125px; } .wrap-map .land-bg6 { width: 44px; height: 44px; } .wrap-map .land-bg7 { width: 40px; height: 40px; } .wrap-map .land-bg8 { width: 101px; height: 101px; } .wrap-map .land-bg9 { width: 100px; height: 100px; } .wrap-map .enoden { width: 127px; height: 127px; } .wrap-map .sea-per1 { width: 42px; height: 42px; } .wrap-map .sea-per2 { width: 36px; height: 36px; } .wrap-map .sea-per3 { width: 28px; height: 28px; } .wrap-map .sea-per4 { width: 56px; height: 56px; } .wrap-map .sea-per5-1 { width: 32px; height: 32px; opacity: 0; } .wrap-map .sea-per5-2 { width: 22px; height: 22px; opacity: 0; } .wrap-map .sea-per6 { top: 34%; width: 52px; height: 52px; } .wrap-map .sea-per7 { top: 348px; width: 38px; height: 38px; opacity: 0; }
  .wrap-map .sea-per7.search-y:after { margin-top: -13px; margin-left: -13px; } .wrap-map .sea-bg1 { width: 33px; height: 33px; opacity: 0; } .wrap-map .sea-bg2 { top: 46.2%; width: 38px; height: 38px; } .wrap-map .sea-dolphin { width: 50px; height: 50px; } .wrap-map .sea-dolphin-splash { width: 32px; height: 32px; top: 50%; left: 36%; } .wrap-map .sea-ship1 { top: 348px; width: 38px; height: 38px; }
  .wrap-map .sea-ship1.search-y:after { margin-top: -13px; margin-left: -13px; } .wrap-map .sea-ship2 { width: 30px; height: 30px; } .wrap-map .sea-ship3 { width: 24px; height: 24px; } .wrap-map .sea-ship4 { width: 20px; height: 20px; } .wrap-map .sea-ship5 { width: 20px; height: 20px; } .wrap-factory .content1-parts1 { width: 3vw; height: auto; left: 16%; top: 3.6%; } .wrap-factory .content1-parts2 { width: 8.5vw; height: auto; left: 50.5%; top: 5.5%; }
  @-webkit-keyframes arms2 { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
    15% { -webkit-transform: translateY(10px); transform: translateY(10px); }
    30% { -webkit-transform: translateY(10px); transform: translateY(10px); }
    45% { -webkit-transform: translateY(0); transform: translateY(0); }
    100% { -webkit-transform: translateY(0); transform: translateY(0); } }
  @keyframes arms2 { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
    15% { -webkit-transform: translateY(10px); transform: translateY(10px); }
    30% { -webkit-transform: translateY(10px); transform: translateY(10px); }
    45% { -webkit-transform: translateY(0); transform: translateY(0); }
    100% { -webkit-transform: translateY(0); transform: translateY(0); } } .wrap-factory .wrap-belt1 { width: 15vw; height: 13vw; left: 25%; top: -0.6%; -webkit-clip-path: polygon(83% 0, 100% 0, 100% 86%, 75% 100%, 0 100%, 0 58%); clip-path: polygon(83% 0, 100% 0, 100% 86%, 75% 100%, 0 100%, 0 58%); }
  .wrap-factory .wrap-belt1 img { width: 320vw; -webkit-animation-duration: 100s; animation-duration: 100s; } .wrap-factory .wrap-belt2 { width: 72.9vw; height: 50vw; left: 31.1%; top: 3.6%; }
  .wrap-factory .wrap-belt2 img { width: 320vw; -webkit-animation-duration: 100s; animation-duration: 100s; } .wrap-factory .content1-bg1 { width: 22vw; height: auto; left: 30%; top: 4.5%; } .wrap-factory .content1-bg2 { width: 15.3vw; height: auto; left: 46.5%; top: 9.2%; } .wrap-factory .content1-bg3 { width: 26.5vw; height: auto; left: 58%; top: 7.2%; } .wrap-factory .content1-bg4 { width: 11vw; height: auto; left: 21%; top: 10%; } .wrap-factory .content1-bg5 { width: 5.5vw; height: auto; left: 39%; top: 14.5%; } .wrap-factory .content2-parts1 { width: 2.7vw; height: auto; left: 28%; top: 36%; }
  @-webkit-keyframes flash { from { -webkit-filter: brightness(100%); filter: brightness(100%); }
    to { -webkit-filter: blur(5px) brightness(160%); filter: blur(5px) brightness(160%); } }
  @keyframes flash { from { -webkit-filter: brightness(100%); filter: brightness(100%); }
    to { -webkit-filter: blur(5px) brightness(160%); filter: blur(5px) brightness(160%); } } .wrap-factory .content2-parts2 { width: 6.2vw; height: auto; left: 33%; top: 21.5%; } .wrap-factory .content3-parts1 { width: 8vw; height: auto; left: 69.2%; top: 58.1%; } .wrap-factory .content3-parts2 { width: 8vw; height: auto; left: 55.8%; top: 58.1%; } .wrap-factory .content4-parts1 { width: 31.5vw; height: auto; left: 36.5%; top: 82.9%; } .wrap-factory .content4-parts2 { width: 53.5vw; height: auto; left: 38.5%; top: 69.8%; } .factory .main { overflow: hidden; } .wrap-opening { background-color: #000; }
  .wrap-opening .wrap-video { position: relative; width: 100%; }
  .wrap-opening .wrap-video video { width: 100%; height: 100%; } }

@media print, all and (max-width: 1240px) and (min-width: 768px) { .wrap-school .hdg-period { margin-left: -165px; } }

@media print, all and (max-width: 1366px) and (min-width: 768px) { .map .wrap-school .hdg-period { margin-left: -228px; } }

@media print, all and (max-width: 390px) { .dialog.all-questions-correct .wrap-congratulations:after { top: -220px; } }
