@import url("https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@300;400;500;700&display=swap");
.container { width: 1100px; margin: 0 auto; }
@media (max-width: 1200px) { .container { width: 100%; padding: 0px 20px; } }

.narrow { width: 770px; margin: 0 auto; }
@media (max-width: 770px) { .narrow { width: 100%; padding: 0px 20px; } }

.pc-only { display: block; }
@media screen and (max-width: 768px) { .pc-only { display: none; } }

.sp-only { display: none; }
@media screen and (max-width: 768px) { .sp-only { display: block; } }

article#page { font-family: "Noto Serif JP", serif; }
article#page .ttl { background: #010002; padding: 2.5rem 0; color: #fff; position: relative; margin-top: 5px; }
article#page .ttl h2 { font-family: "Gilda Display", serif; font-size: 2.4rem; line-height: 1.1; letter-spacing: 0.3rem; }
article#page .ttl h2 span { font-family: "Noto Serif JP", serif; display: block; font-size: 1.2rem; letter-spacing: 0rem; }
article#page .ttl::after { content: ''; border: none; height: calc(100% + 10px); width: 100%; display: inline-block; position: absolute; background: linear-gradient(90deg, #797979 0%, #fff 54%, #c2c2c2 83%, #797979 100%); top: -5px; left: 0; bottom: auto; z-index: -1; }
@media screen and (max-width: 559px) { article#page .ttl h2 { font-size: 2rem; }
  article#page .ttl h2 span { font-size: 1rem; } }

.arrow { position: relative; display: inline-block; padding: 0 0 0 16px; vertical-align: middle; text-decoration: none; font-size: 1rem; }
.arrow::after { position: absolute; top: 0; bottom: 0; margin: auto; content: ""; vertical-align: middle; right: 20px; width: 10px; height: 10px; border-top: 2px solid #fff; border-right: 2px solid #fff; -webkit-transform: rotate(45deg); transform: rotate(45deg); }

a.btn { color: #fff; background: #797979; padding: 0.5rem 0; }
a.btn:hover { filter: brightness(1.7); text-decoration: none; transition: 0.3s; }
a.btn.coming { background: #555; color: #ccc; }
a.btn.coming:hover { filter: none; text-decoration: none; }
a.btn.back.arrow::after { right: auto; left: 20px; width: 10px; height: 10px; border-top: 2px solid #fff; border-right: 2px solid #fff; transform: rotate(225deg); }
a.btn.black { background: #010002; }

#access, #limited, #alphapoint, #view, #limited-login, #concept-design, #outline, #company, #roomplan { padding: 6rem 0; }
@media screen and (max-width: 559px) { #access, #limited, #alphapoint, #view, #limited-login, #concept-design, #outline, #company, #roomplan { padding: 4rem 0; } }

/* CSS Document */
#pageWrap a:hover { opacity: 0.6; text-decoration: none; }

.flex-container { display: flex; flex-wrap: wrap; justify-content: space-between; }

.wrapWidth { width: 100%; margin: 0 auto; }

.boxWidth { width: 96%; max-width: 1200px; margin: 0 auto; }

.brSp { display: none; }

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

.imgBox { position: relative; }

#contents-wrap { position: relative; padding-bottom: 1px; margin-bottom: 1%; }

#contents-wrap:before { position: absolute; content: ""; width: 90%; height: 1px; bottom: 0; left: 5%; background-color: #ccc; }

@media screen and (max-width: 1170px) { #contents-wrap { font-size: 1.2vw; } }
@media screen and (max-width: 810px) { #contents-wrap { font-size: 2vw; } }
@media screen and (max-width: 700px) { #contents-wrap { font-size: 2.4vw; } }
@media screen and (max-width: 599px) { .brSp { display: inline; } }
@media screen and (max-width: 500px) { #contents-wrap { font-size: 2.8vw; } }
.capImg::after { content: 'image'; position: absolute; font-size: 10px; text-align: right; right: 0.5em; bottom: 0.1em; color: #fff; text-shadow: 0px 0px 1px rgba(0, 0, 0, 0.5), 1px 1px 0px rgba(0, 0, 0, 0.5), -1px 1px 0px rgba(0, 0, 0, 0.5), -1px -1px 0px rgba(0, 0, 0, 0.5), 1px -1px 0px rgba(0, 0, 0, 0.5); }

.uLine { background: #ebb38d; background: linear-gradient(180deg, rgba(235, 179, 141, 0) 20%, #ebb38d 20%, rgba(235, 179, 141, 0.5) 100%); background-repeat: no-repeat; background-size: 0% .5em; transition: all 1.5s ease 1s; background-position: 0 1em; }

.active.uLine { background-size: 100% .5em; }

.blink { animation: blink 0.5s ease-in-out infinite alternate; transform-origin: center bottom; }

@keyframes blink { 0% { opacity: 0; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.2); }
  100% { opacity: 1; transform: scale(1.2); } }
.caseBox { transform: rotateY(90deg); opacity: 0; }

.caseBox.active { animation: caseBox 1s ease-in-out 0.6s; animation-fill-mode: forwards; }

@keyframes caseBox { 0% { transform: rotateY(90deg); }
  100% { transform: rotateY(0deg); opacity: 1; } }
.numDay { transform: rotateY(90deg); opacity: 0; }

.active .numDay { animation: caseBox 0.5s ease-in-out 0.5s; animation-fill-mode: forwards; }

.daysBox .txt { opacity: 0; transform: translateX(-30px); }

.daysBox .active .txt { transition: 0.5s ease-out 1s; transform: translateX(0px); opacity: 1; }

.daysBox .imgBox, .daysBox .junbi { opacity: 0; }

.daysBox .active .imgBox, .daysBox .junbi.active { transition: 0.6s ease-out 1.5s; opacity: 1; }

.zen-maru-gothic-light { font-family: "Zen Maru Gothic", sans-serif; font-weight: 300; font-style: normal; }

.zen-maru-gothic-regular { font-family: "Zen Maru Gothic", sans-serif; font-weight: 400; font-style: normal; }

.zen-maru-gothic-medium { font-family: "Zen Maru Gothic", sans-serif; font-weight: 500; font-style: normal; }

.zen-maru-gothic-bold { font-family: "Zen Maru Gothic", sans-serif; font-weight: 700; font-style: normal; }

#pageWrap { padding: 0px 0 0; font-family: 'YakuHanMP', 'Noto Serif JP', serif; font-family: "Zen Maru Gothic", sans-serif; font-weight: 400; text-align: left; letter-spacing: -0.05em; }

#secMain { position: relative; }

.imgBox.capImg::after { content: "image photo"; color: #000; text-shadow: none; }

#secMain #h2Box { position: absolute; width: 32%; top: 50%; right: 0%; transform: translateY(-50%); }

.iconBox { width: 25%; max-width: 100px; margin: 0 auto; }

#sec01 { background-color: #f9e7db; padding: 5% 0; position: relative; }

#sec01 h3 { width: 90%; max-width: 800px; margin: 50px auto; position: relative; z-index: 1; }

#sec01 h3::after { content: ""; position: absolute; width: 85%; height: 50%; right: -2%; bottom: -6%; background-color: #fff; z-index: -1; }

#sec01 p { font-size: 21px; text-align: center; }

#sec01 .figBox { width: 30%; max-width: 220px; margin: 0 auto; padding: 3% 0 1%; }

#sec01 .sankaku { position: absolute; width: 25%; max-width: 230px; left: 50%; bottom: 0%; transform: translate(-50%, 70%); }

.h3Box { padding: 15% 0 5%; position: relative; }

.h3Box .blink { position: absolute; width: 100px; bottom: 40%; left: calc(50% - 50px); }

#h3-02 h3 { max-width: 1000px; margin: 0 auto; }

#sec02, #sec03 { padding: 0 0; position: relative; background-image: url("../../images/schedule/bg-sankaku.svg"), url("../../images/schedule/bg-sankaku02.svg"); background-repeat: no-repeat,no-repeat; background-position: left top, right bottom; background-size: 30%,30%; margin-top: 5%; }

.numBox { width: 30%; max-width: 120px; margin: 0 auto; }

.caseBox { max-width: 1000px; border: #000 solid 2px; background-color: #fff; padding: 5%; position: relative; margin-top: 3%; }

.caseBox .iconBox { position: absolute; top: 0; left: 50%; transform: translate(-50%, -20%); }

.caseBox .flex { align-items: center; }

.caseBox .flex dl { width: 64%; }

.caseBox .flex dt { font-size: 34px; font-weight: 500; text-align: center; }

.caseBox .flex dd { font-size: 20px; padding-top: 1em; }

.caseBox .flex .itemBox { width: 30%; max-width: 240px; }

.caseBox .flex .itemBox p { font-size: 21px; padding-top: 0.5em; text-align: center; line-height: 1.4; }

.daysBox { max-width: 1000px; padding: 5% 0; position: relative; }

.daysBox .imgBox.capImg::after { bottom: -1.6em; }

.daysBox .daysBase { position: absolute; background-color: #f9e7db; width: 7%; height: 95%; top: 5%; left: 3%; z-index: -1; background-image: url("../../../images/schedule/arwend.svg"); background-position: left bottom; background-repeat: no-repeat; background-size: 100%; }

.daysBox .flex-container { justify-content: flex-start; align-items: center; padding: 3% 0; }

.daysBox .numDay { width: 13%; margin-right: 3%; }

.daysBox .txt { margin-right: 3%; }

.daysBox .txt p { font-size: 24px; }

.daysBox .txt p .maru { color: #c1272d; }

.daysBox .txt p .orng { color: #df884d; font-weight: 500; }

.daysBox .flex1 .imgBox { width: 18%; }

.daysBox .flex2 .imgBox, .daysBox .flex3 .imgBox { width: 28%; }

.daysBox .flex4 .imgBox { width: 34%; }

.daysBox .flex6 .imgBox { width: 20%; }

.daysBox .flex6 { padding: 5% 0; }

.junbi { background-color: #f9e7db; margin-left: 16%; padding: 3% 5%; }

.junbi h4 { width: 45%; margin: 0 auto; }

.junbi p { font-size: 21px; }

.junbi { position: relative; }

.junbi .uLine { background: #df884d; background-repeat: no-repeat; transition: all 1.5s ease 1s; background-position: 0 0; color: #fff; display: inline-block; background: #DF884D; background: linear-gradient(0deg, rgba(223, 136, 77, 0) 10%, #df884d 10%, #df884d 90%, rgba(223, 136, 77, 0) 90%); }

.junbi .uLine::before, .junbi .uLine::after { content: ""; padding: 0 0.2em; }

.junbi .flex-container { justify-content: space-between; align-items: flex-start; padding-bottom: 0; }

.junbi .img01 { width: 34%; }

.junbi .img03 { width: 27.7%; }

.junbi .kira { position: absolute; width: 15%; right: 5%; top: -12%; }

.junbi .plant { position: absolute; width: 10%; right: 10%; top: 24%; }

.junbi .caption { font-size: 10px; text-align: right; padding: 0; }

#sec03 .daysBox .flex1 .imgBox { width: 23%; }

#sec03 .daysBox .flex3 .imgBox { width: 29.6%; }

#sec03 .daysBox .flex3 { position: relative; }

#sec03 .daysBox .flex3 .kira { position: absolute; width: 15%; right: 5%; bottom: 0; }

#sec03 .daysBox .flex4 .imgBox { width: 29.6%; }

#sec03 .daysBox .flex6 .imgBox { width: 20%; }

#sec03 .daysBox .flex6 { padding: 5% 0; }

#sec03 .junbi .flex-container { column-gap: 0 4%; max-width: 690px; margin: 0 auto; }

#sec03 .junbi .img01 { width: 48%; }

@media screen and (max-width: 959px) { #sec01 p { font-size: 2.4vw; }
  .h3Box { padding: 20% 0 5%; }
  .h3Box .blink { width: 80px; left: calc(50% - 40px); }
  .caseBox { padding-top: 10%; }
  .caseBox .flex { align-items: flex-end; }
  .caseBox .flex dt { font-size: 3.3vw; }
  .caseBox .flex dd { font-size: 2.2vw; }
  .caseBox .flex .itemBox p { font-size: 2.2vw; }
  .daysBox .txt p, .junbi p { font-size: 2.2vw; } }
@media screen and (max-width: 599px) { #secMain { background-color: #df884d; }
  #secMain #h2Box { position: static; width: 80%; margin: 0 auto; transform: translateY(0%); }
  #sec01 h3::after { width: 100%; height: 40%; }
  #sec01 p { font-size: clamp(14px, 4vw, 16px); }
  #sec01 .figBox { width: 50%; padding: 5% 0; }
  #sec01 .sankaku { width: 40%; }
  .h3Box .blink { position: absolute; width: 60px; bottom: 50%; left: calc(50% - 30px); }
  .caseBox .flex { justify-content: center; padding-top: 23%; }
  .caseBox .flex dl { width: 100%; }
  .caseBox .flex dt { font-size: clamp(23px, 6.4vw, 25px); }
  .caseBox .flex dd, .caseBox .flex .itemBox p { font-size: clamp(14px, 4vw, 16px); padding: 1em 0; }
  .caseBox .flex .itemBox { width: 60%; max-width: 240px; }
  .daysBox .txt p, .junbi p { font-size: clamp(14px, 4vw, 16px); }
  .daysBox .imgBox { margin: 0 auto; padding: 10px 0 0; }
  .daysBox .flex1 .imgBox, .daysBox .flex2 .imgBox, .daysBox .flex3 .imgBox, .daysBox .flex4 .imgBox, .daysBox .flex6 .imgBox, #sec03 .daysBox .flex1 .imgBox, #sec03 .daysBox .flex3 .imgBox, #sec03 .daysBox .flex6 .imgBox { width: 60%; transform: translateX(5%); }
  .daysBox .flex6 .imgBox, #sec03 .daysBox .flex6 .imgBox { width: 40%; }
  .daysBox .numDay { width: 20%; margin-right: 3%; }
  .daysBox .txt { width: 75%; margin-right: 0; }
  .daysBox .txt p br { display: none; }
  .junbi { width: 85%; margin-left: 13%; }
  .junbi p br { display: none; }
  .junbi .uLine { display: inline; }
  .junbi .uLine::before, .junbi .uLine::after, #sec03 .daysBox .flex3 .kira { display: none; }
  .junbi h4 { width: 80%; }
  .junbi .kira, .junbi .plant { display: none; }
  .junbi .img01, .junbi .img03, #sec03 .junbi .img01 { width: 100%; } }
