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

a {
  transition: 0.3s;
}

a:hover {
  opacity: 0.8;
  transition: 0.3s;
}

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", sans-serif;
  background: radial-gradient(circle at 70% 0%, rgba(212, 175, 55, 0.18), transparent 60%), linear-gradient(180deg, #0f0f12, #0b0c10);
  color: #fff;
  text-align: center;
  letter-spacing: 0.04em;
}

img {
  width: -webkit-fill-available;
  height: auto;
  width: -moz-available;
  width: 100%;
}

video {
  width: 100%;
}

.inner {
  max-width: 390px;
  margin: 0 auto;
  background-color: #000;
}

.hero {
  padding: 3% 0 0;
  background-image: url(../img/fv-bg.png);
  background-repeat: no-repeat;
  background-size: contain;
}

.logo {
  width: 86.7%;
  margin: 0 auto;
  display: block;
  mix-blend-mode: screen;
}

.price__slider {
  overflow: hidden;
}
.price__list {
  margin-top: 5%;
}
.price__list .swiper-slide {
  position: relative;
}
.price__list .price__itemContents {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
.price__list .price__itemContents .price__itemLogo {
  margin: 0 auto;
  width: 42.107%;
}
.price__list .price__itemContents p {
  font-size: clamp(16px, 7.6923vw, 30px);
  font-family: "Noto Serif JP", serif;
  margin-top: 1%;
}
.price__list .price__itemContents p span {
  font-size: clamp(16px, 4.81538vw, 18px);
}

.purchase {
  width: 90%;
  margin: 0 auto;
  position: relative;
  font-family: "Noto Serif JP", serif;
}
.purchase__contents {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  text-align: center;
  width: 100%;
}
.purchase__contents h2 {
  font-size: clamp(16px, 8.71794vw, 34px);
  color: #B9A53D;
  line-height: 1.3;
}
.purchase__contents h2 span {
  display: block;
  font-size: clamp(16px, 6.1538vw, 24px);
}
.purchase__contents p {
  font-size: clamp(16px, 4.81538vw, 18px);
  line-height: 1.5;
  margin-top: 3.5%;
}
.purchase__contents ul {
  width: 91.17%;
  margin: 4.5% auto 0;
}
.purchase__contents ul li {
  display: flex;
  align-items: stretch;
}
.purchase__contents ul li p {
  width: 40%;
  margin-top: 0;
  font-size: clamp(16px, 4.10256vw, 16px);
  background-color: #B9A53D;
  display: flex;
  align-items: center;
  justify-content: center;
}
.purchase__contents ul li p + p {
  width: 60%;
  font-size: clamp(16px, 7.17958vw, 28px);
  background-color: #FFFDD6;
  text-align: right;
  color: #301402;
  display: block;
  padding: 1% 2.5% 1% 0;
}
.purchase__contents ul li p + p span {
  font-size: clamp(16px, 4.10256vw, 16px);
}
.purchase__contents ul li + li {
  margin-top: 0.5%;
}
.purchase__contents .annotation {
  font-size: clamp(1px, 3.0769vw, 12px);
  color: #AF9725;
  margin-top: 5%;
}

.cta {
  text-align: center;
  width: 91.17%;
  margin: 7% auto 0;
}
.cta p {
  font-size: clamp(1px, 5.1282vw, 20px);
  line-height: 1.3;
}
.cta .other {
  font-size: clamp(16px, 6.1538vw, 24px);
  color: #fff;
  border: 1px solid #B9A53D;
  padding: 7% 0;
  border-radius: 10px;
  text-decoration: none;
  margin-top: 7%;
  font-weight: bold;
}
.cta a {
  display: block;
  margin-top: 7%;
}
.cta a + a {
  border: none;
  margin-top: 6%;
  padding: 0;
}

.achievements {
  text-align: center;
  width: 91.17%;
  margin: 7% auto 0;
}
.achievements h2 {
  font-size: 48px;
  font-weight: 900;
  color: #fff;
  background: #000;
  font-size: clamp(16px, 6.1538vw, 24px);
}
.achievements h2 span {
  position: relative;
  z-index: 1;
  text-shadow: 2px 2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000, -2px -2px 0 #000, 0 0 8px rgba(0, 0, 0, 0.5);
  font-size: clamp(16px, 10.25641vw, 40px);
}
.achievements h2 span::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 30%;
  background: #ffff00;
  z-index: -1;
}
.achievements ul {
  margin-top: 10%;
}
.achievements ul li + li {
  margin-top: 3%;
}
.achievements p {
  font-size: clamp(16px, 4.10256vw, 16px);
  margin-top: 8%;
}
.achievements p + p {
  font-size: clamp(16px, 6.1538vw, 24px);
  margin-top: 2%;
}
.achievements p + p span {
  font-size: clamp(16px, 4.10256vw, 16px);
}
.achievements h3 {
  position: relative;
  font-size: 48px;
  font-weight: 900;
  color: #fff;
  background: #000;
  font-size: clamp(16px, 12.30769vw, 48px);
  margin: 5% auto 0;
  text-shadow: 2px 2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000, -2px -2px 0 #000, 0 0 8px rgba(0, 0, 0, 0.5);
  z-index: 1;
  width: -moz-max-content;
  width: max-content;
}
.achievements h3::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 30%;
  background: #ffff00;
  z-index: -1;
}
.achievements h3 + p {
  font-size: clamp(16px, 7.6923vw, 30px);
  font-family: "Noto Serif JP", serif;
  line-height: 1.3;
  letter-spacing: -0.05em;
}

.flow {
  position: relative;
}
.flow__img {
  width: 93%;
  position: absolute;
  bottom: 0;
  left: 3%;
}

.organize {
  position: relative;
  background-color: #B2A367;
  margin-top: 19%;
  padding-top: 60%;
  padding-bottom: 15%;
  font-family: "Noto Serif JP", serif;
  text-align: left;
}
.organize__img {
  position: absolute;
  top: -5%;
  left: 0;
  width: 93.59%;
}
.organize h2 {
  font-size: clamp(16px, 9.23077vw, 36px);
  border-bottom: 1px solid #fff;
  padding-bottom: 5%;
  width: 85.9%;
  margin: 0 auto;
  line-height: 1.3;
}
.organize p {
  font-size: clamp(16px, 6.1538vw, 24px);
  width: 85.9%;
  margin: 6% auto 0;
  line-height: 1.3;
}
.organize p + p {
  margin-top: 10%;
}
.organize a {
  position: relative;
  padding: 5%;
  display: block;
  background-color: #84763C;
  border: 1px solid #B2A367;
  color: #fff;
  width: 85.9%;
  margin: 10% auto 0;
  font-size: clamp(16px, 6.1538vw, 24px);
  line-height: 1.3;
  text-decoration: none;
  box-shadow: 0 0 10px rgba(73, 59, 0, 0.6);
}
.organize a::after {
  position: absolute;
  content: "";
  background-image: url(../img/link-arrow.png);
  top: 50%;
  transform: translateY(-50%);
  width: 9.01%;
  height: 29.59%;
  right: 7%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.contact ul {
  margin-top: -10%;
}
.contact ul li {
  background-color: #FFFCF3;
  padding-top: 16%;
}
.contact ul li h2 {
  font-size: clamp(16px, 6.1538vw, 24px);
  border-bottom: 2px solid #000;
  font-weight: bold;
  color: #000;
  padding-bottom: 2%;
  width: -moz-max-content;
  width: max-content;
  margin: 0 auto;
}
.contact ul li .contact__itemContent {
  display: flex;
  margin-top: 5.13%;
}
.contact ul li .contact__itemContentImg {
  width: 50%;
}
.contact ul li .contact__itemContent p {
  width: 50%;
  font-size: clamp(16px, 4.10256vw, 16px);
  line-height: 1.3;
  color: #000;
  text-align: left;
}
.contact ul li:nth-child(2) {
  background-color: #E0DBCD;
}
.contact ul li + li {
  padding-top: 8%;
}

.trademark {
  position: relative;
  margin-top: 15%;
}
.trademark__img {
  position: absolute;
  width: 90.77%;
  margin: 0 auto;
  top: 15%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}
.trademark__logo {
  position: absolute;
  width: 55.4%;
  margin: 0 auto;
  top: 42%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}

.rate-card {
  margin: 0 0 26px;
  border: 1px solid rgba(212, 175, 55, 0.3);
  border-radius: 18px;
  overflow: hidden;
  background: #14161c;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.3);
}
.rate-card table {
  width: 100%;
  border-collapse: collapse;
}
.rate-card th,
.rate-card td {
  padding: 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 14px;
  letter-spacing: 0.08em;
}
.rate-card th:last-child,
.rate-card td:last-child {
  text-align: right;
}
.rate-card th {
  background: rgba(212, 175, 55, 0.16);
  font-weight: 700;
}

.notice {
  padding: 10px 12px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.8;
}

details.admin {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.12);
}
details.admin summary {
  cursor: pointer;
  list-style: none;
  padding: 12px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.08em;
}
details.admin summary::-webkit-details-marker {
  display: none;
}

.admin-inner {
  padding: 12px;
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}
.admin-inner label {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.72);
  display: block;
  margin-bottom: 4px;
  text-align: left;
}
.admin-inner input {
  width: 100%;
  background: rgba(0, 0, 0, 0.28);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  padding: 10px 12px;
  color: #fff;
  font-size: 15px;
  font-weight: 650;
  outline: none;
}
.admin-inner button {
  border-radius: 999px;
  border: 1px solid rgba(212, 175, 55, 0.3);
  background: rgba(212, 175, 55, 0.1);
  color: #d4af37;
  padding: 10px 14px;
  font-weight: 650;
  letter-spacing: 0.08em;
  cursor: pointer;
  white-space: nowrap;
}

h1 {
  margin: 0 0 14px;
  font-size: 28px;
  font-weight: 600;
  letter-spacing: 0.16em;
}

.sub {
  margin: 0 0 18px;
  font-size: 15px;
  line-height: 1.95;
  color: rgba(255, 255, 255, 0.72);
  letter-spacing: 0.1em;
}

.update-time {
  margin: 6px 0 14px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.55);
}

.btn {
  display: block;
  width: 100%;
  margin: 8px auto;
  padding: 18px 24px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 650;
  font-size: 16px;
  letter-spacing: 0.1em;
  border: none;
  transition: 0.18s ease;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.btn:hover {
  transform: translateY(-1px);
  opacity: 0.92;
}
.btn:active {
  transform: translateY(0);
  opacity: 1;
}
.btn.btn-line {
  background: #06C755;
  color: #fff;
}
.btn.btn-phone {
  background: #d4af37;
  color: #000;
}
.btn.btn-detail {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(212, 175, 55, 0.3);
  color: #d4af37;
  padding: 14px 20px;
  font-size: 14px;
  margin-bottom: 6px;
}

.assure {
  margin-top: 18px;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.78);
  letter-spacing: 0.1em;
}

.section {
  padding: 52px 0 72px;
}

.card {
  background: #15171d;
  border-radius: 18px;
  padding: 22px;
  margin: 12px 0;
  text-align: left;
  border: 1px solid rgba(255, 255, 255, 0.06);
}
.card b {
  display: block;
  margin-bottom: 10px;
  letter-spacing: 0.08em;
}
.card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.8;
  letter-spacing: 0.04em;
}

footer {
  padding: 1.016% 0;
}
footer p {
  margin: 0;
  font-size: clamp(1px, 3.33333vw, 13px);
  color: #FFF3D2;
}/*# sourceMappingURL=style.css.map */