@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
/* CSS Reset */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}
body {
  line-height: 1;
}
ol, ul {
  list-style: none;
}
blockquote, q {
  quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
/*common*/
body, html {
  height: 100%;
  font-family: 'Noto Sans JP', sans-serif;
  color: #000000;
}
img {
  max-width: 100%;
  height: auto;
}
a {
  color: #000;
}
a img {
  transition: 0.3s;
}
a:hover img {
  transition: 0.3s;
  opacity: 0.7;
}
p {
  line-height: 2;
}

.en {
  font-family: 'Kumbh Sans', 'Noto Sans JP', sans-serif;
  letter-spacing: 0.02em;
}
.wrap {
  max-width: 1440px;
  padding: 0 20px;
  margin: auto;
}
.flex {
  display: flex;
}

.ttl {
  text-align: center;
}
.ttl .en {
  font-size: 48px;
  font-weight: 700;
  letter-spacing: 0.16em;
}
.ttl h2 {
  font-size:18px;
  font-weight: 600;
  letter-spacing: 0.06em;
  margin: 22px 0 0;
}

.pc {
  display: block;
}
.sp {
  display: none;
}
.btn a {
  display: block;
  width: 190px;
  margin: auto;
  border: 1px solid #0c0303;
  padding: 20px 0;
  color: #0c0303;
  text-decoration: none;
  transition: 0.3s;
  text-align: center;
  letter-spacing: 0.1em;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 16px;
}
.btn a:hover {
  background-color: #0c0303;
  transition: 0.3s;
  color: #fff;
}
.btn a span {
  padding: 0 0 0 2vw;
  position: relative;
  top: 2px;
}

.wp-pagenavi {
  text-align: center;
  margin: 120px 0 160px;
  position: relative;
}

.wp-pagenavi a, 
.wp-pagenavi span {
  display: inline-block;
  padding:0;
  line-height: 44px;
  width: 44px;
  margin: 0 10px;
  text-decoration: none;
  color: #333;
  border-radius: 100vw;
  transition: all 0.3s;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 18px;
  border: 1px solid #000;
}
.wp-pagenavi .pages {
  display: none;
}

.wp-pagenavi a:hover {
  background: #333;
  color: #fff;
}

.wp-pagenavi .current {
  background: #333;
  color: #fff;
  font-weight: bold;
}

.wp-pagenavi a.nextpostslink,
.wp-pagenavi a.previouspostslink {
  color: #000;
  --arrow-size: 20px;   /* くの字の一辺 */
  --arrow-stroke: 1px;  /* 線の太さ */
  border: none;
  background: none;
  text-indent: -9999px;
  font-size: 0;
  bottom: -2px;
  line-height: 1;
  width: auto;
  position: relative;
  top:5px;
}

.wp-pagenavi a.nextpostslink::before,
.wp-pagenavi a.previouspostslink::before{
  content: "";
  display: block;
  width: var(--arrow-size);
  height: var(--arrow-size);
  border-style: solid;
  border-color: currentColor;
  border-width: var(--arrow-stroke) var(--arrow-stroke) 0 0;
  transform-origin: 50% 50%;
  transition: transform .2s ease;
  font-size: 0;
  opacity: 1;
}

/* 向きだけを変える（左：-135deg / 右：45deg） */
.wp-pagenavi a.nextpostslink{
  transform: rotate(45deg);
  left: 35px;
}
.wp-pagenavi a.previouspostslink{
  transform: rotate(-135deg);
  right: 35px;
}



@media (max-width: 768px) {
  body {
    font-size: 13px;
  }
  img {
    max-width: 100%;
    height: auto;
  }
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
	p {
		line-height: 1.75;
	}
.ttl .en {
  font-size: 7.6vw;
	letter-spacing: 0.08em;
}
.ttl h2 {
  font-size:3.2vw;
  margin: 3vw 0 0;
}
  .btn a {
    width:40vw;
    padding:4.5vw 0;
	font-size:3.2vw;
  }
  .btn a span {
    font-size:3.4vw;
  }
  .btn a span:nth-child(2) {
    font-size:2.4vw;
    padding: 8px 0 0;
  }
  .c_ttl {
    font-size: 6.8vw;
  }
  .slick-dotted.slick-slider {
    margin-bottom: 30px;
}
.slick-dots {
    bottom: -30px;
}
  
.wp-pagenavi {
  margin: 10vw 0 20vw;
}

.wp-pagenavi a, 
.wp-pagenavi span {
  line-height: 10vw;
  width: 10vw;
  margin: 0 1.2vw;
  font-size: 3.7vw;
}

/* 向きだけを変える（左：-135deg / 右：45deg） */
.wp-pagenavi a.nextpostslink{
  left: 6vw;
}
.wp-pagenavi a.previouspostslink{
  right: 6vw;
}

  
}
/*header*/
.header {
  position: absolute;
  top: 0;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 10;
  transition: transform 0.7s ease-in-out;
}
.header.highlight {
  transform: translateY(-100%);
  transition: transform 0.7s ease-in-out;
  background: #000;
}
.header.highlight.fixed {
    position: fixed;
  transform: translateY(0);
   transition: transform 0.7s ease-in-out;
}
.header.scroll-up {
  position: fixed;
}
.container {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  position: relative;
}
.logo {
  position: absolute;
  left: 50%;
  top: 30px;
  transform: translateX(-50%);
  opacity: 0;
  z-index: -1;
}
.header.highlight .logo {
  opacity: 1;
  z-index: 1;
}
.nav {
  display: flex;
  align-items: center;
  padding: 30px 30px 0 0;
  gap: 30px;
}

.header.highlight .nav {
    padding: 15px 30px 15px 0;
}
.header .nav .header-logo {
    display: none;
  }
  .header.highlight .nav .header-logo{
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: block;
  }
.nav ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin: 0;
  padding: 0;
}
.nav ul li:not(:last-child)::after {
  content: "/";
  margin-left: 15px; /* ・の間隔を調整 */
  color: #fff;
  font-size: 16px;
}
.nav a {
  color: #fff;
  text-decoration: none;
  font-size: 1rem;
  font-weight: 600;
  transition: 0.3s;
  letter-spacing: 0.1em;
  font-family: 'Montserrat', sans-serif;
}
.nav a:hover {
  opacity: 0.6;
  transition: 0.3s;
}
.nav .contact a {
  border: 1px solid #fff;
  padding: 16px 30px;
  display: block;
}

.hamburger-menu {
  width: 50px;
  height: 50px;
  border: 1px solid #fff;
  border-radius: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  position: absolute;
  z-index: 100;
  top: 30px;
  left: 40px;
  transition: border-color 0.3s ease;
}
.fixed .hamburger-menu {
  top: 12px;
}

.hamburger-menu .bar {
  position: absolute;
  width: 24px;
  height: 1px;
  background-color: #fff;
  border-radius: 2px;
  transition: all 0.4s ease;
}

.hamburger-menu .bar:nth-child(1) {
  top:17px;
  width: 14px;
  left: 13px;
}

.hamburger-menu .bar:nth-child(2) {
  top: 24px;
  width: 19px;
  left: 13px;
}

.hamburger-menu .bar:nth-child(3) {
  top: 30px;
}

/* active状態（×になる） */
.hamburger-menu.active {
border: 1px solid #000;
}
.hamburger-menu.active .bar {
  background-color: #000;
}
.hamburger-menu.active .bar:nth-child(1) {
  transform: rotate(30deg);
  top: 23px;
  width: 24px;
}

.hamburger-menu.active .bar:nth-child(2) {
  opacity: 0;
}

.hamburger-menu.active .bar:nth-child(3) {
  transform: rotate(-30deg);
  top: 23px;
}


.nav-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 360px;
  height: 100vh;
  background: rgba(255, 255, 255, 0.7);
  transform: translateX(-100%);
  opacity: 0;
  transition: transform 0.4s ease-in-out, opacity 0.4s ease-in-out;
  z-index: 1;
  pointer-events: none;
  /* 背景だけをぼかす */
  backdrop-filter: blur(30px) brightness(1.15);
  -webkit-backdrop-filter: blur(30px) brightness(1.15);
}


.nav-menu ul {
  list-style: none;
  padding: 120px 45px 20px;
  margin: 0;
}

.nav-menu li {
  margin: 40px 0;
}

.nav-menu a {
  text-decoration: none;
  font-size: 1.25rem;
  transition: 0.3s;
}

.nav-menu a:hover {
  color: #a47215;
  transition: 0.3s;
}

.nav-menu.active {
  transform: translateX(0);
  opacity: 1;
  pointer-events: auto; /* 表示中はクリック可 */
}
@media (max-width: 1530px) {
  .nav ul {
    display: none;
  }
}
.nav ul li:not(:last-child)::after {
  margin-left: 15px; /* ・の間隔を調整 */
}
.nav a {
  font-size: 0.9rem;
}
@media (max-width: 1680px) {
  .nav ul {
    gap: 5px;
  }
  .header.highlight.fixed .nav ul {
    gap: 5px;
  }
  .nav ul li:not(:last-child)::after {
    margin-left: 5px; /* ・の間隔を調整 */
  }
  .nav a {
    font-size: 0.9rem;
  }
}
@media (max-width: 1520px) {
  .nav ul {
    gap: 10px 5px;
  }
  .nav ul li:not(:last-child)::after {
    margin-left: 5px; /* ・の間隔を調整 */
  }
  .nav a {
    font-size: 0.9rem;
  }
}

@media (max-width: 768px) {
  .logo {
    top: 20px;
    width: 32vw;
    opacity: 1;
  }

.hamburger-menu.active {
border: 1px solid #fff;
}
.hamburger-menu.active .bar {
  background-color: #fff;
}
	
  .hamburger-menu {
    top: 15px;
    left: 4%;
  }
  .nav-menu {
    width: 100%;
	  background-color: #000;
  }
  .nav-menu ul {
    list-style: none;
    padding: 28vw 5vw 20px;
    margin: 0;
  }
	.nav-menu li {
		margin: 0;
}
  .menu-text {
    left:-1%;
    font-size: 0.75rem;
    top: 30px;
  }
  .hamburger-menu.active .menu-text {
    left: -8%;
  }
  .nav {
    padding:  0;
  }
  

  .header.highlight .nav {
    padding: 0;
    
  }
  .nav-menu a {
	  font-size: 4.2vw;
	  color: #fff;
	  border-bottom: 1px solid #808080;
	  display: block;
	  padding: 5.5vw 3vw;
	  font-family: 'Montserrat', sans-serif;
	  font-weight: 600;
  }
	.nav .contact a {
		padding: 10px;
		margin: 18px 3vw;
		font-size: 2.9vw;
		font-family: 'Montserrat', sans-serif;
		font-weight: 600;
	}
	
	.nav-menu .header-logo {
		position: absolute;
		top: 20px;
		left: 28vw;
		width: 37vw;
	}
  	.nav-menu .header-logo a{
		padding: 0;
      border: none;
	}
	.nav-menu .contact {
		position: absolute;
		top: 0;
		right: 0;
	}
	.nav-menu .contact a {
        padding: 10px;
        margin: 18px 3vw;
	font-size: 2.9vw;
		display: inline-block;
		color: #fff;
    letter-spacing: 0.1em;
    font-family: 'Montserrat', sans-serif;
		font-weight: 600;
		border: 1px solid #fff;
    }
}
/*footer*/
.footer {
  padding: 80px 0 25px;
}
.footer .info h2 {
  text-align: center;
  margin: 0 0 25px;
}
.footer .info h3 {
  text-align: center;
  font-size: 18px;
  font-weight: 600;
}
.footer .info p {
  text-align: center;
  margin: 10px 0 0;
}
.footer .info .btn_wrap.wide {
  margin: 40px 0 90px;
}
.footer .btn_wrap .btn a {
  width: 468px;
  padding: 25px 0;
  border: 2px solid #000;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 20px;
}
.footer .btn_wrap .btn a span{
  display: block;
  font-size: 13px;
  margin: 10px 0 0;
}
.footer .inst {
  text-align: center;
}
.footer .inst a {
  text-decoration: none;
  font-weight: bold;
}
.footer .inst a p {
  margin: 10px 0 0;
  font-weight: 600;
  letter-spacing: 0.06em;
}
.footer .copy p {
  text-align: center;
  font-size: 12px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  margin: 20px 0 0;
}
@media (max-width: 768px) {
  .footer {
    padding: 15vw 0 4vw;
  }
.footer .info h2 {
  margin: 0 auto 5.2vw;
	width: 72vw;
}
.footer .info h3 {
  font-size: 4vw;
}
.footer .info p {
  margin: 2.6vw 0 0;
}
.footer .info .btn_wrap.wide {
  margin: 4.5vw 0 13vw;
}
.footer .btn_wrap .btn a {
  width: 84vw;
  padding: 4.7vw 0;
  font-size: 4.2vw;
}
.footer .btn_wrap .btn a span{
  font-size: 3.2vw;
  margin: 1.5vw 0 0;
}
.footer .inst img{
	width: 12vw;
	margin: auto;
}
.footer .inst a {
  text-decoration: none;
  font-weight: bold;
}
.footer .inst a p {
  margin:1.6vw 0 0;
	font-size: 3.2vw;
}
.footer .copy p {
  font-size: 2.9vw;
  margin: 4.2vw 0 0;
}
}


#access {
  padding: 160px 0 100px;
  border-bottom: 1px solid #000;
}
#access .inn .box {
  display: flex;
  align-items: center;
  justify-content:flex-start;
}
#access .inn .box .map {
  max-width: 1130px;
  width: 100%;
}
#access .inn .box .map iframe {
  width: 100%;
}
#access .inn .box .text {
  text-align: left;
  width: 570px;
  padding: 0 40px 0 100px;
}
#access .inn .box .text h2 {
  font-size: 48px;
  font-weight: 700;
  margin: 0 0 55px;
}
#access .inn .box .text_area .text p {
  font-weight: bold;
  font-size: clamp(15.38px, 1.25vw, 21.06px);
  letter-spacing: clamp(.77px, .06vw, 1.05px);
  line-height: 1.6;
}
#access .inn .box .text_area .text p:first-child {
  margin: 0 0 3em;
}


#access .inn .box .text_area .text .transport {
    width: 100%;
  margin: 0 0 40px;
}
#access .inn .box .text_area .text .transport h3 {
  font-size: 24px;
  margin: 0 0 18px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
}
#access .inn .box .text_area .text .route {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 25px 0;
  font-size: clamp(13.38px, 1.25vw, 18.06px);
  letter-spacing: clamp(.77px, .06vw, 1.05px);
}
#access .inn .box .text_area .text .route span {
  font-size: 18px;
  font-weight: 600;
}
#access .inn .box .text_area .text .line {
    flex-grow: 1;
    height:4px;
    background-image: url("../img/common/border.svg");
  background-repeat: repeat-x;
  background-position: center right;
    margin: 0 10px;
}

#access .inn .box .text_area .btn {
  margin: 5rem 0 0;
}

@media (max-width: 768px) {
#access {
  padding:22vw 0 0;
}
#access .inn .box {
  flex-wrap: wrap;
	width: 100%;
}
#access .inn .box .map {
  max-width: auto;
	order: 2;
}
	#access .inn .box .map iframe {
		height: 64vw;
	}
#access .inn .box .text_area {
  width: 100%;
}
#access .inn .box .text {
  width: 100%;
  padding: 0 5vw 6vw;
box-sizing: border-box;
}
#access .inn .box .text h2 {
  font-size: 7.6vw;
	text-align: center;
  margin: 0 0 9vw;
}
#access .inn .box .text_area .text p {
  font-size: clamp(15.38px, 1.25vw, 21.06px);
  letter-spacing: clamp(.77px, .06vw, 1.05px);
  line-height: 1.6;
}
#access .inn .box .text_area .text p:first-child {
  margin: 0 0 3em;
}


#access .inn .box .text_area .text .transport {
    width: 100%;
  margin: 0 0 8vw;
}

#access .inn .box .text_area .text .transport > div{
	font-size: 3.4vw;
	margin: 3vw 0 0;
}
#access .inn .box .text_area .text .transport h3 {
  font-size: 4.8vw;
  margin: 0 0 3.2vw;
}
#access .inn .box .text_area .text .route {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 2vw 0;

}
#access .inn .box .text_area .text .route span {
  font-size:3.7vw;
}
#access .inn .box .text_area .text .line {
    margin: 0 2vw;
}

#access .inn .box .text_area .btn {
  margin: 5rem 0 0;
}
}