.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; } }

/*--top--appealarea--*/
#appeal-area img { width: 100%; }

.text-block { position: relative; color: #fff; font-family: "Noto Serif JP", serif; padding: 4rem 0; }
.text-block img.message1 { filter: invert(1); width: 70em; margin: 0 auto; }
.text-block::before { content: ""; width: 100%; height: 100%; display: block; z-index: -1; position: absolute; top: 0; right: 0; background: #010002; }
.text-block img { display: block; }
.text-block strong { font-size: clamp(16px, 6.5vw, 84px); display: block; font-weight: normal; margin-top: 2rem; }
.text-block .btn-visit { max-width: 370px; margin: 2rem auto; z-index: 1; }
.text-block .btn-visit a { display: block; position: relative; background: linear-gradient(to right, #000, #2f2f2f, #000); color: #fff; transition: .3s filter; }
.text-block .btn-visit a::before { filter: invert(1); }
.text-block .btn-visit a::after { content: ''; border: none; height: 110%; width: 100%; display: inline-block; position: absolute; background: linear-gradient(to right, #ca9c2b, #feda4f, #964f00, #ca9c2b, #fff9b1, #ca9c2b, #824800, #ca9c2b); top: -5%; left: 0; bottom: auto; z-index: -1; }
.text-block .btn-visit a:hover { background: linear-gradient(to right, #debb55, #f0e9ba, #debb55); filter: none; color: #010002; text-decoration: none; }
.text-block .btn-visit a:hover::before { filter: invert(0); }
@media screen and (max-width: 559px) { .text-block .btn-visit { width: 80%; } }

ul.price-list { width: 90%; margin: 4rem auto 0 auto; display: flex; justify-content: space-around; border-top: 1px solid #fff; }
ul.price-list li { width: 30.5%; margin-top: 2rem; display: flex; justify-content: center; flex-direction: column; }
ul.price-list li + li { border-left: 1px solid #fff; padding-left: 1rem; }
ul.price-list li a { width: 100%; margin-top: 1rem; display: block; font-size: 1.2rem; background: linear-gradient(to right, #000, #797979, #fff, #797979, #000); padding: 0.25rem 0; color: #010002; text-decoration: none; }
ul.price-list li a:hover { background: linear-gradient(to right, #000, #debb55, #f0e9ba, #debb55, #000); }
@media screen and (max-width: 768px) { ul.price-list { flex-wrap: wrap; }
  ul.price-list li { width: 100%; }
  ul.price-list li a { font-size: 1rem; }
  ul.price-list li + li { padding-left: 0; border-left: none; padding-top: 2rem; border-top: 1px solid #fff; } }

#appeal-area { font-family: "Noto Serif JP", serif; }
#appeal-area ul.point { width: 92%; margin: 4rem auto 0 auto; display: flex; justify-content: space-around; }
#appeal-area ul.point li { background: #010002; width: 23%; position: relative; padding: 1rem; }
#appeal-area ul.point li:nth-child(4) { padding: 2rem; }
#appeal-area ul.point li::after { content: ''; border: none; height: calc(100% + 10px); width: 100%; display: inline-block; position: absolute; background: linear-gradient(to right, #ca9c2b, #feda4f, #964f00, #ca9c2b, #fff9b1, #ca9c2b, #824800, #ca9c2b); top: -5px; left: 0; bottom: auto; z-index: -1; }
#appeal-area ul.point li span.small { position: absolute; bottom: 0; font-size: 0.7rem; right: 5px; color: #fff; }
#appeal-area ul.point li a { margin-top: 2rem; display: block; padding: 0.5rem 0; font-size: 1.2rem; background: linear-gradient(to right, #000, #797979, #fff, #797979, #000); width: 100%; color: #010002; text-decoration: none; }
#appeal-area ul.point li a:hover { background: linear-gradient(to right, #000, #debb55, #f0e9ba, #debb55, #000); }
#appeal-area img.message2 { width: 80em; margin-top: 4rem; }
@media screen and (max-width: 768px) { #appeal-area ul.point { flex-wrap: wrap; }
  #appeal-area ul.point li { width: 48%; }
  #appeal-area ul.point li:nth-child(4), #appeal-area ul.point li:nth-child(3) { margin-top: 2rem; } }
@media screen and (max-width: 559px) { #appeal-area ul.point { flex-wrap: wrap; }
  #appeal-area ul.point li { width: 100%; }
  #appeal-area ul.point li:nth-child(2) { margin-top: 2rem; } }
