﻿@charset "utf-8";

body {
  margin: 0;
  /*font-family: "Helvetica Neue",
    Arial,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    Meiryo,
    sans-serif;*/
  font-family: "Noto Serif JP", serif;
  background-color: #fff;
  color: #111;
  letter-spacing: 0.05em;
}

a[href^="tel:"] {
  color: #fff;
  text-decoration: none;
}

@media (min-width: 769px) {
  a[href^="tel:"] {
      pointer-events: none;
      cursor: default;
  }
}

.header p {
  margin: 0 0;
  padding: 15px 15px 15px 20px;
}

@media (max-width: 768px) {
  .header p {
    margin: 0 0;
    padding: 15px 15px 10px 20px;
  }

  .header p img {
    width: 38vw;
    height: auto;
  }
}

.hero {
  height: 75vh;
  background: url('img/mv-2.jpg') no-repeat center center / cover;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 0 20px;
}

.hero h1 {
  margin: 0;
  padding: 0;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.88);
  line-height: 1.5;
  color: #fff;
}

.hero h1 .hotel-name {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 600;
  font-size: 4rem;
}

.hero h1 .opening-date {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 600;
  font-size: 2.8rem;
  display: block;
}

.hero h1 .opening-date span {
  font-family: 'Times New Roman',serif;
  font-weight: 500;
}

.pc-none {
  display: none;
}
.sp-none {
  display: block;
}

.content {
  max-width: 800px;
  margin: 80px auto 80px;
  padding: 0 20px;
  text-align: center;
  line-height: 1.8;
}

.content h2 {
  font-size: 1.6rem;
  font-weight: normal;
}

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

.map iframe {
  width: 100%;
}

.appeal {
  background-color: #222;
  background: url('img/bg-marble-2.jpg') repeat center center;
  padding: 80px 0 40px;
}

.appeal .appeal-wedding,
.appeal .appeal-party,
.appeal .appeal-fitness {
  display: flex;
  max-width: 1260px;
  margin: 0 auto;
  align-items: center;
}

.appeal .appeal-wedding {
  justify-content: left;
}
.appeal .appeal-party {
  flex-direction: row-reverse;
  justify-content: right;
}
.appeal .appeal-fitness {
  justify-content: left;
}

.appeal .appeal-img {
  margin-bottom: 40px;
}
.appeal .appeal-text {
}
.appeal .appeal-text h5 {
  position: relative;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 600;
  font-size: 6rem;
  color: #666;
  margin: 0 0;
  margin-left: 1px;
  margin-top: -10px;
  z-index: 2;
}
.appeal .appeal-text p {
  padding-left: 60px;
  line-height: 1.6;
}
.appeal .text-right h5 {
  text-align: right;
  margin-left: unset;
  margin-right: 1px;
}
.appeal .text-right p {
  padding-left: 0;
  padding-right: 60px;
}

@media (max-width: 768px) {
  .appeal {
    padding: 10.25vw 0 5vw;
    margin-top: 10.25vw;
  }

  .appeal .appeal-wedding,
  .appeal .appeal-party,
  .appeal .appeal-fitness {
    display: flex;
    width: 90vw;
    max-width: unset;
    margin: 0 auto;
    margin-bottom: 8vw;
    align-items: normal;
    flex-direction: column;
  }
  .appeal .appeal-img {
    margin-bottom: 0;
  }
  .appeal .appeal-img img {
    width: 100%;
  }
  .appeal .appeal-text p {
    padding: 0 0;
    font-size: 3.84vw;
    width: 80vw;
    margin: 1em auto;
  }
  .appeal .appeal-text h5 {
    font-size: 18vw;
    text-align: center;
    margin-top: -5vw;
  }
}

.gradient-text {
  background: linear-gradient(to left, #444, #eee);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.text-right .gradient-text {
  background: linear-gradient(to right, #444, #eee);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

a.single-button {
  display: inline-block;
  margin: 0 0;
  padding: 10px 28px;
  color: #fff;
  text-decoration: none;
  border: 1px solid #888;
  transition: background 0.3s, color 0.3s;
}
a.single-button:hover {
  background-color: #f0f0f0;
  color: #000;
}
a.single-button i {
  font-size: 1.2em;
}

@media (max-width: 768px) {
  .text-right .gradient-text {
    background: linear-gradient(to left, #444, #eee);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  a.single-button {
    margin: 10px 0;
    padding: 10px 0;
    width: 100%;
    text-align: center;
  }
}

.buttons {
  margin: 30px 0;
}

.buttons a {
  display: inline-block;
  min-width: 200px;
  margin: 0 10px;
  padding: 12px 28px;
  background: linear-gradient(135deg, #a98c36, #d1b85a);
  color: #000;
  text-decoration: none;
  border: none;
  border-radius: 0;
  transition: background 0.3s, color 0.3s;
}

.buttons a i {
  margin-right: 2px;
  font-size: 1.4em;
  vertical-align: middle;
  margin-bottom: 2px;
}
.buttons a i.la-calendar-check {
  font-size: 1.6em;
}

.buttons a:hover {
  background: linear-gradient(135deg, #8a7330, #bfa046);
  color: #fff;
}

.gallery-section {
  max-width: 1198px;
  margin: 40px auto;
  padding: 0 20px;
  overflow: hidden;
  margin-top: 80px;
}

.swiper {
  width: 100%;
  overflow: visible;
  position: relative;
}

.swiper-slide {
  position: relative;
  text-align: center;
}

.caption {
  margin-top: 8px;
  font-size: 0.9em;
  color: #333;
}

.swiper-slide img {
  width: 100%;
  height: auto;
  border-radius: 0;
}

.swiper-button-prev,
.swiper-button-next {
  color: #666;
  font-size: 2rem;
  width: auto;
  height: auto;
  top: 50%;
  margin-top: -32px;
  z-index: 10;
  cursor: pointer;
}

.swiper-button-prev {
  left: -25px;
}

.swiper-button-next {
  right: -25px;
}

.swiper-button-prev i,
.swiper-button-next i {
  pointer-events: none; /* 子要素でクリックがブロックされないように */
}

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after,
.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
  content: none;
}

footer {
  background-color: #4a6fa1;
  padding: 40px 0;
  text-align: center;
  font-size: 0.9rem;
  color: #fff;
  line-height: 2;
}
footer p {
  margin-top: 0;
  color: #fff;
  font-size: 1.6rem;
  line-height: 1.6;
}
footer p span {
  display: block;
  font-size: 1.4rem;
  font-family: 'Cormorant Garamond', serif;
}

.copyright {
  background-color: #a7b5cf;
  padding: 15px 0;
  text-align: center;
  color: #111;
  font-size: 0.8rem;
}

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

  .hero {
    height: 60vh;
  }
  .hero h1 .hotel-name {
    font-size: 8.8vw;
  }
  .hero h1 .opening-date {
    font-size: 6.8vw;
  }

  .content  {
    margin: 50px auto 50px;
  }
  .content h2 {
    font-size: 5.12vw;
    line-height: 2;
  }
  .content p {
    text-align: left;
    font-size: 3.84vw;
  }

  .map {
    width: 90vw;
  }
  .map iframe {
    max-height: 45vh;
  }

  .buttons a {
    width: 60vw;
    margin-bottom: 1em;
  }

  footer {
    font-size: 3.84vw;
  }
  footer p {
    font-size: 5.64vw;
  }
  footer p img {
    width: 60vw;
    height: auto;
  }
  footer p span {
    font-size: 5.12vw;
  }
  .copyright {
    font-size: 3.58vw;
  }

  .concept p {
    text-align: center;
  }
}

.title-en {
  font-size: 3rem;
  font-family: 'Cormorant Garamond', serif;
  color: #ddd;
}

/* 固定ボタン */
.floating-buttons {
  position: fixed;
  top: 20px;
  right: 20px;
  display: flex;
  flex-direction: row;
  gap: 10px;
  z-index: 1000;
}

.floating-buttons a {
  background-color: #e04c4c;
  color: #fff;
  padding: 13px 22px 10px;
  border-radius: 0;
  font-size: 14px;
  text-decoration: none;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  transition: background 0.3s, color 0.3s;
  white-space: nowrap;
  text-align: center;
  min-width: 120px;
  min-height: 25px;
}
.floating-buttons a.contact {
  background-color: #4a6fa1;
}

.floating-buttons a:hover {
  background-color: #d16c47;
}
.floating-buttons a.contact:hover {
  background-color: #4AA19B;
}

.floating-buttons i {
  margin-right: 2px;
  font-size: 1.4em;
  vertical-align: middle;
  margin-bottom: 2px;
}
.floating-buttons i.la-calendar-check {
  font-size: 1.6em;
}

@media (max-width: 768px) {
  .floating-buttons {
    top: 25px;
  }
  .floating-buttons a {
    padding: 11px 18px 10px;
    min-width: unset;
  }
}
